blob: 2f5107ffeef047e4cce0d9925ae6d8fbc3f60079 [file] [log] [blame]
Linus Walleij978577e2013-04-08 11:38:50 +02001/*
2 * Device Tree for the ST-Ericsson U300 Machine and SoC
3 */
4
5/dts-v1/;
6/include/ "skeleton.dtsi"
7
8/ {
9 model = "ST-Ericsson U300";
10 compatible = "stericsson,u300";
11 #address-cells = <1>;
12 #size-cells = <1>;
13
14 chosen {
15 bootargs = "root=/dev/ram0 console=ttyAMA0,115200n8 earlyprintk";
16 };
17
18 aliases {
19 serial0 = &uart0;
20 serial1 = &uart1;
21 };
22
23 memory {
24 reg = <0x48000000 0x03c00000>;
25 };
26
Linus Walleijecf5b392013-04-19 10:51:59 +020027 s365 {
28 compatible = "stericsson,s365";
29 vana15-supply = <&ab3100_ldo_d_reg>;
Linus Walleijcf0ce092013-05-22 16:15:13 +020030 syscon = <&syscon>;
31 };
32
33 syscon: syscon@c0011000 {
Linus Walleij7fca1f22013-06-13 21:21:31 +020034 compatible = "stericsson,u300-syscon", "syscon";
Linus Walleijcf0ce092013-05-22 16:15:13 +020035 reg = <0xc0011000 0x1000>;
Linus Walleij14c26072013-05-23 11:09:57 +020036 clk32: app_32_clk@32k {
37 #clock-cells = <0>;
38 compatible = "fixed-clock";
39 clock-frequency = <32768>;
40 };
41 pll13: pll13@13M {
42 #clock-cells = <0>;
43 compatible = "fixed-clock";
44 clock-frequency = <13000000>;
45 };
Linus Walleijbba5f2c2013-05-23 15:42:33 +020046 /* Slow bridge clocks under PLL13 */
47 slow_clk: slow_clk@13M {
48 #clock-cells = <0>;
49 compatible = "stericsson,u300-syscon-clk";
50 clock-type = <0>; /* Slow */
51 clock-id = <0>;
52 clocks = <&pll13>;
53 };
54 uart0_clk: uart0_clk@13M {
55 #clock-cells = <0>;
56 compatible = "stericsson,u300-syscon-clk";
57 clock-type = <0>; /* Slow */
58 clock-id = <1>;
59 clocks = <&slow_clk>;
60 };
61 gpio_clk: gpio_clk@13M {
62 #clock-cells = <0>;
63 compatible = "stericsson,u300-syscon-clk";
64 clock-type = <0>; /* Slow */
65 clock-id = <4>;
66 clocks = <&slow_clk>;
67 };
68 rtc_clk: rtc_clk@13M {
69 #clock-cells = <0>;
70 compatible = "stericsson,u300-syscon-clk";
71 clock-type = <0>; /* Slow */
72 clock-id = <6>;
73 clocks = <&slow_clk>;
74 };
75 apptimer_clk: app_tmr_clk@13M {
76 #clock-cells = <0>;
77 compatible = "stericsson,u300-syscon-clk";
78 clock-type = <0>; /* Slow */
79 clock-id = <7>;
80 clocks = <&slow_clk>;
81 };
82 acc_tmr_clk@13M {
83 #clock-cells = <0>;
84 compatible = "stericsson,u300-syscon-clk";
85 clock-type = <0>; /* Slow */
86 clock-id = <8>;
87 clocks = <&slow_clk>;
88 };
Linus Walleij14c26072013-05-23 11:09:57 +020089 pll208: pll208@208M {
90 #clock-cells = <0>;
91 compatible = "fixed-clock";
92 clock-frequency = <208000000>;
93 };
94 app208: app_208_clk@208M {
95 #clock-cells = <0>;
96 compatible = "fixed-factor-clock";
97 clock-div = <1>;
98 clock-mult = <1>;
99 clocks = <&pll208>;
100 };
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200101 cpu_clk@208M {
102 #clock-cells = <0>;
103 compatible = "stericsson,u300-syscon-clk";
104 clock-type = <2>; /* Rest */
105 clock-id = <3>;
106 clocks = <&app208>;
107 };
Linus Walleij14c26072013-05-23 11:09:57 +0200108 app104: app_104_clk@104M {
109 #clock-cells = <0>;
110 compatible = "fixed-factor-clock";
111 clock-div = <2>;
112 clock-mult = <1>;
113 clocks = <&pll208>;
114 };
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200115 semi_clk@104M {
116 #clock-cells = <0>;
117 compatible = "stericsson,u300-syscon-clk";
118 clock-type = <2>; /* Rest */
119 clock-id = <9>;
120 clocks = <&app104>;
121 };
Linus Walleij14c26072013-05-23 11:09:57 +0200122 app52: app_52_clk@52M {
123 #clock-cells = <0>;
124 compatible = "fixed-factor-clock";
125 clock-div = <4>;
126 clock-mult = <1>;
127 clocks = <&pll208>;
128 };
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200129 /* AHB subsystem clocks */
130 ahb_clk: ahb_subsys_clk@52M {
131 #clock-cells = <0>;
132 compatible = "stericsson,u300-syscon-clk";
133 clock-type = <2>; /* Rest */
134 clock-id = <10>;
135 clocks = <&app52>;
136 };
137 intcon_clk@52M {
138 #clock-cells = <0>;
139 compatible = "stericsson,u300-syscon-clk";
140 clock-type = <2>; /* Rest */
141 clock-id = <12>;
142 clocks = <&ahb_clk>;
143 };
144 emif_clk@52M {
145 #clock-cells = <0>;
146 compatible = "stericsson,u300-syscon-clk";
147 clock-type = <2>; /* Rest */
148 clock-id = <5>;
149 clocks = <&ahb_clk>;
150 };
151 dmac_clk: dmac_clk@52M {
152 #clock-cells = <0>;
153 compatible = "stericsson,u300-syscon-clk";
154 clock-type = <2>; /* Rest */
155 clock-id = <4>;
156 clocks = <&app52>;
157 };
158 fsmc_clk: fsmc_clk@52M {
159 #clock-cells = <0>;
160 compatible = "stericsson,u300-syscon-clk";
161 clock-type = <2>; /* Rest */
162 clock-id = <6>;
163 clocks = <&app52>;
164 };
165 xgam_clk: xgam_clk@52M {
166 #clock-cells = <0>;
167 compatible = "stericsson,u300-syscon-clk";
168 clock-type = <2>; /* Rest */
169 clock-id = <8>;
170 clocks = <&app52>;
171 };
Linus Walleij14c26072013-05-23 11:09:57 +0200172 app26: app_26_clk@26M {
173 #clock-cells = <0>;
174 compatible = "fixed-factor-clock";
175 clock-div = <2>;
176 clock-mult = <1>;
177 clocks = <&app52>;
178 };
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200179 /* Fast bridge clocks */
180 fast_clk: fast_clk@26M {
181 #clock-cells = <0>;
182 compatible = "stericsson,u300-syscon-clk";
183 clock-type = <1>; /* Fast */
184 clock-id = <0>;
185 clocks = <&app26>;
186 };
187 i2c0_clk: i2c0_clk@26M {
188 #clock-cells = <0>;
189 compatible = "stericsson,u300-syscon-clk";
190 clock-type = <1>; /* Fast */
191 clock-id = <1>;
192 clocks = <&fast_clk>;
193 };
194 i2c1_clk: i2c1_clk@26M {
195 #clock-cells = <0>;
196 compatible = "stericsson,u300-syscon-clk";
197 clock-type = <1>; /* Fast */
198 clock-id = <2>;
199 clocks = <&fast_clk>;
200 };
201 mmc_pclk: mmc_p_clk@26M {
202 #clock-cells = <0>;
203 compatible = "stericsson,u300-syscon-clk";
204 clock-type = <1>; /* Fast */
205 clock-id = <5>;
206 clocks = <&fast_clk>;
207 };
Linus Walleij85fb28b2013-05-23 19:18:28 +0200208 mmc_mclk: mmc_mclk {
209 #clock-cells = <0>;
210 compatible = "stericsson,u300-syscon-mclk";
211 clocks = <&mmc_pclk>;
212 };
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200213 spi_clk: spi_p_clk@26M {
214 #clock-cells = <0>;
215 compatible = "stericsson,u300-syscon-clk";
216 clock-type = <1>; /* Fast */
217 clock-id = <6>;
218 clocks = <&fast_clk>;
219 };
Linus Walleijecf5b392013-04-19 10:51:59 +0200220 };
221
Linus Walleij978577e2013-04-08 11:38:50 +0200222 timer: timer@c0014000 {
223 compatible = "stericsson,u300-apptimer";
224 reg = <0xc0014000 0x1000>;
225 interrupt-parent = <&vica>;
226 interrupts = <24 25 26 27>;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200227 clocks = <&apptimer_clk>;
Linus Walleij978577e2013-04-08 11:38:50 +0200228 };
229
230 gpio: gpio@c0016000 {
231 compatible = "stericsson,gpio-coh901";
232 reg = <0xc0016000 0x1000>;
233 interrupt-parent = <&vicb>;
234 interrupts = <0 1 2 18 21 22 23>;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200235 clocks = <&gpio_clk>;
Linus Walleij978577e2013-04-08 11:38:50 +0200236 interrupt-names = "gpio0", "gpio1", "gpio2", "gpio3",
237 "gpio4", "gpio5", "gpio6";
238 interrupt-controller;
239 #interrupt-cells = <2>;
240 gpio-controller;
241 #gpio-cells = <2>;
242 };
243
244 pinctrl: pinctrl@c0011000 {
245 compatible = "stericsson,pinctrl-u300";
246 reg = <0xc0011000 0x1000>;
247 };
248
Linus Walleij63a62ec2013-04-19 12:59:59 +0200249 watchdog: watchdog@c0012000 {
250 compatible = "stericsson,coh901327";
251 reg = <0xc0012000 0x1000>;
252 interrupt-parent = <&vicb>;
253 interrupts = <3>;
Linus Walleij14c26072013-05-23 11:09:57 +0200254 clocks = <&clk32>;
Linus Walleij63a62ec2013-04-19 12:59:59 +0200255 };
256
Linus Walleijae87bb82013-04-19 13:22:57 +0200257 rtc: rtc@c0017000 {
258 compatible = "stericsson,coh901331";
259 reg = <0xc0017000 0x1000>;
260 interrupt-parent = <&vicb>;
261 interrupts = <10>;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200262 clocks = <&rtc_clk>;
Linus Walleijae87bb82013-04-19 13:22:57 +0200263 };
264
Linus Walleij39738cc2013-04-19 13:44:25 +0200265 dmac: dma-controller@c00020000 {
266 compatible = "stericsson,coh901318";
267 reg = <0xc0020000 0x1000>;
268 interrupt-parent = <&vica>;
269 interrupts = <2>;
270 #dma-cells = <1>;
271 dma-channels = <40>;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200272 clocks = <&dmac_clk>;
Linus Walleij39738cc2013-04-19 13:44:25 +0200273 };
274
Linus Walleijd1346362013-04-22 11:00:02 +0200275 /* A NAND flash of 128 MiB */
276 fsmc: flash@40000000 {
277 compatible = "stericsson,fsmc-nand";
278 #address-cells = <1>;
279 #size-cells = <1>;
280 reg = <0x9f800000 0x1000>, /* FSMC Register*/
281 <0x80000000 0x4000>, /* NAND Base DATA */
282 <0x80020000 0x4000>, /* NAND Base ADDR */
283 <0x80010000 0x4000>; /* NAND Base CMD */
284 reg-names = "fsmc_regs", "nand_data", "nand_addr", "nand_cmd";
285 nand-skip-bbtscan;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200286 clocks = <&fsmc_clk>;
Linus Walleijd1346362013-04-22 11:00:02 +0200287
288 partition@0 {
289 label = "boot records";
290 reg = <0x0 0x20000>;
291 };
292 partition@20000 {
293 label = "free";
294 reg = <0x20000 0x7e0000>;
295 };
296 partition@800000 {
297 label = "platform";
298 reg = <0x800000 0xf800000>;
299 };
300 };
301
Linus Walleijc023b8b2013-04-11 15:13:39 +0200302 i2c0: i2c@c0004000 {
303 compatible = "st,ddci2c";
304 reg = <0xc0004000 0x1000>;
305 interrupt-parent = <&vicb>;
306 interrupts = <8>;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200307 clocks = <&i2c0_clk>;
Linus Walleijc023b8b2013-04-11 15:13:39 +0200308 #address-cells = <1>;
309 #size-cells = <0>;
Lee Jones8ddd0f62013-07-22 11:52:22 +0100310 ab3100: ab3100@48 {
Linus Walleijecf5b392013-04-19 10:51:59 +0200311 compatible = "stericsson,ab3100";
312 reg = <0x48>;
313 interrupt-parent = <&vica>;
314 interrupts = <0>; /* EXT0 IRQ */
315 ab3100-regulators {
316 compatible = "stericsson,ab3100-regulators";
317 ab3100_ldo_a_reg: ab3100_ldo_a {
Linus Walleijecf5b392013-04-19 10:51:59 +0200318 startup-delay-us = <200>;
319 regulator-always-on;
320 regulator-boot-on;
321 };
322 ab3100_ldo_c_reg: ab3100_ldo_c {
Linus Walleijecf5b392013-04-19 10:51:59 +0200323 startup-delay-us = <200>;
324 };
325 ab3100_ldo_d_reg: ab3100_ldo_d {
Linus Walleijecf5b392013-04-19 10:51:59 +0200326 startup-delay-us = <200>;
327 };
328 ab3100_ldo_e_reg: ab3100_ldo_e {
Linus Walleijecf5b392013-04-19 10:51:59 +0200329 regulator-min-microvolt = <1800000>;
330 regulator-max-microvolt = <1800000>;
331 startup-delay-us = <200>;
332 regulator-always-on;
333 regulator-boot-on;
334 };
335 ab3100_ldo_f_reg: ab3100_ldo_f {
Linus Walleijecf5b392013-04-19 10:51:59 +0200336 regulator-min-microvolt = <2500000>;
337 regulator-max-microvolt = <2500000>;
338 startup-delay-us = <600>;
339 regulator-always-on;
340 regulator-boot-on;
341 };
342 ab3100_ldo_g_reg: ab3100_ldo_g {
Linus Walleijecf5b392013-04-19 10:51:59 +0200343 regulator-min-microvolt = <1500000>;
344 regulator-max-microvolt = <2850000>;
345 startup-delay-us = <400>;
346 };
347 ab3100_ldo_h_reg: ab3100_ldo_h {
Linus Walleijecf5b392013-04-19 10:51:59 +0200348 regulator-min-microvolt = <1200000>;
349 regulator-max-microvolt = <2750000>;
350 startup-delay-us = <200>;
351 };
352 ab3100_ldo_k_reg: ab3100_ldo_k {
Linus Walleijecf5b392013-04-19 10:51:59 +0200353 regulator-min-microvolt = <1800000>;
354 regulator-max-microvolt = <2750000>;
355 startup-delay-us = <200>;
356 };
357 ab3100_ext_reg: ab3100_ext {
Linus Walleijecf5b392013-04-19 10:51:59 +0200358 };
359 ab3100_buck_reg: ab3100_buck {
Linus Walleijecf5b392013-04-19 10:51:59 +0200360 regulator-min-microvolt = <1200000>;
361 regulator-max-microvolt = <1800000>;
362 startup-delay-us = <1000>;
363 regulator-always-on;
364 regulator-boot-on;
365 };
366 };
367 };
Linus Walleijc023b8b2013-04-11 15:13:39 +0200368 };
369
370 i2c1: i2c@c0005000 {
371 compatible = "st,ddci2c";
372 reg = <0xc0005000 0x1000>;
373 interrupt-parent = <&vicb>;
374 interrupts = <9>;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200375 clocks = <&i2c1_clk>;
Linus Walleijc023b8b2013-04-11 15:13:39 +0200376 #address-cells = <1>;
377 #size-cells = <0>;
Lee Jones8ddd0f62013-07-22 11:52:22 +0100378 fwcam0: fwcam@10 {
Linus Walleijecf5b392013-04-19 10:51:59 +0200379 reg = <0x10>;
380 };
Lee Jones8ddd0f62013-07-22 11:52:22 +0100381 fwcam1: fwcam@5d {
Linus Walleijecf5b392013-04-19 10:51:59 +0200382 reg = <0x5d>;
383 };
Linus Walleijc023b8b2013-04-11 15:13:39 +0200384 };
385
Linus Walleij978577e2013-04-08 11:38:50 +0200386 amba {
Masahiro Yamada2ef7d5f2016-03-09 13:26:45 +0900387 compatible = "simple-bus";
Linus Walleij978577e2013-04-08 11:38:50 +0200388 #address-cells = <1>;
389 #size-cells = <1>;
390 ranges;
391
392 vica: interrupt-controller@a0001000 {
393 compatible = "arm,versatile-vic";
394 interrupt-controller;
395 #interrupt-cells = <1>;
396 reg = <0xa0001000 0x20>;
397 };
398
399 vicb: interrupt-controller@a0002000 {
400 compatible = "arm,versatile-vic";
401 interrupt-controller;
402 #interrupt-cells = <1>;
403 reg = <0xa0002000 0x20>;
404 };
405
406 uart0: serial@c0013000 {
407 compatible = "arm,pl011", "arm,primecell";
408 reg = <0xc0013000 0x1000>;
409 interrupt-parent = <&vica>;
410 interrupts = <22>;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200411 clocks = <&uart0_clk>, <&uart0_clk>;
412 clock-names = "apb_pclk", "uart0_clk";
Linus Walleijefb9bc22013-05-02 10:38:52 +0200413 dmas = <&dmac 17 &dmac 18>;
414 dma-names = "tx", "rx";
Linus Walleij978577e2013-04-08 11:38:50 +0200415 };
416
417 uart1: serial@c0007000 {
418 compatible = "arm,pl011", "arm,primecell";
419 reg = <0xc0007000 0x1000>;
420 interrupt-parent = <&vicb>;
421 interrupts = <20>;
Linus Walleijefb9bc22013-05-02 10:38:52 +0200422 dmas = <&dmac 38 &dmac 39>;
423 dma-names = "tx", "rx";
Linus Walleij978577e2013-04-08 11:38:50 +0200424 };
Linus Walleijba078d12013-04-10 14:34:00 +0200425
426 mmcsd: mmcsd@c0001000 {
427 compatible = "arm,pl18x", "arm,primecell";
428 reg = <0xc0001000 0x1000>;
429 interrupt-parent = <&vicb>;
430 interrupts = <6 7>;
Linus Walleij85fb28b2013-05-23 19:18:28 +0200431 clocks = <&mmc_pclk>, <&mmc_mclk>;
432 clock-names = "apb_pclk", "mclk";
Linus Walleijba078d12013-04-10 14:34:00 +0200433 max-frequency = <24000000>;
434 bus-width = <4>; // SD-card slot
Ulf Hansson2071f852014-03-18 20:37:26 +0100435 cap-mmc-highspeed;
436 cap-sd-highspeed;
Linus Walleijba078d12013-04-10 14:34:00 +0200437 cd-gpios = <&gpio 12 0x4>;
438 cd-inverted;
439 vmmc-supply = <&ab3100_ldo_g_reg>;
Linus Walleijefb9bc22013-05-02 10:38:52 +0200440 dmas = <&dmac 14>;
441 dma-names = "rx";
Linus Walleijba078d12013-04-10 14:34:00 +0200442 };
Linus Walleijcf4af862013-04-19 14:56:46 +0200443
444 spi: ssp@c0006000 {
445 compatible = "arm,pl022", "arm,primecell";
446 reg = <0xc0006000 0x1000>;
447 interrupt-parent = <&vica>;
448 interrupts = <23>;
Linus Walleijbba5f2c2013-05-23 15:42:33 +0200449 clocks = <&spi_clk>, <&spi_clk>;
Linus Walleijdfc98322014-02-24 13:34:59 +0100450 clock-names = "SSPCLK", "apb_pclk";
Linus Walleijcf4af862013-04-19 14:56:46 +0200451 dmas = <&dmac 27 &dmac 28>;
452 dma-names = "tx", "rx";
453 num-cs = <3>;
454 #address-cells = <1>;
455 #size-cells = <0>;
Linus Walleij20d4af62013-04-21 21:39:46 +0200456 spi-dummy@1 {
457 compatible = "arm,pl022-dummy";
458 reg = <1>;
459 spi-max-frequency = <20000000>;
460 };
Linus Walleijcf4af862013-04-19 14:56:46 +0200461 };
Linus Walleij978577e2013-04-08 11:38:50 +0200462 };
463};