blob: c037c223619a7a9ced403c88f1146fb20c112378 [file] [log] [blame]
Sascha Hauer9f0749e2012-02-28 21:57:50 +01001/*
2 * Copyright 2012 Sascha Hauer, Pengutronix
3 *
4 * The code contained herein is licensed under the GNU General Public
5 * License. You may obtain a copy of the GNU General Public License
6 * Version 2 or later at the following locations:
7 *
8 * http://www.opensource.org/licenses/gpl-license.html
9 * http://www.gnu.org/copyleft/gpl.html
10 */
11
Shawn Guo36dffd82013-04-07 10:49:34 +080012#include "skeleton.dtsi"
Sascha Hauer9f0749e2012-02-28 21:57:50 +010013
14/ {
15 aliases {
Shawn Guo5230f8f2012-08-05 14:01:28 +080016 gpio0 = &gpio1;
17 gpio1 = &gpio2;
18 gpio2 = &gpio3;
19 gpio3 = &gpio4;
20 gpio4 = &gpio5;
21 gpio5 = &gpio6;
Sascha Hauer6a3c0b32013-06-25 15:51:54 +020022 i2c0 = &i2c1;
23 i2c1 = &i2c2;
24 serial0 = &uart1;
25 serial1 = &uart2;
26 serial2 = &uart3;
27 serial3 = &uart4;
28 serial4 = &uart5;
29 serial5 = &uart6;
Alexander Shiyana5a641a2013-05-01 14:46:57 +040030 spi0 = &cspi1;
31 spi1 = &cspi2;
32 spi2 = &cspi3;
Sascha Hauer9f0749e2012-02-28 21:57:50 +010033 };
34
Fabio Estevam6189bc32013-06-28 16:50:33 +020035 aitc: aitc-interrupt-controller@e0000000 {
36 compatible = "fsl,imx27-aitc", "fsl,avic";
Sascha Hauer9f0749e2012-02-28 21:57:50 +010037 interrupt-controller;
38 #interrupt-cells = <1>;
39 reg = <0x10040000 0x1000>;
40 };
41
42 clocks {
43 #address-cells = <1>;
44 #size-cells = <0>;
45
46 osc26m {
47 compatible = "fsl,imx-osc26m", "fixed-clock";
48 clock-frequency = <26000000>;
49 };
50 };
51
Markus Pargmanndc1d0f92013-06-28 16:50:36 +020052 cpus {
53 #size-cells = <0>;
54 #address-cells = <1>;
55
Alexander Shiyan48568be2013-07-20 11:17:56 +040056 cpu: cpu@0 {
Markus Pargmanndc1d0f92013-06-28 16:50:36 +020057 device_type = "cpu";
58 compatible = "arm,arm926ej-s";
59 operating-points = <
Alexander Shiyan98a3e802013-07-13 08:34:44 +040060 /* kHz uV */
61 266000 1300000
62 399000 1450000
Markus Pargmanndc1d0f92013-06-28 16:50:36 +020063 >;
Alexander Shiyan8defcb52013-07-20 11:17:57 +040064 clock-latency = <62500>;
Markus Pargmanndc1d0f92013-06-28 16:50:36 +020065 clocks = <&clks 18>;
Alexander Shiyan98a3e802013-07-13 08:34:44 +040066 voltage-tolerance = <5>;
Markus Pargmanndc1d0f92013-06-28 16:50:36 +020067 };
68 };
69
Sascha Hauer9f0749e2012-02-28 21:57:50 +010070 soc {
71 #address-cells = <1>;
72 #size-cells = <1>;
73 compatible = "simple-bus";
Fabio Estevam6189bc32013-06-28 16:50:33 +020074 interrupt-parent = <&aitc>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +010075 ranges;
76
77 aipi@10000000 { /* AIPI1 */
78 compatible = "fsl,aipi-bus", "simple-bus";
79 #address-cells = <1>;
80 #size-cells = <1>;
Fabio Estevam3e24b052012-11-21 17:19:38 -020081 reg = <0x10000000 0x20000>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +010082 ranges;
83
Alexander Shiyanb858c342013-06-08 18:39:36 +040084 dma: dma@10001000 {
85 compatible = "fsl,imx27-dma";
86 reg = <0x10001000 0x1000>;
87 interrupts = <32>;
88 clocks = <&clks 50>, <&clks 70>;
89 clock-names = "ipg", "ahb";
90 #dma-cells = <1>;
91 #dma-channels = <16>;
92 };
93
Sascha Hauer7b7d6722012-11-15 09:31:52 +010094 wdog: wdog@10002000 {
Sascha Hauer9f0749e2012-02-28 21:57:50 +010095 compatible = "fsl,imx27-wdt", "fsl,imx21-wdt";
Sascha Hauerca26d042013-03-14 13:08:57 +010096 reg = <0x10002000 0x1000>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +010097 interrupts = <27>;
Alexander Shiyan3c0e2a22013-07-20 11:17:54 +040098 clocks = <&clks 74>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +010099 };
100
Sascha Hauerca26d042013-03-14 13:08:57 +0100101 gpt1: timer@10003000 {
102 compatible = "fsl,imx27-gpt", "fsl,imx1-gpt";
103 reg = <0x10003000 0x1000>;
104 interrupts = <26>;
Sascha Hauerb700c112013-03-14 13:09:02 +0100105 clocks = <&clks 46>, <&clks 61>;
106 clock-names = "ipg", "per";
Sascha Hauerca26d042013-03-14 13:08:57 +0100107 };
108
109 gpt2: timer@10004000 {
110 compatible = "fsl,imx27-gpt", "fsl,imx1-gpt";
111 reg = <0x10004000 0x1000>;
112 interrupts = <25>;
Sascha Hauerb700c112013-03-14 13:09:02 +0100113 clocks = <&clks 45>, <&clks 61>;
114 clock-names = "ipg", "per";
Sascha Hauerca26d042013-03-14 13:08:57 +0100115 };
116
117 gpt3: timer@10005000 {
118 compatible = "fsl,imx27-gpt", "fsl,imx1-gpt";
119 reg = <0x10005000 0x1000>;
120 interrupts = <24>;
Sascha Hauerb700c112013-03-14 13:09:02 +0100121 clocks = <&clks 44>, <&clks 61>;
122 clock-names = "ipg", "per";
Sascha Hauerca26d042013-03-14 13:08:57 +0100123 };
124
Alexander Shiyana392d042013-06-23 10:54:47 +0400125 pwm: pwm@10006000 {
Gwenhael Goavec-Merou08f4881a2013-04-14 09:44:25 +0200126 compatible = "fsl,imx27-pwm";
127 reg = <0x10006000 0x1000>;
128 interrupts = <23>;
129 clocks = <&clks 34>, <&clks 61>;
130 clock-names = "ipg", "per";
131 };
132
Alexander Shiyan6c04ad22013-06-23 10:54:50 +0400133 kpp: kpp@10008000 {
134 compatible = "fsl,imx27-kpp", "fsl,imx21-kpp";
135 reg = <0x10008000 0x1000>;
136 interrupts = <21>;
137 clocks = <&clks 37>;
138 status = "disabled";
139 };
140
Markus Pargmann6a486b72013-07-01 17:21:22 +0800141 owire: owire@10009000 {
142 compatible = "fsl,imx27-owire", "fsl,imx21-owire";
143 reg = <0x10009000 0x1000>;
144 clocks = <&clks 35>;
145 status = "disabled";
146 };
147
Shawn Guo0c456cf2012-04-02 14:39:26 +0800148 uart1: serial@1000a000 {
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100149 compatible = "fsl,imx27-uart", "fsl,imx21-uart";
150 reg = <0x1000a000 0x1000>;
151 interrupts = <20>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200152 clocks = <&clks 81>, <&clks 61>;
153 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100154 status = "disabled";
155 };
156
Shawn Guo0c456cf2012-04-02 14:39:26 +0800157 uart2: serial@1000b000 {
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100158 compatible = "fsl,imx27-uart", "fsl,imx21-uart";
159 reg = <0x1000b000 0x1000>;
160 interrupts = <19>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200161 clocks = <&clks 80>, <&clks 61>;
162 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100163 status = "disabled";
164 };
165
Shawn Guo0c456cf2012-04-02 14:39:26 +0800166 uart3: serial@1000c000 {
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100167 compatible = "fsl,imx27-uart", "fsl,imx21-uart";
168 reg = <0x1000c000 0x1000>;
169 interrupts = <18>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200170 clocks = <&clks 79>, <&clks 61>;
171 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100172 status = "disabled";
173 };
174
Shawn Guo0c456cf2012-04-02 14:39:26 +0800175 uart4: serial@1000d000 {
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100176 compatible = "fsl,imx27-uart", "fsl,imx21-uart";
177 reg = <0x1000d000 0x1000>;
178 interrupts = <17>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200179 clocks = <&clks 78>, <&clks 61>;
180 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100181 status = "disabled";
182 };
183
184 cspi1: cspi@1000e000 {
185 #address-cells = <1>;
186 #size-cells = <0>;
187 compatible = "fsl,imx27-cspi";
188 reg = <0x1000e000 0x1000>;
189 interrupts = <16>;
Jonas Andersson37523dc2013-05-23 13:38:05 +0200190 clocks = <&clks 53>, <&clks 53>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200191 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100192 status = "disabled";
193 };
194
195 cspi2: cspi@1000f000 {
196 #address-cells = <1>;
197 #size-cells = <0>;
198 compatible = "fsl,imx27-cspi";
199 reg = <0x1000f000 0x1000>;
200 interrupts = <15>;
Jonas Andersson37523dc2013-05-23 13:38:05 +0200201 clocks = <&clks 52>, <&clks 52>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200202 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100203 status = "disabled";
204 };
205
206 i2c1: i2c@10012000 {
207 #address-cells = <1>;
208 #size-cells = <0>;
Shawn Guo5bdfba22012-09-14 15:19:00 +0800209 compatible = "fsl,imx27-i2c", "fsl,imx21-i2c";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100210 reg = <0x10012000 0x1000>;
211 interrupts = <12>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200212 clocks = <&clks 40>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100213 status = "disabled";
214 };
215
Alexander Shiyan0e7b01a2013-06-08 18:39:37 +0400216 sdhci1: sdhci@10013000 {
217 compatible = "fsl,imx27-mmc", "fsl,imx21-mmc";
218 reg = <0x10013000 0x1000>;
219 interrupts = <11>;
220 clocks = <&clks 30>, <&clks 60>;
221 clock-names = "ipg", "per";
222 dmas = <&dma 7>;
223 dma-names = "rx-tx";
224 status = "disabled";
225 };
226
227 sdhci2: sdhci@10014000 {
228 compatible = "fsl,imx27-mmc", "fsl,imx21-mmc";
229 reg = <0x10014000 0x1000>;
230 interrupts = <10>;
231 clocks = <&clks 29>, <&clks 60>;
232 clock-names = "ipg", "per";
233 dmas = <&dma 6>;
234 dma-names = "rx-tx";
235 status = "disabled";
236 };
237
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100238 gpio1: gpio@10015000 {
239 compatible = "fsl,imx27-gpio", "fsl,imx21-gpio";
240 reg = <0x10015000 0x100>;
241 interrupts = <8>;
242 gpio-controller;
243 #gpio-cells = <2>;
244 interrupt-controller;
Shawn Guo88cde8b2012-07-06 20:03:37 +0800245 #interrupt-cells = <2>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100246 };
247
248 gpio2: gpio@10015100 {
249 compatible = "fsl,imx27-gpio", "fsl,imx21-gpio";
250 reg = <0x10015100 0x100>;
251 interrupts = <8>;
252 gpio-controller;
253 #gpio-cells = <2>;
254 interrupt-controller;
Shawn Guo88cde8b2012-07-06 20:03:37 +0800255 #interrupt-cells = <2>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100256 };
257
258 gpio3: gpio@10015200 {
259 compatible = "fsl,imx27-gpio", "fsl,imx21-gpio";
260 reg = <0x10015200 0x100>;
261 interrupts = <8>;
262 gpio-controller;
263 #gpio-cells = <2>;
264 interrupt-controller;
Shawn Guo88cde8b2012-07-06 20:03:37 +0800265 #interrupt-cells = <2>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100266 };
267
268 gpio4: gpio@10015300 {
269 compatible = "fsl,imx27-gpio", "fsl,imx21-gpio";
270 reg = <0x10015300 0x100>;
271 interrupts = <8>;
272 gpio-controller;
273 #gpio-cells = <2>;
274 interrupt-controller;
Shawn Guo88cde8b2012-07-06 20:03:37 +0800275 #interrupt-cells = <2>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100276 };
277
278 gpio5: gpio@10015400 {
279 compatible = "fsl,imx27-gpio", "fsl,imx21-gpio";
280 reg = <0x10015400 0x100>;
281 interrupts = <8>;
282 gpio-controller;
283 #gpio-cells = <2>;
284 interrupt-controller;
Shawn Guo88cde8b2012-07-06 20:03:37 +0800285 #interrupt-cells = <2>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100286 };
287
288 gpio6: gpio@10015500 {
289 compatible = "fsl,imx27-gpio", "fsl,imx21-gpio";
290 reg = <0x10015500 0x100>;
291 interrupts = <8>;
292 gpio-controller;
293 #gpio-cells = <2>;
294 interrupt-controller;
Shawn Guo88cde8b2012-07-06 20:03:37 +0800295 #interrupt-cells = <2>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100296 };
297
Alexander Shiyan6e228e82013-06-23 10:54:46 +0400298 audmux: audmux@10016000 {
299 compatible = "fsl,imx27-audmux", "fsl,imx21-audmux";
300 reg = <0x10016000 0x1000>;
301 clocks = <&clks 0>;
302 clock-names = "audmux";
Alexander Shiyan1c04ab02013-08-10 12:51:50 +0400303 status = "disabled";
Alexander Shiyan6e228e82013-06-23 10:54:46 +0400304 };
305
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100306 cspi3: cspi@10017000 {
307 #address-cells = <1>;
308 #size-cells = <0>;
309 compatible = "fsl,imx27-cspi";
310 reg = <0x10017000 0x1000>;
311 interrupts = <6>;
Jonas Andersson37523dc2013-05-23 13:38:05 +0200312 clocks = <&clks 51>, <&clks 51>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200313 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100314 status = "disabled";
315 };
316
Sascha Hauerca26d042013-03-14 13:08:57 +0100317 gpt4: timer@10019000 {
318 compatible = "fsl,imx27-gpt", "fsl,imx1-gpt";
319 reg = <0x10019000 0x1000>;
320 interrupts = <4>;
Sascha Hauerb700c112013-03-14 13:09:02 +0100321 clocks = <&clks 43>, <&clks 61>;
322 clock-names = "ipg", "per";
Sascha Hauerca26d042013-03-14 13:08:57 +0100323 };
324
325 gpt5: timer@1001a000 {
326 compatible = "fsl,imx27-gpt", "fsl,imx1-gpt";
327 reg = <0x1001a000 0x1000>;
328 interrupts = <3>;
Sascha Hauerb700c112013-03-14 13:09:02 +0100329 clocks = <&clks 42>, <&clks 61>;
330 clock-names = "ipg", "per";
Sascha Hauerca26d042013-03-14 13:08:57 +0100331 };
332
Shawn Guo0c456cf2012-04-02 14:39:26 +0800333 uart5: serial@1001b000 {
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100334 compatible = "fsl,imx27-uart", "fsl,imx21-uart";
335 reg = <0x1001b000 0x1000>;
336 interrupts = <49>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200337 clocks = <&clks 77>, <&clks 61>;
338 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100339 status = "disabled";
340 };
341
Shawn Guo0c456cf2012-04-02 14:39:26 +0800342 uart6: serial@1001c000 {
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100343 compatible = "fsl,imx27-uart", "fsl,imx21-uart";
344 reg = <0x1001c000 0x1000>;
345 interrupts = <48>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200346 clocks = <&clks 78>, <&clks 61>;
347 clock-names = "ipg", "per";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100348 status = "disabled";
349 };
350
351 i2c2: i2c@1001d000 {
352 #address-cells = <1>;
353 #size-cells = <0>;
Shawn Guo5bdfba22012-09-14 15:19:00 +0800354 compatible = "fsl,imx27-i2c", "fsl,imx21-i2c";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100355 reg = <0x1001d000 0x1000>;
356 interrupts = <1>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200357 clocks = <&clks 39>;
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100358 status = "disabled";
359 };
360
Alexander Shiyan0e7b01a2013-06-08 18:39:37 +0400361 sdhci3: sdhci@1001e000 {
362 compatible = "fsl,imx27-mmc", "fsl,imx21-mmc";
363 reg = <0x1001e000 0x1000>;
364 interrupts = <9>;
365 clocks = <&clks 28>, <&clks 60>;
366 clock-names = "ipg", "per";
367 dmas = <&dma 36>;
368 dma-names = "rx-tx";
369 status = "disabled";
370 };
371
Sascha Hauerca26d042013-03-14 13:08:57 +0100372 gpt6: timer@1001f000 {
373 compatible = "fsl,imx27-gpt", "fsl,imx1-gpt";
374 reg = <0x1001f000 0x1000>;
375 interrupts = <2>;
Sascha Hauerb700c112013-03-14 13:09:02 +0100376 clocks = <&clks 41>, <&clks 61>;
377 clock-names = "ipg", "per";
Sascha Hauerca26d042013-03-14 13:08:57 +0100378 };
Fabio Estevam3e24b052012-11-21 17:19:38 -0200379 };
380
381 aipi@10020000 { /* AIPI2 */
382 compatible = "fsl,aipi-bus", "simple-bus";
383 #address-cells = <1>;
384 #size-cells = <1>;
385 reg = <0x10020000 0x20000>;
386 ranges;
387
Markus Pargmann5e57b242013-06-28 16:50:34 +0200388 fb: fb@10021000 {
389 compatible = "fsl,imx27-fb", "fsl,imx21-fb";
390 interrupts = <61>;
391 reg = <0x10021000 0x1000>;
392 clocks = <&clks 36>, <&clks 65>, <&clks 59>;
393 clock-names = "ipg", "ahb", "per";
394 status = "disabled";
395 };
396
Alexander Shiyan93b331c2013-06-15 16:22:58 +0400397 coda: coda@10023000 {
398 compatible = "fsl,imx27-vpu";
399 reg = <0x10023000 0x0200>;
400 interrupts = <53>;
401 clocks = <&clks 57>, <&clks 66>;
402 clock-names = "per", "ahb";
403 iram = <&iram>;
404 };
405
Alexander Shiyane4b6a052013-06-23 10:54:45 +0400406 sahara2: sahara@10025000 {
407 compatible = "fsl,imx27-sahara";
408 reg = <0x10025000 0x1000>;
409 interrupts = <59>;
410 clocks = <&clks 32>, <&clks 64>;
411 clock-names = "ipg", "ahb";
412 };
413
Alexander Shiyan93b331c2013-06-15 16:22:58 +0400414 clks: ccm@10027000{
415 compatible = "fsl,imx27-ccm";
416 reg = <0x10027000 0x1000>;
417 #clock-cells = <1>;
418 };
419
Alexander Shiyand36afcd2013-07-02 20:02:24 +0400420 iim: iim@10028000 {
421 compatible = "fsl,imx27-iim";
422 reg = <0x10028000 0x1000>;
423 interrupts = <62>;
424 clocks = <&clks 38>;
425 };
426
Shawn Guo0c456cf2012-04-02 14:39:26 +0800427 fec: ethernet@1002b000 {
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100428 compatible = "fsl,imx27-fec";
429 reg = <0x1002b000 0x4000>;
430 interrupts = <50>;
Alexander Shiyanc0b357c2013-07-20 11:17:55 +0400431 clocks = <&clks 48>, <&clks 67>;
432 clock-names = "ipg", "ahb";
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100433 status = "disabled";
434 };
435 };
Sascha Hauer7b7d6722012-11-15 09:31:52 +0100436
437 nfc: nand@d8000000 {
Uwe Kleine-König37787362012-04-23 11:23:42 +0200438 #address-cells = <1>;
439 #size-cells = <1>;
Uwe Kleine-König37787362012-04-23 11:23:42 +0200440 compatible = "fsl,imx27-nand";
441 reg = <0xd8000000 0x1000>;
442 interrupts = <29>;
Fabio Estevamc20736f2012-11-28 15:55:30 -0200443 clocks = <&clks 54>;
Uwe Kleine-König37787362012-04-23 11:23:42 +0200444 status = "disabled";
445 };
Alexander Shiyanff1450f2013-06-23 10:54:48 +0400446
Alexander Shiyan0912f592013-07-02 20:02:25 +0400447 weim: weim@d8002000 {
448 #address-cells = <2>;
449 #size-cells = <1>;
450 compatible = "fsl,imx27-weim";
451 reg = <0xd8002000 0x1000>;
452 clocks = <&clks 0>;
453 ranges = <
454 0 0 0xc0000000 0x08000000
455 1 0 0xc8000000 0x08000000
456 2 0 0xd0000000 0x02000000
457 3 0 0xd2000000 0x02000000
458 4 0 0xd4000000 0x02000000
459 5 0 0xd6000000 0x02000000
460 >;
461 status = "disabled";
462 };
463
Alexander Shiyanff1450f2013-06-23 10:54:48 +0400464 iram: iram@ffff4c00 {
465 compatible = "mmio-sram";
466 reg = <0xffff4c00 0xb400>;
467 };
Sascha Hauer9f0749e2012-02-28 21:57:50 +0100468 };
469};