blob: 8ccf2647e962a9a8e70e877b59715a7e1a154d42 [file] [log] [blame]
Peng Fan6301e652016-11-28 17:49:47 +08001/*
2 * Copyright 2014 Freescale Semiconductor, Inc.
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation.
7 */
8
9#include <dt-bindings/clock/imx6sx-clock.h>
10#include <dt-bindings/gpio/gpio.h>
11#include <dt-bindings/input/input.h>
12#include <dt-bindings/interrupt-controller/arm-gic.h>
13#include "imx6sx-pinfunc.h"
14#include "skeleton.dtsi"
15
16/ {
17 aliases {
18 can0 = &flexcan1;
19 can1 = &flexcan2;
20 ethernet0 = &fec1;
21 ethernet1 = &fec2;
22 gpio0 = &gpio1;
23 gpio1 = &gpio2;
24 gpio2 = &gpio3;
25 gpio3 = &gpio4;
26 gpio4 = &gpio5;
27 gpio5 = &gpio6;
28 gpio6 = &gpio7;
29 i2c0 = &i2c1;
30 i2c1 = &i2c2;
31 i2c2 = &i2c3;
32 i2c3 = &i2c4;
33 mmc0 = &usdhc1;
34 mmc1 = &usdhc2;
35 mmc2 = &usdhc3;
36 mmc3 = &usdhc4;
37 serial0 = &uart1;
38 serial1 = &uart2;
39 serial2 = &uart3;
40 serial3 = &uart4;
41 serial4 = &uart5;
42 serial5 = &uart6;
Ye Li536c5c72018-06-27 19:26:59 -070043 spi0 = &qspi1;
44 spi1 = &qspi2;
45 spi2 = &ecspi1;
46 spi3 = &ecspi2;
47 spi4 = &ecspi3;
48 spi5 = &ecspi4;
49 spi6 = &ecspi5;
Peng Fan6301e652016-11-28 17:49:47 +080050 usbphy0 = &usbphy1;
51 usbphy1 = &usbphy2;
52 };
53
54 cpus {
55 #address-cells = <1>;
56 #size-cells = <0>;
57
58 cpu0: cpu@0 {
59 compatible = "arm,cortex-a9";
60 device_type = "cpu";
61 reg = <0>;
62 next-level-cache = <&L2>;
63 operating-points = <
64 /* kHz uV */
65 996000 1250000
66 792000 1175000
67 396000 1075000
68 198000 975000
69 >;
70 fsl,soc-operating-points = <
71 /* ARM kHz SOC uV */
72 996000 1175000
73 792000 1175000
74 396000 1175000
75 198000 1175000
76 >;
77 clock-latency = <61036>; /* two CLK32 periods */
78 clocks = <&clks IMX6SX_CLK_ARM>,
79 <&clks IMX6SX_CLK_PLL2_PFD2>,
80 <&clks IMX6SX_CLK_STEP>,
81 <&clks IMX6SX_CLK_PLL1_SW>,
82 <&clks IMX6SX_CLK_PLL1_SYS>;
83 clock-names = "arm", "pll2_pfd2_396m", "step",
84 "pll1_sw", "pll1_sys";
85 arm-supply = <&reg_arm>;
86 soc-supply = <&reg_soc>;
87 };
88 };
89
90 intc: interrupt-controller@00a01000 {
91 compatible = "arm,cortex-a9-gic";
92 #interrupt-cells = <3>;
93 interrupt-controller;
94 reg = <0x00a01000 0x1000>,
95 <0x00a00100 0x100>;
96 interrupt-parent = <&intc>;
97 };
98
99 clocks {
100 #address-cells = <1>;
101 #size-cells = <0>;
102
103 ckil: clock@0 {
104 compatible = "fixed-clock";
105 reg = <0>;
106 #clock-cells = <0>;
107 clock-frequency = <32768>;
108 clock-output-names = "ckil";
109 };
110
111 osc: clock@1 {
112 compatible = "fixed-clock";
113 reg = <1>;
114 #clock-cells = <0>;
115 clock-frequency = <24000000>;
116 clock-output-names = "osc";
117 };
118
119 ipp_di0: clock@2 {
120 compatible = "fixed-clock";
121 reg = <2>;
122 #clock-cells = <0>;
123 clock-frequency = <0>;
124 clock-output-names = "ipp_di0";
125 };
126
127 ipp_di1: clock@3 {
128 compatible = "fixed-clock";
129 reg = <3>;
130 #clock-cells = <0>;
131 clock-frequency = <0>;
132 clock-output-names = "ipp_di1";
133 };
134 };
135
136 soc {
137 #address-cells = <1>;
138 #size-cells = <1>;
139 compatible = "simple-bus";
140 interrupt-parent = <&gpc>;
141 ranges;
142
143 pmu {
144 compatible = "arm,cortex-a9-pmu";
145 interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
146 };
147
148 ocram: sram@00900000 {
149 compatible = "mmio-sram";
150 reg = <0x00900000 0x20000>;
151 clocks = <&clks IMX6SX_CLK_OCRAM>;
152 };
153
154 L2: l2-cache@00a02000 {
155 compatible = "arm,pl310-cache";
156 reg = <0x00a02000 0x1000>;
157 interrupts = <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>;
158 cache-unified;
159 cache-level = <2>;
160 arm,tag-latency = <4 2 3>;
161 arm,data-latency = <4 2 3>;
162 };
163
164 gpu: gpu@01800000 {
165 compatible = "vivante,gc";
166 reg = <0x01800000 0x4000>;
167 interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
168 clocks = <&clks IMX6SX_CLK_GPU>,
169 <&clks IMX6SX_CLK_GPU>,
170 <&clks IMX6SX_CLK_GPU>;
171 clock-names = "bus", "core", "shader";
172 };
173
174 dma_apbh: dma-apbh@01804000 {
175 compatible = "fsl,imx6sx-dma-apbh", "fsl,imx28-dma-apbh";
176 reg = <0x01804000 0x2000>;
177 interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>,
178 <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>,
179 <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>,
180 <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
181 interrupt-names = "gpmi0", "gpmi1", "gpmi2", "gpmi3";
182 #dma-cells = <1>;
183 dma-channels = <4>;
184 clocks = <&clks IMX6SX_CLK_APBH_DMA>;
185 };
186
187 gpmi: gpmi-nand@01806000{
188 compatible = "fsl,imx6sx-gpmi-nand";
189 #address-cells = <1>;
190 #size-cells = <1>;
191 reg = <0x01806000 0x2000>, <0x01808000 0x4000>;
192 reg-names = "gpmi-nand", "bch";
193 interrupts = <GIC_SPI 15 IRQ_TYPE_LEVEL_HIGH>;
194 interrupt-names = "bch";
195 clocks = <&clks IMX6SX_CLK_GPMI_IO>,
196 <&clks IMX6SX_CLK_GPMI_APB>,
197 <&clks IMX6SX_CLK_GPMI_BCH>,
198 <&clks IMX6SX_CLK_GPMI_BCH_APB>,
199 <&clks IMX6SX_CLK_PER1_BCH>;
200 clock-names = "gpmi_io", "gpmi_apb", "gpmi_bch",
201 "gpmi_bch_apb", "per1_bch";
202 dmas = <&dma_apbh 0>;
203 dma-names = "rx-tx";
204 status = "disabled";
205 };
206
207 aips1: aips-bus@02000000 {
208 compatible = "fsl,aips-bus", "simple-bus";
209 #address-cells = <1>;
210 #size-cells = <1>;
211 reg = <0x02000000 0x100000>;
212 ranges;
213
214 spba-bus@02000000 {
215 compatible = "fsl,spba-bus", "simple-bus";
216 #address-cells = <1>;
217 #size-cells = <1>;
218 reg = <0x02000000 0x40000>;
219 ranges;
220
221 spdif: spdif@02004000 {
222 compatible = "fsl,imx6sx-spdif", "fsl,imx35-spdif";
223 reg = <0x02004000 0x4000>;
224 interrupts = <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>;
225 dmas = <&sdma 14 18 0>,
226 <&sdma 15 18 0>;
227 dma-names = "rx", "tx";
228 clocks = <&clks IMX6SX_CLK_SPDIF_GCLK>,
229 <&clks IMX6SX_CLK_OSC>,
230 <&clks IMX6SX_CLK_SPDIF>,
231 <&clks 0>, <&clks 0>, <&clks 0>,
232 <&clks IMX6SX_CLK_IPG>,
233 <&clks 0>, <&clks 0>,
234 <&clks IMX6SX_CLK_SPBA>;
235 clock-names = "core", "rxtx0",
236 "rxtx1", "rxtx2",
237 "rxtx3", "rxtx4",
238 "rxtx5", "rxtx6",
239 "rxtx7", "spba";
240 status = "disabled";
241 };
242
243 ecspi1: ecspi@02008000 {
244 #address-cells = <1>;
245 #size-cells = <0>;
246 compatible = "fsl,imx6sx-ecspi", "fsl,imx51-ecspi";
247 reg = <0x02008000 0x4000>;
248 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
249 clocks = <&clks IMX6SX_CLK_ECSPI1>,
250 <&clks IMX6SX_CLK_ECSPI1>;
251 clock-names = "ipg", "per";
252 status = "disabled";
253 };
254
255 ecspi2: ecspi@0200c000 {
256 #address-cells = <1>;
257 #size-cells = <0>;
258 compatible = "fsl,imx6sx-ecspi", "fsl,imx51-ecspi";
259 reg = <0x0200c000 0x4000>;
260 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
261 clocks = <&clks IMX6SX_CLK_ECSPI2>,
262 <&clks IMX6SX_CLK_ECSPI2>;
263 clock-names = "ipg", "per";
264 status = "disabled";
265 };
266
267 ecspi3: ecspi@02010000 {
268 #address-cells = <1>;
269 #size-cells = <0>;
270 compatible = "fsl,imx6sx-ecspi", "fsl,imx51-ecspi";
271 reg = <0x02010000 0x4000>;
272 interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
273 clocks = <&clks IMX6SX_CLK_ECSPI3>,
274 <&clks IMX6SX_CLK_ECSPI3>;
275 clock-names = "ipg", "per";
276 status = "disabled";
277 };
278
279 ecspi4: ecspi@02014000 {
280 #address-cells = <1>;
281 #size-cells = <0>;
282 compatible = "fsl,imx6sx-ecspi", "fsl,imx51-ecspi";
283 reg = <0x02014000 0x4000>;
284 interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
285 clocks = <&clks IMX6SX_CLK_ECSPI4>,
286 <&clks IMX6SX_CLK_ECSPI4>;
287 clock-names = "ipg", "per";
288 status = "disabled";
289 };
290
291 uart1: serial@02020000 {
292 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
293 reg = <0x02020000 0x4000>;
294 interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
295 clocks = <&clks IMX6SX_CLK_UART_IPG>,
296 <&clks IMX6SX_CLK_UART_SERIAL>;
297 clock-names = "ipg", "per";
298 dmas = <&sdma 25 4 0>, <&sdma 26 4 0>;
299 dma-names = "rx", "tx";
300 status = "disabled";
301 };
302
303 esai: esai@02024000 {
304 reg = <0x02024000 0x4000>;
305 interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>;
306 clocks = <&clks IMX6SX_CLK_ESAI_IPG>,
307 <&clks IMX6SX_CLK_ESAI_MEM>,
308 <&clks IMX6SX_CLK_ESAI_EXTAL>,
309 <&clks IMX6SX_CLK_ESAI_IPG>,
310 <&clks IMX6SX_CLK_SPBA>;
311 clock-names = "core", "mem", "extal",
312 "fsys", "spba";
313 status = "disabled";
314 };
315
316 ssi1: ssi@02028000 {
317 #sound-dai-cells = <0>;
318 compatible = "fsl,imx6sx-ssi", "fsl,imx51-ssi";
319 reg = <0x02028000 0x4000>;
320 interrupts = <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>;
321 clocks = <&clks IMX6SX_CLK_SSI1_IPG>,
322 <&clks IMX6SX_CLK_SSI1>;
323 clock-names = "ipg", "baud";
324 dmas = <&sdma 37 1 0>, <&sdma 38 1 0>;
325 dma-names = "rx", "tx";
326 fsl,fifo-depth = <15>;
327 status = "disabled";
328 };
329
330 ssi2: ssi@0202c000 {
331 #sound-dai-cells = <0>;
332 compatible = "fsl,imx6sx-ssi", "fsl,imx51-ssi";
333 reg = <0x0202c000 0x4000>;
334 interrupts = <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>;
335 clocks = <&clks IMX6SX_CLK_SSI2_IPG>,
336 <&clks IMX6SX_CLK_SSI2>;
337 clock-names = "ipg", "baud";
338 dmas = <&sdma 41 1 0>, <&sdma 42 1 0>;
339 dma-names = "rx", "tx";
340 fsl,fifo-depth = <15>;
341 status = "disabled";
342 };
343
344 ssi3: ssi@02030000 {
345 #sound-dai-cells = <0>;
346 compatible = "fsl,imx6sx-ssi", "fsl,imx51-ssi";
347 reg = <0x02030000 0x4000>;
348 interrupts = <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>;
349 clocks = <&clks IMX6SX_CLK_SSI3_IPG>,
350 <&clks IMX6SX_CLK_SSI3>;
351 clock-names = "ipg", "baud";
352 dmas = <&sdma 45 1 0>, <&sdma 46 1 0>;
353 dma-names = "rx", "tx";
354 fsl,fifo-depth = <15>;
355 status = "disabled";
356 };
357
358 asrc: asrc@02034000 {
359 reg = <0x02034000 0x4000>;
360 interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
361 clocks = <&clks IMX6SX_CLK_ASRC_MEM>,
362 <&clks IMX6SX_CLK_ASRC_IPG>,
363 <&clks IMX6SX_CLK_SPDIF>,
364 <&clks IMX6SX_CLK_SPBA>;
365 clock-names = "mem", "ipg", "asrck", "spba";
366 dmas = <&sdma 17 20 1>, <&sdma 18 20 1>,
367 <&sdma 19 20 1>, <&sdma 20 20 1>,
368 <&sdma 21 20 1>, <&sdma 22 20 1>;
369 dma-names = "rxa", "rxb", "rxc",
370 "txa", "txb", "txc";
371 status = "okay";
372 };
373 };
374
375 pwm1: pwm@02080000 {
376 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
377 reg = <0x02080000 0x4000>;
378 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
379 clocks = <&clks IMX6SX_CLK_PWM1>,
380 <&clks IMX6SX_CLK_PWM1>;
381 clock-names = "ipg", "per";
382 #pwm-cells = <2>;
383 };
384
385 pwm2: pwm@02084000 {
386 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
387 reg = <0x02084000 0x4000>;
388 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
389 clocks = <&clks IMX6SX_CLK_PWM2>,
390 <&clks IMX6SX_CLK_PWM2>;
391 clock-names = "ipg", "per";
392 #pwm-cells = <2>;
393 };
394
395 pwm3: pwm@02088000 {
396 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
397 reg = <0x02088000 0x4000>;
398 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
399 clocks = <&clks IMX6SX_CLK_PWM3>,
400 <&clks IMX6SX_CLK_PWM3>;
401 clock-names = "ipg", "per";
402 #pwm-cells = <2>;
403 };
404
405 pwm4: pwm@0208c000 {
406 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
407 reg = <0x0208c000 0x4000>;
408 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
409 clocks = <&clks IMX6SX_CLK_PWM4>,
410 <&clks IMX6SX_CLK_PWM4>;
411 clock-names = "ipg", "per";
412 #pwm-cells = <2>;
413 };
414
415 flexcan1: can@02090000 {
416 compatible = "fsl,imx6sx-flexcan", "fsl,imx6q-flexcan";
417 reg = <0x02090000 0x4000>;
418 interrupts = <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>;
419 clocks = <&clks IMX6SX_CLK_CAN1_IPG>,
420 <&clks IMX6SX_CLK_CAN1_SERIAL>;
421 clock-names = "ipg", "per";
422 status = "disabled";
423 };
424
425 flexcan2: can@02094000 {
426 compatible = "fsl,imx6sx-flexcan", "fsl,imx6q-flexcan";
427 reg = <0x02094000 0x4000>;
428 interrupts = <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>;
429 clocks = <&clks IMX6SX_CLK_CAN2_IPG>,
430 <&clks IMX6SX_CLK_CAN2_SERIAL>;
431 clock-names = "ipg", "per";
432 status = "disabled";
433 };
434
435 gpt: gpt@02098000 {
436 compatible = "fsl,imx6sx-gpt", "fsl,imx31-gpt";
437 reg = <0x02098000 0x4000>;
438 interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
439 clocks = <&clks IMX6SX_CLK_GPT_BUS>,
440 <&clks IMX6SX_CLK_GPT_3M>;
441 clock-names = "ipg", "per";
442 };
443
444 gpio1: gpio@0209c000 {
445 compatible = "fsl,imx6sx-gpio", "fsl,imx35-gpio";
446 reg = <0x0209c000 0x4000>;
447 interrupts = <GIC_SPI 66 IRQ_TYPE_LEVEL_HIGH>,
448 <GIC_SPI 67 IRQ_TYPE_LEVEL_HIGH>;
449 gpio-controller;
450 #gpio-cells = <2>;
451 interrupt-controller;
452 #interrupt-cells = <2>;
453 gpio-ranges = <&iomuxc 0 5 26>;
454 };
455
456 gpio2: gpio@020a0000 {
457 compatible = "fsl,imx6sx-gpio", "fsl,imx35-gpio";
458 reg = <0x020a0000 0x4000>;
459 interrupts = <GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>,
460 <GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>;
461 gpio-controller;
462 #gpio-cells = <2>;
463 interrupt-controller;
464 #interrupt-cells = <2>;
465 gpio-ranges = <&iomuxc 0 31 20>;
466 };
467
468 gpio3: gpio@020a4000 {
469 compatible = "fsl,imx6sx-gpio", "fsl,imx35-gpio";
470 reg = <0x020a4000 0x4000>;
471 interrupts = <GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>,
472 <GIC_SPI 71 IRQ_TYPE_LEVEL_HIGH>;
473 gpio-controller;
474 #gpio-cells = <2>;
475 interrupt-controller;
476 #interrupt-cells = <2>;
477 gpio-ranges = <&iomuxc 0 51 29>;
478 };
479
480 gpio4: gpio@020a8000 {
481 compatible = "fsl,imx6sx-gpio", "fsl,imx35-gpio";
482 reg = <0x020a8000 0x4000>;
483 interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>,
484 <GIC_SPI 73 IRQ_TYPE_LEVEL_HIGH>;
485 gpio-controller;
486 #gpio-cells = <2>;
487 interrupt-controller;
488 #interrupt-cells = <2>;
489 gpio-ranges = <&iomuxc 0 80 32>;
490 };
491
492 gpio5: gpio@020ac000 {
493 compatible = "fsl,imx6sx-gpio", "fsl,imx35-gpio";
494 reg = <0x020ac000 0x4000>;
495 interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>,
496 <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
497 gpio-controller;
498 #gpio-cells = <2>;
499 interrupt-controller;
500 #interrupt-cells = <2>;
501 gpio-ranges = <&iomuxc 0 112 24>;
502 };
503
504 gpio6: gpio@020b0000 {
505 compatible = "fsl,imx6sx-gpio", "fsl,imx35-gpio";
506 reg = <0x020b0000 0x4000>;
507 interrupts = <GIC_SPI 76 IRQ_TYPE_LEVEL_HIGH>,
508 <GIC_SPI 77 IRQ_TYPE_LEVEL_HIGH>;
509 gpio-controller;
510 #gpio-cells = <2>;
511 interrupt-controller;
512 #interrupt-cells = <2>;
513 gpio-ranges = <&iomuxc 0 136 12>, <&iomuxc 12 158 11>;
514 };
515
516 gpio7: gpio@020b4000 {
517 compatible = "fsl,imx6sx-gpio", "fsl,imx35-gpio";
518 reg = <0x020b4000 0x4000>;
519 interrupts = <GIC_SPI 78 IRQ_TYPE_LEVEL_HIGH>,
520 <GIC_SPI 79 IRQ_TYPE_LEVEL_HIGH>;
521 gpio-controller;
522 #gpio-cells = <2>;
523 interrupt-controller;
524 #interrupt-cells = <2>;
525 gpio-ranges = <&iomuxc 0 148 10>, <&iomuxc 10 169 2>;
526 };
527
528 kpp: kpp@020b8000 {
529 compatible = "fsl,imx6sx-kpp", "fsl,imx21-kpp";
530 reg = <0x020b8000 0x4000>;
531 interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
532 clocks = <&clks IMX6SX_CLK_DUMMY>;
533 status = "disabled";
534 };
535
536 wdog1: wdog@020bc000 {
537 compatible = "fsl,imx6sx-wdt", "fsl,imx21-wdt";
538 reg = <0x020bc000 0x4000>;
539 interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
540 clocks = <&clks IMX6SX_CLK_DUMMY>;
541 };
542
543 wdog2: wdog@020c0000 {
544 compatible = "fsl,imx6sx-wdt", "fsl,imx21-wdt";
545 reg = <0x020c0000 0x4000>;
546 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
547 clocks = <&clks IMX6SX_CLK_DUMMY>;
548 status = "disabled";
549 };
550
551 clks: ccm@020c4000 {
552 compatible = "fsl,imx6sx-ccm";
553 reg = <0x020c4000 0x4000>;
554 interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>,
555 <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
556 #clock-cells = <1>;
557 clocks = <&ckil>, <&osc>, <&ipp_di0>, <&ipp_di1>;
558 clock-names = "ckil", "osc", "ipp_di0", "ipp_di1";
559 };
560
561 anatop: anatop@020c8000 {
562 compatible = "fsl,imx6sx-anatop", "fsl,imx6q-anatop",
563 "syscon", "simple-bus";
564 reg = <0x020c8000 0x1000>;
565 interrupts = <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>,
566 <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
567 <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>;
568
569 regulator-1p1 {
570 compatible = "fsl,anatop-regulator";
571 regulator-name = "vdd1p1";
572 regulator-min-microvolt = <800000>;
573 regulator-max-microvolt = <1375000>;
574 regulator-always-on;
575 anatop-reg-offset = <0x110>;
576 anatop-vol-bit-shift = <8>;
577 anatop-vol-bit-width = <5>;
578 anatop-min-bit-val = <4>;
579 anatop-min-voltage = <800000>;
580 anatop-max-voltage = <1375000>;
581 };
582
583 regulator-3p0 {
584 compatible = "fsl,anatop-regulator";
585 regulator-name = "vdd3p0";
586 regulator-min-microvolt = <2800000>;
587 regulator-max-microvolt = <3150000>;
588 regulator-always-on;
589 anatop-reg-offset = <0x120>;
590 anatop-vol-bit-shift = <8>;
591 anatop-vol-bit-width = <5>;
592 anatop-min-bit-val = <0>;
593 anatop-min-voltage = <2625000>;
594 anatop-max-voltage = <3400000>;
595 };
596
597 regulator-2p5 {
598 compatible = "fsl,anatop-regulator";
599 regulator-name = "vdd2p5";
600 regulator-min-microvolt = <2100000>;
601 regulator-max-microvolt = <2875000>;
602 regulator-always-on;
603 anatop-reg-offset = <0x130>;
604 anatop-vol-bit-shift = <8>;
605 anatop-vol-bit-width = <5>;
606 anatop-min-bit-val = <0>;
607 anatop-min-voltage = <2100000>;
608 anatop-max-voltage = <2875000>;
609 };
610
611 reg_arm: regulator-vddcore {
612 compatible = "fsl,anatop-regulator";
613 regulator-name = "vddarm";
614 regulator-min-microvolt = <725000>;
615 regulator-max-microvolt = <1450000>;
616 regulator-always-on;
617 anatop-reg-offset = <0x140>;
618 anatop-vol-bit-shift = <0>;
619 anatop-vol-bit-width = <5>;
620 anatop-delay-reg-offset = <0x170>;
621 anatop-delay-bit-shift = <24>;
622 anatop-delay-bit-width = <2>;
623 anatop-min-bit-val = <1>;
624 anatop-min-voltage = <725000>;
625 anatop-max-voltage = <1450000>;
626 };
627
628 reg_pcie: regulator-vddpcie {
629 compatible = "fsl,anatop-regulator";
630 regulator-name = "vddpcie";
631 regulator-min-microvolt = <725000>;
632 regulator-max-microvolt = <1450000>;
633 anatop-reg-offset = <0x140>;
634 anatop-vol-bit-shift = <9>;
635 anatop-vol-bit-width = <5>;
636 anatop-delay-reg-offset = <0x170>;
637 anatop-delay-bit-shift = <26>;
638 anatop-delay-bit-width = <2>;
639 anatop-min-bit-val = <1>;
640 anatop-min-voltage = <725000>;
641 anatop-max-voltage = <1450000>;
642 };
643
644 reg_soc: regulator-vddsoc {
645 compatible = "fsl,anatop-regulator";
646 regulator-name = "vddsoc";
647 regulator-min-microvolt = <725000>;
648 regulator-max-microvolt = <1450000>;
649 regulator-always-on;
650 anatop-reg-offset = <0x140>;
651 anatop-vol-bit-shift = <18>;
652 anatop-vol-bit-width = <5>;
653 anatop-delay-reg-offset = <0x170>;
654 anatop-delay-bit-shift = <28>;
655 anatop-delay-bit-width = <2>;
656 anatop-min-bit-val = <1>;
657 anatop-min-voltage = <725000>;
658 anatop-max-voltage = <1450000>;
659 };
660 };
661
662 tempmon: tempmon {
663 compatible = "fsl,imx6sx-tempmon", "fsl,imx6q-tempmon";
664 interrupts = <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>;
665 fsl,tempmon = <&anatop>;
666 fsl,tempmon-data = <&ocotp>;
667 clocks = <&clks IMX6SX_CLK_PLL3_USB_OTG>;
668 };
669
670 usbphy1: usbphy@020c9000 {
671 compatible = "fsl,imx6sx-usbphy", "fsl,imx23-usbphy";
672 reg = <0x020c9000 0x1000>;
673 interrupts = <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>;
674 clocks = <&clks IMX6SX_CLK_USBPHY1>;
675 fsl,anatop = <&anatop>;
676 };
677
678 usbphy2: usbphy@020ca000 {
679 compatible = "fsl,imx6sx-usbphy", "fsl,imx23-usbphy";
680 reg = <0x020ca000 0x1000>;
681 interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
682 clocks = <&clks IMX6SX_CLK_USBPHY2>;
683 fsl,anatop = <&anatop>;
684 };
685
686 snvs: snvs@020cc000 {
687 compatible = "fsl,sec-v4.0-mon", "syscon", "simple-mfd";
688 reg = <0x020cc000 0x4000>;
689
690 snvs_rtc: snvs-rtc-lp {
691 compatible = "fsl,sec-v4.0-mon-rtc-lp";
692 regmap = <&snvs>;
693 offset = <0x34>;
694 interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>, <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
695 };
696
697 snvs_poweroff: snvs-poweroff {
698 compatible = "syscon-poweroff";
699 regmap = <&snvs>;
700 offset = <0x38>;
701 mask = <0x60>;
702 status = "disabled";
703 };
704
705 snvs_pwrkey: snvs-powerkey {
706 compatible = "fsl,sec-v4.0-pwrkey";
707 regmap = <&snvs>;
708 interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
709 linux,keycode = <KEY_POWER>;
710 wakeup-source;
711 };
712 };
713
714 epit1: epit@020d0000 {
715 reg = <0x020d0000 0x4000>;
716 interrupts = <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>;
717 };
718
719 epit2: epit@020d4000 {
720 reg = <0x020d4000 0x4000>;
721 interrupts = <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
722 };
723
724 src: src@020d8000 {
725 compatible = "fsl,imx6sx-src", "fsl,imx51-src";
726 reg = <0x020d8000 0x4000>;
727 interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>,
728 <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
729 #reset-cells = <1>;
730 };
731
732 gpc: gpc@020dc000 {
733 compatible = "fsl,imx6sx-gpc", "fsl,imx6q-gpc";
734 reg = <0x020dc000 0x4000>;
735 interrupt-controller;
736 #interrupt-cells = <3>;
737 interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
738 interrupt-parent = <&intc>;
739 };
740
741 iomuxc: iomuxc@020e0000 {
742 compatible = "fsl,imx6sx-iomuxc";
743 reg = <0x020e0000 0x4000>;
744 };
745
746 gpr: iomuxc-gpr@020e4000 {
747 compatible = "fsl,imx6sx-iomuxc-gpr",
748 "fsl,imx6q-iomuxc-gpr", "syscon";
749 reg = <0x020e4000 0x4000>;
750 };
751
752 sdma: sdma@020ec000 {
753 compatible = "fsl,imx6sx-sdma", "fsl,imx6q-sdma";
754 reg = <0x020ec000 0x4000>;
755 interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
756 clocks = <&clks IMX6SX_CLK_SDMA>,
757 <&clks IMX6SX_CLK_SDMA>;
758 clock-names = "ipg", "ahb";
759 #dma-cells = <3>;
760 /* imx6sx reuses imx6q sdma firmware */
761 fsl,sdma-ram-script-name = "imx/sdma/sdma-imx6q.bin";
762 };
763 };
764
765 aips2: aips-bus@02100000 {
766 compatible = "fsl,aips-bus", "simple-bus";
767 #address-cells = <1>;
768 #size-cells = <1>;
769 reg = <0x02100000 0x100000>;
770 ranges;
771
772 crypto: caam@2100000 {
773 compatible = "fsl,sec-v4.0";
774 fsl,sec-era = <4>;
775 #address-cells = <1>;
776 #size-cells = <1>;
777 reg = <0x2100000 0x10000>;
778 ranges = <0 0x2100000 0x10000>;
779 interrupt-parent = <&intc>;
780 clocks = <&clks IMX6SX_CLK_CAAM_MEM>,
781 <&clks IMX6SX_CLK_CAAM_ACLK>,
782 <&clks IMX6SX_CLK_CAAM_IPG>,
783 <&clks IMX6SX_CLK_EIM_SLOW>;
784 clock-names = "mem", "aclk", "ipg", "emi_slow";
785
786 sec_jr0: jr0@1000 {
787 compatible = "fsl,sec-v4.0-job-ring";
788 reg = <0x1000 0x1000>;
789 interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
790 };
791
792 sec_jr1: jr1@2000 {
793 compatible = "fsl,sec-v4.0-job-ring";
794 reg = <0x2000 0x1000>;
795 interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
796 };
797 };
798
799 usbotg1: usb@02184000 {
800 compatible = "fsl,imx6sx-usb", "fsl,imx27-usb";
801 reg = <0x02184000 0x200>;
802 interrupts = <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>;
803 clocks = <&clks IMX6SX_CLK_USBOH3>;
804 fsl,usbphy = <&usbphy1>;
805 fsl,usbmisc = <&usbmisc 0>;
806 fsl,anatop = <&anatop>;
807 ahb-burst-config = <0x0>;
808 tx-burst-size-dword = <0x10>;
809 rx-burst-size-dword = <0x10>;
810 status = "disabled";
811 };
812
813 usbotg2: usb@02184200 {
814 compatible = "fsl,imx6sx-usb", "fsl,imx27-usb";
815 reg = <0x02184200 0x200>;
816 interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
817 clocks = <&clks IMX6SX_CLK_USBOH3>;
818 fsl,usbphy = <&usbphy2>;
819 fsl,usbmisc = <&usbmisc 1>;
820 ahb-burst-config = <0x0>;
821 tx-burst-size-dword = <0x10>;
822 rx-burst-size-dword = <0x10>;
823 status = "disabled";
824 };
825
826 usbh: usb@02184400 {
827 compatible = "fsl,imx6sx-usb", "fsl,imx27-usb";
828 reg = <0x02184400 0x200>;
829 interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>;
830 clocks = <&clks IMX6SX_CLK_USBOH3>;
831 fsl,usbmisc = <&usbmisc 2>;
832 phy_type = "hsic";
833 fsl,anatop = <&anatop>;
834 dr_mode = "host";
835 ahb-burst-config = <0x0>;
836 tx-burst-size-dword = <0x10>;
837 rx-burst-size-dword = <0x10>;
838 status = "disabled";
839 };
840
841 usbmisc: usbmisc@02184800 {
842 #index-cells = <1>;
843 compatible = "fsl,imx6sx-usbmisc", "fsl,imx6q-usbmisc";
844 reg = <0x02184800 0x200>;
845 clocks = <&clks IMX6SX_CLK_USBOH3>;
846 };
847
848 fec1: ethernet@02188000 {
849 compatible = "fsl,imx6sx-fec", "fsl,imx6q-fec";
850 reg = <0x02188000 0x4000>;
851 interrupts = <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
852 <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>;
853 clocks = <&clks IMX6SX_CLK_ENET>,
854 <&clks IMX6SX_CLK_ENET_AHB>,
855 <&clks IMX6SX_CLK_ENET_PTP>,
856 <&clks IMX6SX_CLK_ENET_REF>,
857 <&clks IMX6SX_CLK_ENET_PTP>;
858 clock-names = "ipg", "ahb", "ptp",
859 "enet_clk_ref", "enet_out";
860 fsl,num-tx-queues=<3>;
861 fsl,num-rx-queues=<3>;
862 status = "disabled";
863 };
864
865 mlb: mlb@0218c000 {
866 reg = <0x0218c000 0x4000>;
867 interrupts = <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
868 <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
869 <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>;
870 clocks = <&clks IMX6SX_CLK_MLB>;
871 status = "disabled";
872 };
873
874 usdhc1: usdhc@02190000 {
875 compatible = "fsl,imx6sx-usdhc", "fsl,imx6sl-usdhc";
876 reg = <0x02190000 0x4000>;
877 interrupts = <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>;
878 clocks = <&clks IMX6SX_CLK_USDHC1>,
879 <&clks IMX6SX_CLK_USDHC1>,
880 <&clks IMX6SX_CLK_USDHC1>;
881 clock-names = "ipg", "ahb", "per";
882 bus-width = <4>;
883 status = "disabled";
884 };
885
886 usdhc2: usdhc@02194000 {
887 compatible = "fsl,imx6sx-usdhc", "fsl,imx6sl-usdhc";
888 reg = <0x02194000 0x4000>;
889 interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
890 clocks = <&clks IMX6SX_CLK_USDHC2>,
891 <&clks IMX6SX_CLK_USDHC2>,
892 <&clks IMX6SX_CLK_USDHC2>;
893 clock-names = "ipg", "ahb", "per";
894 bus-width = <4>;
895 status = "disabled";
896 };
897
898 usdhc3: usdhc@02198000 {
899 compatible = "fsl,imx6sx-usdhc", "fsl,imx6sl-usdhc";
900 reg = <0x02198000 0x4000>;
901 interrupts = <GIC_SPI 24 IRQ_TYPE_LEVEL_HIGH>;
902 clocks = <&clks IMX6SX_CLK_USDHC3>,
903 <&clks IMX6SX_CLK_USDHC3>,
904 <&clks IMX6SX_CLK_USDHC3>;
905 clock-names = "ipg", "ahb", "per";
906 bus-width = <4>;
907 status = "disabled";
908 };
909
910 usdhc4: usdhc@0219c000 {
911 compatible = "fsl,imx6sx-usdhc", "fsl,imx6sl-usdhc";
912 reg = <0x0219c000 0x4000>;
913 interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
914 clocks = <&clks IMX6SX_CLK_USDHC4>,
915 <&clks IMX6SX_CLK_USDHC4>,
916 <&clks IMX6SX_CLK_USDHC4>;
917 clock-names = "ipg", "ahb", "per";
918 bus-width = <4>;
919 status = "disabled";
920 };
921
922 i2c1: i2c@021a0000 {
923 #address-cells = <1>;
924 #size-cells = <0>;
925 compatible = "fsl,imx6sx-i2c", "fsl,imx21-i2c";
926 reg = <0x021a0000 0x4000>;
927 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
928 clocks = <&clks IMX6SX_CLK_I2C1>;
929 status = "disabled";
930 };
931
932 i2c2: i2c@021a4000 {
933 #address-cells = <1>;
934 #size-cells = <0>;
935 compatible = "fsl,imx6sx-i2c", "fsl,imx21-i2c";
936 reg = <0x021a4000 0x4000>;
937 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
938 clocks = <&clks IMX6SX_CLK_I2C2>;
939 status = "disabled";
940 };
941
942 i2c3: i2c@021a8000 {
943 #address-cells = <1>;
944 #size-cells = <0>;
945 compatible = "fsl,imx6sx-i2c", "fsl,imx21-i2c";
946 reg = <0x021a8000 0x4000>;
947 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
948 clocks = <&clks IMX6SX_CLK_I2C3>;
949 status = "disabled";
950 };
951
952 mmdc: mmdc@021b0000 {
953 compatible = "fsl,imx6sx-mmdc", "fsl,imx6q-mmdc";
954 reg = <0x021b0000 0x4000>;
955 };
956
957 fec2: ethernet@021b4000 {
958 compatible = "fsl,imx6sx-fec", "fsl,imx6q-fec";
959 reg = <0x021b4000 0x4000>;
960 interrupts = <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>,
961 <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
962 clocks = <&clks IMX6SX_CLK_ENET>,
963 <&clks IMX6SX_CLK_ENET_AHB>,
964 <&clks IMX6SX_CLK_ENET_PTP>,
965 <&clks IMX6SX_CLK_ENET2_REF_125M>,
966 <&clks IMX6SX_CLK_ENET_PTP>;
967 clock-names = "ipg", "ahb", "ptp",
968 "enet_clk_ref", "enet_out";
969 status = "disabled";
970 };
971
972 weim: weim@021b8000 {
973 compatible = "fsl,imx6sx-weim", "fsl,imx6q-weim";
974 reg = <0x021b8000 0x4000>;
975 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
976 clocks = <&clks IMX6SX_CLK_EIM_SLOW>;
977 };
978
979 ocotp: ocotp@021bc000 {
980 compatible = "fsl,imx6sx-ocotp", "syscon";
981 reg = <0x021bc000 0x4000>;
982 clocks = <&clks IMX6SX_CLK_OCOTP>;
983 };
984
985 sai1: sai@021d4000 {
986 compatible = "fsl,imx6sx-sai";
987 reg = <0x021d4000 0x4000>;
988 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
989 clocks = <&clks IMX6SX_CLK_SAI1_IPG>,
990 <&clks IMX6SX_CLK_SAI1>,
991 <&clks 0>, <&clks 0>;
992 clock-names = "bus", "mclk1", "mclk2", "mclk3";
993 dma-names = "rx", "tx";
994 dmas = <&sdma 31 24 0>, <&sdma 32 24 0>;
995 status = "disabled";
996 };
997
998 audmux: audmux@021d8000 {
999 compatible = "fsl,imx6sx-audmux", "fsl,imx31-audmux";
1000 reg = <0x021d8000 0x4000>;
1001 status = "disabled";
1002 };
1003
1004 sai2: sai@021dc000 {
1005 compatible = "fsl,imx6sx-sai";
1006 reg = <0x021dc000 0x4000>;
1007 interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
1008 clocks = <&clks IMX6SX_CLK_SAI2_IPG>,
1009 <&clks IMX6SX_CLK_SAI2>,
1010 <&clks 0>, <&clks 0>;
1011 clock-names = "bus", "mclk1", "mclk2", "mclk3";
1012 dma-names = "rx", "tx";
1013 dmas = <&sdma 33 24 0>, <&sdma 34 24 0>;
1014 status = "disabled";
1015 };
1016
1017 qspi1: qspi@021e0000 {
1018 #address-cells = <1>;
1019 #size-cells = <0>;
1020 compatible = "fsl,imx6sx-qspi";
1021 reg = <0x021e0000 0x4000>, <0x60000000 0x10000000>;
1022 reg-names = "QuadSPI", "QuadSPI-memory";
1023 interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
1024 clocks = <&clks IMX6SX_CLK_QSPI1>,
1025 <&clks IMX6SX_CLK_QSPI1>;
1026 clock-names = "qspi_en", "qspi";
1027 status = "disabled";
1028 };
1029
1030 qspi2: qspi@021e4000 {
1031 #address-cells = <1>;
1032 #size-cells = <0>;
1033 compatible = "fsl,imx6sx-qspi";
1034 reg = <0x021e4000 0x4000>, <0x70000000 0x10000000>;
1035 reg-names = "QuadSPI", "QuadSPI-memory";
1036 interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
1037 clocks = <&clks IMX6SX_CLK_QSPI2>,
1038 <&clks IMX6SX_CLK_QSPI2>;
1039 clock-names = "qspi_en", "qspi";
1040 status = "disabled";
1041 };
1042
1043 uart2: serial@021e8000 {
1044 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1045 reg = <0x021e8000 0x4000>;
1046 interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
1047 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1048 <&clks IMX6SX_CLK_UART_SERIAL>;
1049 clock-names = "ipg", "per";
1050 dmas = <&sdma 27 4 0>, <&sdma 28 4 0>;
1051 dma-names = "rx", "tx";
1052 status = "disabled";
1053 };
1054
1055 uart3: serial@021ec000 {
1056 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1057 reg = <0x021ec000 0x4000>;
1058 interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
1059 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1060 <&clks IMX6SX_CLK_UART_SERIAL>;
1061 clock-names = "ipg", "per";
1062 dmas = <&sdma 29 4 0>, <&sdma 30 4 0>;
1063 dma-names = "rx", "tx";
1064 status = "disabled";
1065 };
1066
1067 uart4: serial@021f0000 {
1068 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1069 reg = <0x021f0000 0x4000>;
1070 interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
1071 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1072 <&clks IMX6SX_CLK_UART_SERIAL>;
1073 clock-names = "ipg", "per";
1074 dmas = <&sdma 31 4 0>, <&sdma 32 4 0>;
1075 dma-names = "rx", "tx";
1076 status = "disabled";
1077 };
1078
1079 uart5: serial@021f4000 {
1080 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1081 reg = <0x021f4000 0x4000>;
1082 interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
1083 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1084 <&clks IMX6SX_CLK_UART_SERIAL>;
1085 clock-names = "ipg", "per";
1086 dmas = <&sdma 33 4 0>, <&sdma 34 4 0>;
1087 dma-names = "rx", "tx";
1088 status = "disabled";
1089 };
1090
1091 i2c4: i2c@021f8000 {
1092 #address-cells = <1>;
1093 #size-cells = <0>;
1094 compatible = "fsl,imx6sx-i2c", "fsl,imx21-i2c";
1095 reg = <0x021f8000 0x4000>;
1096 interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
1097 clocks = <&clks IMX6SX_CLK_I2C4>;
1098 status = "disabled";
1099 };
1100 };
1101
1102 aips3: aips-bus@02200000 {
1103 compatible = "fsl,aips-bus", "simple-bus";
1104 #address-cells = <1>;
1105 #size-cells = <1>;
1106 reg = <0x02200000 0x100000>;
1107 ranges;
1108
1109 spba-bus@02200000 {
1110 compatible = "fsl,spba-bus", "simple-bus";
1111 #address-cells = <1>;
1112 #size-cells = <1>;
1113 reg = <0x02240000 0x40000>;
1114 ranges;
1115
1116 csi1: csi@02214000 {
1117 reg = <0x02214000 0x4000>;
1118 interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
1119 clocks = <&clks IMX6SX_CLK_DISPLAY_AXI>,
1120 <&clks IMX6SX_CLK_CSI>,
1121 <&clks IMX6SX_CLK_DCIC1>;
1122 clock-names = "disp-axi", "csi_mclk", "dcic";
1123 status = "disabled";
1124 };
1125
1126 pxp: pxp@02218000 {
1127 reg = <0x02218000 0x4000>;
1128 interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
1129 clocks = <&clks IMX6SX_CLK_PXP_AXI>,
1130 <&clks IMX6SX_CLK_DISPLAY_AXI>;
1131 clock-names = "pxp-axi", "disp-axi";
1132 status = "disabled";
1133 };
1134
1135 csi2: csi@0221c000 {
1136 reg = <0x0221c000 0x4000>;
1137 interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
1138 clocks = <&clks IMX6SX_CLK_DISPLAY_AXI>,
1139 <&clks IMX6SX_CLK_CSI>,
1140 <&clks IMX6SX_CLK_DCIC2>;
1141 clock-names = "disp-axi", "csi_mclk", "dcic";
1142 status = "disabled";
1143 };
1144
1145 lcdif1: lcdif@02220000 {
1146 compatible = "fsl,imx6sx-lcdif", "fsl,imx28-lcdif";
1147 reg = <0x02220000 0x4000>;
1148 interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
1149 clocks = <&clks IMX6SX_CLK_LCDIF1_PIX>,
1150 <&clks IMX6SX_CLK_LCDIF_APB>,
1151 <&clks IMX6SX_CLK_DISPLAY_AXI>;
1152 clock-names = "pix", "axi", "disp_axi";
1153 status = "disabled";
1154 };
1155
1156 lcdif2: lcdif@02224000 {
1157 compatible = "fsl,imx6sx-lcdif", "fsl,imx28-lcdif";
1158 reg = <0x02224000 0x4000>;
1159 interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
1160 clocks = <&clks IMX6SX_CLK_LCDIF2_PIX>,
1161 <&clks IMX6SX_CLK_LCDIF_APB>,
1162 <&clks IMX6SX_CLK_DISPLAY_AXI>;
1163 clock-names = "pix", "axi", "disp_axi";
1164 status = "disabled";
1165 };
1166
1167 vadc: vadc@02228000 {
1168 reg = <0x02228000 0x4000>, <0x0222c000 0x4000>;
1169 reg-names = "vadc-vafe", "vadc-vdec";
1170 clocks = <&clks IMX6SX_CLK_VADC>,
1171 <&clks IMX6SX_CLK_CSI>;
1172 clock-names = "vadc", "csi";
1173 status = "disabled";
1174 };
1175 };
1176
1177 adc1: adc@02280000 {
1178 compatible = "fsl,imx6sx-adc", "fsl,vf610-adc";
1179 reg = <0x02280000 0x4000>;
1180 interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
1181 clocks = <&clks IMX6SX_CLK_IPG>;
1182 clock-names = "adc";
1183 fsl,adck-max-frequency = <30000000>, <40000000>,
1184 <20000000>;
1185 status = "disabled";
1186 };
1187
1188 adc2: adc@02284000 {
1189 compatible = "fsl,imx6sx-adc", "fsl,vf610-adc";
1190 reg = <0x02284000 0x4000>;
1191 interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
1192 clocks = <&clks IMX6SX_CLK_IPG>;
1193 clock-names = "adc";
1194 fsl,adck-max-frequency = <30000000>, <40000000>,
1195 <20000000>;
1196 status = "disabled";
1197 };
1198
1199 wdog3: wdog@02288000 {
1200 compatible = "fsl,imx6sx-wdt", "fsl,imx21-wdt";
1201 reg = <0x02288000 0x4000>;
1202 interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
1203 clocks = <&clks IMX6SX_CLK_DUMMY>;
1204 status = "disabled";
1205 };
1206
1207 ecspi5: ecspi@0228c000 {
1208 #address-cells = <1>;
1209 #size-cells = <0>;
1210 compatible = "fsl,imx6sx-ecspi", "fsl,imx51-ecspi";
1211 reg = <0x0228c000 0x4000>;
1212 interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
1213 clocks = <&clks IMX6SX_CLK_ECSPI5>,
1214 <&clks IMX6SX_CLK_ECSPI5>;
1215 clock-names = "ipg", "per";
1216 status = "disabled";
1217 };
1218
1219 uart6: serial@022a0000 {
1220 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1221 reg = <0x022a0000 0x4000>;
1222 interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
1223 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1224 <&clks IMX6SX_CLK_UART_SERIAL>;
1225 clock-names = "ipg", "per";
1226 dmas = <&sdma 0 4 0>, <&sdma 47 4 0>;
1227 dma-names = "rx", "tx";
1228 status = "disabled";
1229 };
1230
1231 pwm5: pwm@022a4000 {
1232 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
1233 reg = <0x022a4000 0x4000>;
1234 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
1235 clocks = <&clks IMX6SX_CLK_PWM5>,
1236 <&clks IMX6SX_CLK_PWM5>;
1237 clock-names = "ipg", "per";
1238 #pwm-cells = <2>;
1239 };
1240
1241 pwm6: pwm@022a8000 {
1242 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
1243 reg = <0x022a8000 0x4000>;
1244 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
1245 clocks = <&clks IMX6SX_CLK_PWM6>,
1246 <&clks IMX6SX_CLK_PWM6>;
1247 clock-names = "ipg", "per";
1248 #pwm-cells = <2>;
1249 };
1250
1251 pwm7: pwm@022ac000 {
1252 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
1253 reg = <0x022ac000 0x4000>;
1254 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
1255 clocks = <&clks IMX6SX_CLK_PWM7>,
1256 <&clks IMX6SX_CLK_PWM7>;
1257 clock-names = "ipg", "per";
1258 #pwm-cells = <2>;
1259 };
1260
1261 pwm8: pwm@0022b0000 {
1262 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
1263 reg = <0x0022b0000 0x4000>;
1264 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
1265 clocks = <&clks IMX6SX_CLK_PWM8>,
1266 <&clks IMX6SX_CLK_PWM8>;
1267 clock-names = "ipg", "per";
1268 #pwm-cells = <2>;
1269 };
1270 };
1271
1272 pcie: pcie@0x08000000 {
1273 compatible = "fsl,imx6sx-pcie", "snps,dw-pcie";
1274 reg = <0x08ffc000 0x4000>; /* DBI */
1275 #address-cells = <3>;
1276 #size-cells = <2>;
1277 device_type = "pci";
1278 /* configuration space */
1279 ranges = <0x00000800 0 0x08f00000 0x08f00000 0 0x00080000
1280 /* downstream I/O */
1281 0x81000000 0 0 0x08f80000 0 0x00010000
1282 /* non-prefetchable memory */
1283 0x82000000 0 0x08000000 0x08000000 0 0x00f00000>;
1284 num-lanes = <1>;
1285 interrupts = <GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>;
1286 clocks = <&clks IMX6SX_CLK_PCIE_REF_125M>,
1287 <&clks IMX6SX_CLK_PCIE_AXI>,
1288 <&clks IMX6SX_CLK_LVDS1_OUT>,
1289 <&clks IMX6SX_CLK_DISPLAY_AXI>;
1290 clock-names = "pcie_ref_125m", "pcie_axi",
1291 "lvds_gate", "display_axi";
1292 status = "disabled";
1293 };
1294 };
1295
1296 gpu-subsystem {
1297 compatible = "fsl,imx-gpu-subsystem";
1298 cores = <&gpu>;
1299 };
1300};