blob: ae3a17c791f6f530ad6c8b95d63fa862b2c24e82 [file] [log] [blame]
Kukjin Kim1355bbc2012-10-24 13:41:15 +09001/*
2 * SAMSUNG EXYNOS5440 SoC device tree source
3 *
4 * Copyright (c) 2012 Samsung Electronics Co., Ltd.
5 * http://www.samsung.com
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10*/
11
Andrzej Hajda86feafe2014-02-26 09:53:31 +090012#include <dt-bindings/clock/exynos5440.h>
Padmavathi Venna37992792013-06-18 00:02:08 +090013#include "skeleton.dtsi"
Kukjin Kim1355bbc2012-10-24 13:41:15 +090014
15/ {
Sachin Kamat8bdb31b2014-03-21 02:17:22 +090016 compatible = "samsung,exynos5440", "samsung,exynos5";
Kukjin Kim1355bbc2012-10-24 13:41:15 +090017
18 interrupt-parent = <&gic>;
19
Girish K Sdabd3f92013-06-18 06:35:14 +090020 aliases {
21 spi0 = &spi_0;
Amit Daniel Kachhap5c7311b2013-07-24 14:27:16 +090022 tmuctrl0 = &tmuctrl_0;
23 tmuctrl1 = &tmuctrl_1;
24 tmuctrl2 = &tmuctrl_2;
Girish K Sdabd3f92013-06-18 06:35:14 +090025 };
26
Lee Jones644a79a2013-08-06 03:05:02 +090027 clock: clock-controller@160000 {
Thomas Abrahamd8bafc82013-03-09 17:11:33 +090028 compatible = "samsung,exynos5440-clock";
29 reg = <0x160000 0x1000>;
30 #clock-cells = <1>;
31 };
32
Tomasz Figa0572b722013-12-19 03:17:54 +090033 gic: interrupt-controller@2E0000 {
Kukjin Kim1355bbc2012-10-24 13:41:15 +090034 compatible = "arm,cortex-a15-gic";
35 #interrupt-cells = <3>;
36 interrupt-controller;
Giridhar Maruthy3279dd32013-04-04 15:25:00 +090037 reg = <0x2E1000 0x1000>,
38 <0x2E2000 0x1000>,
39 <0x2E4000 0x2000>,
40 <0x2E6000 0x2000>;
41 interrupts = <1 9 0xf04>;
Kukjin Kim1355bbc2012-10-24 13:41:15 +090042 };
43
44 cpus {
Kukjin Kimf5108e12012-12-06 16:54:10 +090045 #address-cells = <1>;
46 #size-cells = <0>;
47
Kukjin Kim1355bbc2012-10-24 13:41:15 +090048 cpu@0 {
Lorenzo Pieralisi88e41842013-04-18 18:32:40 +010049 device_type = "cpu";
Kukjin Kim1355bbc2012-10-24 13:41:15 +090050 compatible = "arm,cortex-a15";
Kukjin Kimf5108e12012-12-06 16:54:10 +090051 reg = <0>;
Kukjin Kim1355bbc2012-10-24 13:41:15 +090052 };
53 cpu@1 {
Lorenzo Pieralisi88e41842013-04-18 18:32:40 +010054 device_type = "cpu";
Kukjin Kim1355bbc2012-10-24 13:41:15 +090055 compatible = "arm,cortex-a15";
Kukjin Kimf5108e12012-12-06 16:54:10 +090056 reg = <1>;
Kukjin Kim1355bbc2012-10-24 13:41:15 +090057 };
58 cpu@2 {
Lorenzo Pieralisi88e41842013-04-18 18:32:40 +010059 device_type = "cpu";
Kukjin Kim1355bbc2012-10-24 13:41:15 +090060 compatible = "arm,cortex-a15";
Kukjin Kimf5108e12012-12-06 16:54:10 +090061 reg = <2>;
Kukjin Kim1355bbc2012-10-24 13:41:15 +090062 };
63 cpu@3 {
Lorenzo Pieralisi88e41842013-04-18 18:32:40 +010064 device_type = "cpu";
Kukjin Kim1355bbc2012-10-24 13:41:15 +090065 compatible = "arm,cortex-a15";
Kukjin Kimf5108e12012-12-06 16:54:10 +090066 reg = <3>;
Kukjin Kim1355bbc2012-10-24 13:41:15 +090067 };
68 };
69
Subash Patel4c46f512013-04-05 15:22:59 +090070 arm-pmu {
71 compatible = "arm,cortex-a15-pmu", "arm,cortex-a9-pmu";
72 interrupts = <0 52 4>,
73 <0 53 4>,
74 <0 54 4>,
75 <0 55 4>;
76 };
77
Kukjin Kimf5108e12012-12-06 16:54:10 +090078 timer {
79 compatible = "arm,cortex-a15-timer",
80 "arm,armv7-timer";
81 interrupts = <1 13 0xf08>,
82 <1 14 0xf08>,
83 <1 11 0xf08>,
84 <1 10 0xf08>;
85 clock-frequency = <50000000>;
86 };
87
Amit Daniel Kachhap7f7b8ed2013-04-08 21:48:17 +090088 cpufreq@160000 {
89 compatible = "samsung,exynos5440-cpufreq";
90 reg = <0x160000 0x1000>;
91 interrupts = <0 57 0>;
92 operating-points = <
93 /* KHz uV */
Amit Daniel Kachhapafbbf922013-06-18 06:39:41 +090094 1500000 1100000
95 1400000 1075000
96 1300000 1050000
Amit Daniel Kachhap7f7b8ed2013-04-08 21:48:17 +090097 1200000 1025000
Amit Daniel Kachhapafbbf922013-06-18 06:39:41 +090098 1100000 1000000
Amit Daniel Kachhap7f7b8ed2013-04-08 21:48:17 +090099 1000000 975000
Amit Daniel Kachhapafbbf922013-06-18 06:39:41 +0900100 900000 950000
Amit Daniel Kachhap7f7b8ed2013-04-08 21:48:17 +0900101 800000 925000
102 >;
103 };
104
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900105 serial@B0000 {
106 compatible = "samsung,exynos4210-uart";
107 reg = <0xB0000 0x1000>;
108 interrupts = <0 2 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900109 clocks = <&clock CLK_B_125>, <&clock CLK_B_125>;
Thomas Abraham6a0338c2013-03-09 17:19:17 +0900110 clock-names = "uart", "clk_uart_baud0";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900111 };
112
113 serial@C0000 {
114 compatible = "samsung,exynos4210-uart";
115 reg = <0xC0000 0x1000>;
116 interrupts = <0 3 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900117 clocks = <&clock CLK_B_125>, <&clock CLK_B_125>;
Thomas Abraham6a0338c2013-03-09 17:19:17 +0900118 clock-names = "uart", "clk_uart_baud0";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900119 };
120
Girish K Sdabd3f92013-06-18 06:35:14 +0900121 spi_0: spi@D0000 {
122 compatible = "samsung,exynos5440-spi";
123 reg = <0xD0000 0x100>;
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900124 interrupts = <0 4 0>;
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900125 #address-cells = <1>;
126 #size-cells = <0>;
Girish K Sdabd3f92013-06-18 06:35:14 +0900127 samsung,spi-src-clk = <0>;
128 num-cs = <1>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900129 clocks = <&clock CLK_B_125>, <&clock CLK_SPI_BAUD>;
Thomas Abraham6a0338c2013-03-09 17:19:17 +0900130 clock-names = "spi", "spi_busclk0";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900131 };
132
Jingoo Hanb342e642013-06-21 16:26:14 +0900133 pin_ctrl: pinctrl {
Thomas Abrahamf6925432012-12-27 13:25:02 -0800134 compatible = "samsung,exynos5440-pinctrl";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900135 reg = <0xE0000 0x1000>;
Thomas Abraham71d87da2013-04-05 15:20:03 +0900136 interrupts = <0 37 0>, <0 38 0>, <0 39 0>, <0 40 0>,
137 <0 41 0>, <0 42 0>, <0 43 0>, <0 44 0>;
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900138 interrupt-controller;
139 #interrupt-cells = <2>;
Thomas Abrahamb1ce1012012-10-24 17:18:52 +0900140 #gpio-cells = <2>;
141
142 fan: fan {
143 samsung,exynos5440-pin-function = <1>;
144 };
145
146 hdd_led0: hdd_led0 {
147 samsung,exynos5440-pin-function = <2>;
148 };
149
150 hdd_led1: hdd_led1 {
151 samsung,exynos5440-pin-function = <3>;
152 };
153
154 uart1: uart1 {
155 samsung,exynos5440-pin-function = <4>;
156 };
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900157 };
158
159 i2c@F0000 {
Giridhar Maruthy49498c52012-12-28 09:33:58 -0800160 compatible = "samsung,exynos5440-i2c";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900161 reg = <0xF0000 0x1000>;
162 interrupts = <0 5 0>;
163 #address-cells = <1>;
164 #size-cells = <0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900165 clocks = <&clock CLK_B_125>;
Thomas Abraham6a0338c2013-03-09 17:19:17 +0900166 clock-names = "i2c";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900167 };
168
169 i2c@100000 {
Giridhar Maruthy49498c52012-12-28 09:33:58 -0800170 compatible = "samsung,exynos5440-i2c";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900171 reg = <0x100000 0x1000>;
172 interrupts = <0 6 0>;
173 #address-cells = <1>;
174 #size-cells = <0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900175 clocks = <&clock CLK_B_125>;
Thomas Abraham6a0338c2013-03-09 17:19:17 +0900176 clock-names = "i2c";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900177 };
178
Sachin Kamat64f5d1e2014-05-28 00:56:26 +0900179 watchdog@110000 {
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900180 compatible = "samsung,s3c2410-wdt";
181 reg = <0x110000 0x1000>;
182 interrupts = <0 1 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900183 clocks = <&clock CLK_B_125>;
Thomas Abraham6a0338c2013-03-09 17:19:17 +0900184 clock-names = "watchdog";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900185 };
186
Byungho Anc038c4d2013-04-05 15:22:58 +0900187 gmac: ethernet@00230000 {
188 compatible = "snps,dwmac-3.70a";
189 reg = <0x00230000 0x8000>;
190 interrupt-parent = <&gic>;
191 interrupts = <0 31 4>;
192 interrupt-names = "macirq";
193 phy-mode = "sgmii";
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900194 clocks = <&clock CLK_GMAC0>;
Byungho Anc038c4d2013-04-05 15:22:58 +0900195 clock-names = "stmmaceth";
196 };
197
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900198 amba {
199 #address-cells = <1>;
200 #size-cells = <1>;
201 compatible = "arm,amba-bus";
202 interrupt-parent = <&gic>;
203 ranges;
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900204 };
205
206 rtc {
207 compatible = "samsung,s3c6410-rtc";
208 reg = <0x130000 0x1000>;
Giridhar Maruthye877a5a2012-12-27 18:02:58 -0800209 interrupts = <0 17 0>, <0 16 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900210 clocks = <&clock CLK_B_125>;
Thomas Abraham6a0338c2013-03-09 17:19:17 +0900211 clock-names = "rtc";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900212 };
Girish K S1a12f522013-06-10 17:29:34 +0900213
Amit Daniel Kachhap5c7311b2013-07-24 14:27:16 +0900214 tmuctrl_0: tmuctrl@160118 {
215 compatible = "samsung,exynos5440-tmu";
216 reg = <0x160118 0x230>, <0x160368 0x10>;
217 interrupts = <0 58 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900218 clocks = <&clock CLK_B_125>;
Amit Daniel Kachhap5c7311b2013-07-24 14:27:16 +0900219 clock-names = "tmu_apbif";
220 };
221
222 tmuctrl_1: tmuctrl@16011C {
223 compatible = "samsung,exynos5440-tmu";
224 reg = <0x16011C 0x230>, <0x160368 0x10>;
225 interrupts = <0 58 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900226 clocks = <&clock CLK_B_125>;
Amit Daniel Kachhap5c7311b2013-07-24 14:27:16 +0900227 clock-names = "tmu_apbif";
228 };
229
230 tmuctrl_2: tmuctrl@160120 {
231 compatible = "samsung,exynos5440-tmu";
232 reg = <0x160120 0x230>, <0x160368 0x10>;
233 interrupts = <0 58 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900234 clocks = <&clock CLK_B_125>;
Amit Daniel Kachhap5c7311b2013-07-24 14:27:16 +0900235 clock-names = "tmu_apbif";
236 };
237
Girish K S1a12f522013-06-10 17:29:34 +0900238 sata@210000 {
239 compatible = "snps,exynos5440-ahci";
240 reg = <0x210000 0x10000>;
241 interrupts = <0 30 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900242 clocks = <&clock CLK_SATA>;
Girish K S1a12f522013-06-10 17:29:34 +0900243 clock-names = "sata";
244 };
245
Thomas Abrahama3808902013-06-12 04:58:34 +0900246 ohci@220000 {
247 compatible = "samsung,exynos5440-ohci";
248 reg = <0x220000 0x1000>;
249 interrupts = <0 29 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900250 clocks = <&clock CLK_USB>;
Thomas Abrahama3808902013-06-12 04:58:34 +0900251 clock-names = "usbhost";
252 };
253
254 ehci@221000 {
255 compatible = "samsung,exynos5440-ehci";
256 reg = <0x221000 0x1000>;
257 interrupts = <0 29 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900258 clocks = <&clock CLK_USB>;
Thomas Abrahama3808902013-06-12 04:58:34 +0900259 clock-names = "usbhost";
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900260 };
Jingoo Han406a9322013-06-21 16:25:51 +0900261
262 pcie@290000 {
263 compatible = "samsung,exynos5440-pcie", "snps,dw-pcie";
264 reg = <0x290000 0x1000
265 0x270000 0x1000
266 0x271000 0x40>;
267 interrupts = <0 20 0>, <0 21 0>, <0 22 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900268 clocks = <&clock CLK_PR0_250_O>, <&clock CLK_PB0_250_O>;
Jingoo Han406a9322013-06-21 16:25:51 +0900269 clock-names = "pcie", "pcie_bus";
270 #address-cells = <3>;
271 #size-cells = <2>;
272 device_type = "pci";
273 ranges = <0x00000800 0 0x40000000 0x40000000 0 0x00001000 /* configuration space */
274 0x81000000 0 0 0x40001000 0 0x00010000 /* downstream I/O */
275 0x82000000 0 0x40011000 0x40011000 0 0x1ffef000>; /* non-prefetchable memory */
276 #interrupt-cells = <1>;
277 interrupt-map-mask = <0 0 0 0>;
278 interrupt-map = <0x0 0 &gic 53>;
Jingoo Han4b1ced82013-07-31 17:14:10 +0900279 num-lanes = <4>;
Jingoo Han331d7d62013-10-29 15:12:34 +0900280 status = "disabled";
Jingoo Han406a9322013-06-21 16:25:51 +0900281 };
282
283 pcie@2a0000 {
284 compatible = "samsung,exynos5440-pcie", "snps,dw-pcie";
285 reg = <0x2a0000 0x1000
286 0x272000 0x1000
287 0x271040 0x40>;
288 interrupts = <0 23 0>, <0 24 0>, <0 25 0>;
Andrzej Hajda86feafe2014-02-26 09:53:31 +0900289 clocks = <&clock CLK_PR1_250_O>, <&clock CLK_PB0_250_O>;
Jingoo Han406a9322013-06-21 16:25:51 +0900290 clock-names = "pcie", "pcie_bus";
291 #address-cells = <3>;
292 #size-cells = <2>;
293 device_type = "pci";
294 ranges = <0x00000800 0 0x60000000 0x60000000 0 0x00001000 /* configuration space */
295 0x81000000 0 0 0x60001000 0 0x00010000 /* downstream I/O */
296 0x82000000 0 0x60011000 0x60011000 0 0x1ffef000>; /* non-prefetchable memory */
297 #interrupt-cells = <1>;
298 interrupt-map-mask = <0 0 0 0>;
299 interrupt-map = <0x0 0 &gic 56>;
Jingoo Han4b1ced82013-07-31 17:14:10 +0900300 num-lanes = <4>;
Jingoo Han331d7d62013-10-29 15:12:34 +0900301 status = "disabled";
Jingoo Han406a9322013-06-21 16:25:51 +0900302 };
Kukjin Kim1355bbc2012-10-24 13:41:15 +0900303};