blob: 076a30f9bcae26d8e62b119ee92fd71d1944e922 [file] [log] [blame]
Shawn Guob1d17f62014-05-13 20:21:35 +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>
Frank Li93db0552015-05-27 00:26:02 +080011#include <dt-bindings/input/input.h>
Shawn Guob1d17f62014-05-13 20:21:35 +080012#include <dt-bindings/interrupt-controller/arm-gic.h>
13#include "imx6sx-pinfunc.h"
Shawn Guob1d17f62014-05-13 20:21:35 +080014
15/ {
Fabio Estevam7f107882016-11-12 13:30:35 -020016 #address-cells = <1>;
17 #size-cells = <1>;
18
Shawn Guob1d17f62014-05-13 20:21:35 +080019 aliases {
20 can0 = &flexcan1;
21 can1 = &flexcan2;
22 ethernet0 = &fec1;
23 ethernet1 = &fec2;
24 gpio0 = &gpio1;
25 gpio1 = &gpio2;
26 gpio2 = &gpio3;
27 gpio3 = &gpio4;
28 gpio4 = &gpio5;
29 gpio5 = &gpio6;
30 gpio6 = &gpio7;
31 i2c0 = &i2c1;
32 i2c1 = &i2c2;
33 i2c2 = &i2c3;
34 i2c3 = &i2c4;
35 mmc0 = &usdhc1;
36 mmc1 = &usdhc2;
37 mmc2 = &usdhc3;
38 mmc3 = &usdhc4;
39 serial0 = &uart1;
40 serial1 = &uart2;
41 serial2 = &uart3;
42 serial3 = &uart4;
43 serial4 = &uart5;
44 serial5 = &uart6;
45 spi0 = &ecspi1;
46 spi1 = &ecspi2;
47 spi2 = &ecspi3;
48 spi3 = &ecspi4;
49 spi4 = &ecspi5;
50 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
Fabio Estevamfe4266b2016-04-25 16:38:48 -030068 198000 975000
Shawn Guob1d17f62014-05-13 20:21:35 +080069 >;
70 fsl,soc-operating-points = <
71 /* ARM kHz SOC uV */
72 996000 1175000
73 792000 1175000
74 396000 1175000
Fabio Estevamfe4266b2016-04-25 16:38:48 -030075 198000 1175000
Shawn Guob1d17f62014-05-13 20:21:35 +080076 >;
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>;
Marc Zyngierb923ff62015-02-23 17:45:18 +000096 interrupt-parent = <&intc>;
Shawn Guob1d17f62014-05-13 20:21:35 +080097 };
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";
Marc Zyngierb923ff62015-02-23 17:45:18 +0000140 interrupt-parent = <&gpc>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800141 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
Marek Vasut51c578e2016-08-26 16:22:54 +0200164 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
Shawn Guob1d17f62014-05-13 20:21:35 +0800174 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";
Shengjiu Wang833f2cb2015-10-10 18:15:07 +0800228 clocks = <&clks IMX6SX_CLK_SPDIF_GCLK>,
Shawn Guob1d17f62014-05-13 20:21:35 +0800229 <&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",
Shengjiu Wang09d30592015-11-26 10:39:30 +0800239 "rxtx7", "spba";
Shawn Guob1d17f62014-05-13 20:21:35 +0800240 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",
Shengjiu Wang09d30592015-11-26 10:39:30 +0800312 "fsys", "spba";
Shawn Guob1d17f62014-05-13 20:21:35 +0800313 status = "disabled";
314 };
315
316 ssi1: ssi@02028000 {
Alexander Shiyan6ff7f512014-08-19 20:00:09 +0400317 #sound-dai-cells = <0>;
Fabio Estevam4c035272014-07-07 10:04:52 -0300318 compatible = "fsl,imx6sx-ssi", "fsl,imx51-ssi";
Shawn Guob1d17f62014-05-13 20:21:35 +0800319 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";
Fabio Estevam3a462a62014-07-02 11:58:50 -0300326 fsl,fifo-depth = <15>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800327 status = "disabled";
328 };
329
330 ssi2: ssi@0202c000 {
Alexander Shiyan6ff7f512014-08-19 20:00:09 +0400331 #sound-dai-cells = <0>;
Fabio Estevam4c035272014-07-07 10:04:52 -0300332 compatible = "fsl,imx6sx-ssi", "fsl,imx51-ssi";
Shawn Guob1d17f62014-05-13 20:21:35 +0800333 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";
Fabio Estevam3a462a62014-07-02 11:58:50 -0300340 fsl,fifo-depth = <15>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800341 status = "disabled";
342 };
343
344 ssi3: ssi@02030000 {
Alexander Shiyan6ff7f512014-08-19 20:00:09 +0400345 #sound-dai-cells = <0>;
Fabio Estevam4c035272014-07-07 10:04:52 -0300346 compatible = "fsl,imx6sx-ssi", "fsl,imx51-ssi";
Shawn Guob1d17f62014-05-13 20:21:35 +0800347 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";
Fabio Estevam3a462a62014-07-02 11:58:50 -0300354 fsl,fifo-depth = <15>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800355 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>;
Shengjiu Wang09d30592015-11-26 10:39:30 +0800365 clock-names = "mem", "ipg", "asrck", "spba";
Shawn Guob1d17f62014-05-13 20:21:35 +0800366 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>,
Anson Huang2b2244a2014-09-11 11:29:41 +0800440 <&clks IMX6SX_CLK_GPT_3M>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800441 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>;
Vladimir Zapolskiybb728d62016-09-09 05:02:36 +0300453 gpio-ranges = <&iomuxc 0 5 26>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800454 };
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>;
Vladimir Zapolskiybb728d62016-09-09 05:02:36 +0300465 gpio-ranges = <&iomuxc 0 31 20>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800466 };
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>;
Vladimir Zapolskiybb728d62016-09-09 05:02:36 +0300477 gpio-ranges = <&iomuxc 0 51 29>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800478 };
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>;
Vladimir Zapolskiybb728d62016-09-09 05:02:36 +0300489 gpio-ranges = <&iomuxc 0 80 32>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800490 };
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>;
Vladimir Zapolskiybb728d62016-09-09 05:02:36 +0300501 gpio-ranges = <&iomuxc 0 112 24>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800502 };
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>;
Vladimir Zapolskiybb728d62016-09-09 05:02:36 +0300513 gpio-ranges = <&iomuxc 0 136 12>, <&iomuxc 12 158 11>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800514 };
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>;
Vladimir Zapolskiybb728d62016-09-09 05:02:36 +0300525 gpio-ranges = <&iomuxc 0 148 10>, <&iomuxc 10 169 2>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800526 };
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
Fabio Estevam298701ec2016-05-03 10:57:31 -0300569 regulator-1p1 {
Shawn Guob1d17f62014-05-13 20:21:35 +0800570 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
Fabio Estevam298701ec2016-05-03 10:57:31 -0300583 regulator-3p0 {
Shawn Guob1d17f62014-05-13 20:21:35 +0800584 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
Fabio Estevam298701ec2016-05-03 10:57:31 -0300597 regulator-2p5 {
Shawn Guob1d17f62014-05-13 20:21:35 +0800598 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
Fabio Estevam298701ec2016-05-03 10:57:31 -0300611 reg_arm: regulator-vddcore {
Shawn Guob1d17f62014-05-13 20:21:35 +0800612 compatible = "fsl,anatop-regulator";
Fabio Estevamf78a5972014-06-17 01:07:35 -0300613 regulator-name = "vddarm";
Shawn Guob1d17f62014-05-13 20:21:35 +0800614 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
Fabio Estevam298701ec2016-05-03 10:57:31 -0300628 reg_pcie: regulator-vddpcie {
Shawn Guob1d17f62014-05-13 20:21:35 +0800629 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
Fabio Estevam298701ec2016-05-03 10:57:31 -0300644 reg_soc: regulator-vddsoc {
Shawn Guob1d17f62014-05-13 20:21:35 +0800645 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 {
Frank Li95d739b2015-05-27 00:25:59 +0800687 compatible = "fsl,sec-v4.0-mon", "syscon", "simple-mfd";
688 reg = <0x020cc000 0x4000>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800689
Frank Li95d739b2015-05-27 00:25:59 +0800690 snvs_rtc: snvs-rtc-lp {
Shawn Guob1d17f62014-05-13 20:21:35 +0800691 compatible = "fsl,sec-v4.0-mon-rtc-lp";
Frank Li95d739b2015-05-27 00:25:59 +0800692 regmap = <&snvs>;
693 offset = <0x34>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800694 interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>, <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
695 };
Robin Gong422b0672014-11-12 16:20:37 +0800696
Frank Li95d739b2015-05-27 00:25:59 +0800697 snvs_poweroff: snvs-poweroff {
698 compatible = "syscon-poweroff";
699 regmap = <&snvs>;
700 offset = <0x38>;
701 mask = <0x60>;
Robin Gong422b0672014-11-12 16:20:37 +0800702 status = "disabled";
703 };
Frank Li93db0552015-05-27 00:26:02 +0800704
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>;
Anson Huang461aa6d2015-08-05 21:57:55 +0800710 wakeup-source;
Frank Li93db0552015-05-27 00:26:02 +0800711 };
Shawn Guob1d17f62014-05-13 20:21:35 +0800712 };
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>;
Marc Zyngierb923ff62015-02-23 17:45:18 +0000735 interrupt-controller;
736 #interrupt-cells = <3>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800737 interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
Marc Zyngierb923ff62015-02-23 17:45:18 +0000738 interrupt-parent = <&intc>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800739 };
740
741 iomuxc: iomuxc@020e0000 {
742 compatible = "fsl,imx6sx-iomuxc";
743 reg = <0x020e0000 0x4000>;
744 };
745
746 gpr: iomuxc-gpr@020e4000 {
Anson Huang77e0d1c2014-06-23 14:04:01 +0800747 compatible = "fsl,imx6sx-iomuxc-gpr",
748 "fsl,imx6q-iomuxc-gpr", "syscon";
Shawn Guob1d17f62014-05-13 20:21:35 +0800749 reg = <0x020e4000 0x4000>;
750 };
751
752 sdma: sdma@020ec000 {
Shawn Guo811e76852014-07-04 14:30:27 +0800753 compatible = "fsl,imx6sx-sdma", "fsl,imx6q-sdma";
Shawn Guob1d17f62014-05-13 20:21:35 +0800754 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>;
Fabio Estevamaeb88532014-07-02 11:58:49 -0300760 /* imx6sx reuses imx6q sdma firmware */
761 fsl,sdma-ram-script-name = "imx/sdma/sdma-imx6q.bin";
Shawn Guob1d17f62014-05-13 20:21:35 +0800762 };
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
Victoria Milhoanb15e9ea2015-08-06 11:42:37 -0700772 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
Shawn Guob1d17f62014-05-13 20:21:35 +0800799 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>;
Peter Chen9493bf52015-09-30 10:17:16 +0800807 ahb-burst-config = <0x0>;
Peter Chen2b1a40e2015-09-30 10:17:17 +0800808 tx-burst-size-dword = <0x10>;
809 rx-burst-size-dword = <0x10>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800810 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>;
Peter Chen9493bf52015-09-30 10:17:16 +0800820 ahb-burst-config = <0x0>;
Peter Chen2b1a40e2015-09-30 10:17:17 +0800821 tx-burst-size-dword = <0x10>;
822 rx-burst-size-dword = <0x10>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800823 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>;
Matt Porter3ec481e2015-02-27 09:06:00 -0500834 dr_mode = "host";
Peter Chen9493bf52015-09-30 10:17:16 +0800835 ahb-burst-config = <0x0>;
Peter Chen2b1a40e2015-09-30 10:17:17 +0800836 tx-burst-size-dword = <0x10>;
837 rx-burst-size-dword = <0x10>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800838 status = "disabled";
839 };
840
841 usbmisc: usbmisc@02184800 {
842 #index-cells = <1>;
Fabio Estevamb29f4fa2014-06-23 11:21:04 -0300843 compatible = "fsl,imx6sx-usbmisc", "fsl,imx6q-usbmisc";
Shawn Guob1d17f62014-05-13 20:21:35 +0800844 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";
Frank Li0afdfe92014-09-13 05:00:57 +0800860 fsl,num-tx-queues=<3>;
861 fsl,num-rx-queues=<3>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800862 status = "disabled";
Jagan Teki46311702016-10-26 15:31:01 +0530863 };
Shawn Guob1d17f62014-05-13 20:21:35 +0800864
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 {
Fugang Duan9863aba2014-09-28 16:40:36 +0800958 compatible = "fsl,imx6sx-fec", "fsl,imx6q-fec";
Shawn Guob1d17f62014-05-13 20:21:35 +0800959 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 {
Joshua Clayton1be81ea2016-11-01 16:51:45 -0700973 #address-cells = <2>;
974 #size-cells = <1>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800975 compatible = "fsl,imx6sx-weim", "fsl,imx6q-weim";
976 reg = <0x021b8000 0x4000>;
977 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
978 clocks = <&clks IMX6SX_CLK_EIM_SLOW>;
Joshua Clayton1be81ea2016-11-01 16:51:45 -0700979 fsl,weim-cs-gpr = <&gpr>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800980 };
981
982 ocotp: ocotp@021bc000 {
983 compatible = "fsl,imx6sx-ocotp", "syscon";
984 reg = <0x021bc000 0x4000>;
985 clocks = <&clks IMX6SX_CLK_OCOTP>;
986 };
987
988 sai1: sai@021d4000 {
989 compatible = "fsl,imx6sx-sai";
990 reg = <0x021d4000 0x4000>;
991 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
992 clocks = <&clks IMX6SX_CLK_SAI1_IPG>,
993 <&clks IMX6SX_CLK_SAI1>,
994 <&clks 0>, <&clks 0>;
995 clock-names = "bus", "mclk1", "mclk2", "mclk3";
996 dma-names = "rx", "tx";
Fabio Estevam78f31b02016-04-01 20:52:14 -0300997 dmas = <&sdma 31 24 0>, <&sdma 32 24 0>;
Shawn Guob1d17f62014-05-13 20:21:35 +0800998 status = "disabled";
999 };
1000
1001 audmux: audmux@021d8000 {
1002 compatible = "fsl,imx6sx-audmux", "fsl,imx31-audmux";
1003 reg = <0x021d8000 0x4000>;
1004 status = "disabled";
1005 };
1006
1007 sai2: sai@021dc000 {
1008 compatible = "fsl,imx6sx-sai";
1009 reg = <0x021dc000 0x4000>;
1010 interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
1011 clocks = <&clks IMX6SX_CLK_SAI2_IPG>,
1012 <&clks IMX6SX_CLK_SAI2>,
1013 <&clks 0>, <&clks 0>;
1014 clock-names = "bus", "mclk1", "mclk2", "mclk3";
1015 dma-names = "rx", "tx";
Fabio Estevam78f31b02016-04-01 20:52:14 -03001016 dmas = <&sdma 33 24 0>, <&sdma 34 24 0>;
Shawn Guob1d17f62014-05-13 20:21:35 +08001017 status = "disabled";
1018 };
1019
1020 qspi1: qspi@021e0000 {
1021 #address-cells = <1>;
1022 #size-cells = <0>;
1023 compatible = "fsl,imx6sx-qspi";
1024 reg = <0x021e0000 0x4000>, <0x60000000 0x10000000>;
1025 reg-names = "QuadSPI", "QuadSPI-memory";
1026 interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
1027 clocks = <&clks IMX6SX_CLK_QSPI1>,
1028 <&clks IMX6SX_CLK_QSPI1>;
1029 clock-names = "qspi_en", "qspi";
1030 status = "disabled";
1031 };
1032
1033 qspi2: qspi@021e4000 {
1034 #address-cells = <1>;
1035 #size-cells = <0>;
1036 compatible = "fsl,imx6sx-qspi";
1037 reg = <0x021e4000 0x4000>, <0x70000000 0x10000000>;
1038 reg-names = "QuadSPI", "QuadSPI-memory";
1039 interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
1040 clocks = <&clks IMX6SX_CLK_QSPI2>,
1041 <&clks IMX6SX_CLK_QSPI2>;
1042 clock-names = "qspi_en", "qspi";
1043 status = "disabled";
1044 };
1045
1046 uart2: serial@021e8000 {
1047 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1048 reg = <0x021e8000 0x4000>;
1049 interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
1050 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1051 <&clks IMX6SX_CLK_UART_SERIAL>;
1052 clock-names = "ipg", "per";
1053 dmas = <&sdma 27 4 0>, <&sdma 28 4 0>;
1054 dma-names = "rx", "tx";
1055 status = "disabled";
1056 };
1057
1058 uart3: serial@021ec000 {
1059 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1060 reg = <0x021ec000 0x4000>;
1061 interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
1062 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1063 <&clks IMX6SX_CLK_UART_SERIAL>;
1064 clock-names = "ipg", "per";
1065 dmas = <&sdma 29 4 0>, <&sdma 30 4 0>;
1066 dma-names = "rx", "tx";
1067 status = "disabled";
1068 };
1069
1070 uart4: serial@021f0000 {
1071 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1072 reg = <0x021f0000 0x4000>;
1073 interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
1074 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1075 <&clks IMX6SX_CLK_UART_SERIAL>;
1076 clock-names = "ipg", "per";
1077 dmas = <&sdma 31 4 0>, <&sdma 32 4 0>;
1078 dma-names = "rx", "tx";
1079 status = "disabled";
1080 };
1081
1082 uart5: serial@021f4000 {
1083 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1084 reg = <0x021f4000 0x4000>;
1085 interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
1086 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1087 <&clks IMX6SX_CLK_UART_SERIAL>;
1088 clock-names = "ipg", "per";
1089 dmas = <&sdma 33 4 0>, <&sdma 34 4 0>;
1090 dma-names = "rx", "tx";
1091 status = "disabled";
1092 };
1093
1094 i2c4: i2c@021f8000 {
1095 #address-cells = <1>;
1096 #size-cells = <0>;
1097 compatible = "fsl,imx6sx-i2c", "fsl,imx21-i2c";
1098 reg = <0x021f8000 0x4000>;
1099 interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
1100 clocks = <&clks IMX6SX_CLK_I2C4>;
1101 status = "disabled";
1102 };
1103 };
1104
1105 aips3: aips-bus@02200000 {
1106 compatible = "fsl,aips-bus", "simple-bus";
1107 #address-cells = <1>;
1108 #size-cells = <1>;
1109 reg = <0x02200000 0x100000>;
1110 ranges;
1111
1112 spba-bus@02200000 {
1113 compatible = "fsl,spba-bus", "simple-bus";
1114 #address-cells = <1>;
1115 #size-cells = <1>;
1116 reg = <0x02240000 0x40000>;
1117 ranges;
1118
1119 csi1: csi@02214000 {
1120 reg = <0x02214000 0x4000>;
1121 interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
1122 clocks = <&clks IMX6SX_CLK_DISPLAY_AXI>,
1123 <&clks IMX6SX_CLK_CSI>,
1124 <&clks IMX6SX_CLK_DCIC1>;
1125 clock-names = "disp-axi", "csi_mclk", "dcic";
1126 status = "disabled";
1127 };
1128
1129 pxp: pxp@02218000 {
1130 reg = <0x02218000 0x4000>;
1131 interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
1132 clocks = <&clks IMX6SX_CLK_PXP_AXI>,
1133 <&clks IMX6SX_CLK_DISPLAY_AXI>;
1134 clock-names = "pxp-axi", "disp-axi";
1135 status = "disabled";
1136 };
1137
1138 csi2: csi@0221c000 {
1139 reg = <0x0221c000 0x4000>;
1140 interrupts = <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>;
1141 clocks = <&clks IMX6SX_CLK_DISPLAY_AXI>,
1142 <&clks IMX6SX_CLK_CSI>,
1143 <&clks IMX6SX_CLK_DCIC2>;
1144 clock-names = "disp-axi", "csi_mclk", "dcic";
1145 status = "disabled";
1146 };
1147
1148 lcdif1: lcdif@02220000 {
Fabio Estevam8c78c402014-09-02 15:00:43 -03001149 compatible = "fsl,imx6sx-lcdif", "fsl,imx28-lcdif";
Shawn Guob1d17f62014-05-13 20:21:35 +08001150 reg = <0x02220000 0x4000>;
Marek Vasutf7f3b482016-10-02 18:44:35 +02001151 interrupts = <GIC_SPI 5 IRQ_TYPE_EDGE_RISING>;
Shawn Guob1d17f62014-05-13 20:21:35 +08001152 clocks = <&clks IMX6SX_CLK_LCDIF1_PIX>,
1153 <&clks IMX6SX_CLK_LCDIF_APB>,
1154 <&clks IMX6SX_CLK_DISPLAY_AXI>;
1155 clock-names = "pix", "axi", "disp_axi";
1156 status = "disabled";
1157 };
1158
1159 lcdif2: lcdif@02224000 {
Fabio Estevam8c78c402014-09-02 15:00:43 -03001160 compatible = "fsl,imx6sx-lcdif", "fsl,imx28-lcdif";
Shawn Guob1d17f62014-05-13 20:21:35 +08001161 reg = <0x02224000 0x4000>;
Marek Vasutf7f3b482016-10-02 18:44:35 +02001162 interrupts = <GIC_SPI 6 IRQ_TYPE_EDGE_RISING>;
Shawn Guob1d17f62014-05-13 20:21:35 +08001163 clocks = <&clks IMX6SX_CLK_LCDIF2_PIX>,
1164 <&clks IMX6SX_CLK_LCDIF_APB>,
1165 <&clks IMX6SX_CLK_DISPLAY_AXI>;
1166 clock-names = "pix", "axi", "disp_axi";
1167 status = "disabled";
1168 };
1169
1170 vadc: vadc@02228000 {
1171 reg = <0x02228000 0x4000>, <0x0222c000 0x4000>;
1172 reg-names = "vadc-vafe", "vadc-vdec";
1173 clocks = <&clks IMX6SX_CLK_VADC>,
1174 <&clks IMX6SX_CLK_CSI>;
1175 clock-names = "vadc", "csi";
1176 status = "disabled";
1177 };
1178 };
1179
1180 adc1: adc@02280000 {
1181 compatible = "fsl,imx6sx-adc", "fsl,vf610-adc";
1182 reg = <0x02280000 0x4000>;
1183 interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
1184 clocks = <&clks IMX6SX_CLK_IPG>;
1185 clock-names = "adc";
Fabio Estevameb45ff72015-11-03 14:25:36 -02001186 fsl,adck-max-frequency = <30000000>, <40000000>,
1187 <20000000>;
Shawn Guob1d17f62014-05-13 20:21:35 +08001188 status = "disabled";
Jagan Teki46311702016-10-26 15:31:01 +05301189 };
Shawn Guob1d17f62014-05-13 20:21:35 +08001190
1191 adc2: adc@02284000 {
1192 compatible = "fsl,imx6sx-adc", "fsl,vf610-adc";
1193 reg = <0x02284000 0x4000>;
1194 interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
1195 clocks = <&clks IMX6SX_CLK_IPG>;
1196 clock-names = "adc";
Fabio Estevameb45ff72015-11-03 14:25:36 -02001197 fsl,adck-max-frequency = <30000000>, <40000000>,
1198 <20000000>;
Shawn Guob1d17f62014-05-13 20:21:35 +08001199 status = "disabled";
Jagan Teki46311702016-10-26 15:31:01 +05301200 };
Shawn Guob1d17f62014-05-13 20:21:35 +08001201
1202 wdog3: wdog@02288000 {
1203 compatible = "fsl,imx6sx-wdt", "fsl,imx21-wdt";
1204 reg = <0x02288000 0x4000>;
1205 interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
1206 clocks = <&clks IMX6SX_CLK_DUMMY>;
1207 status = "disabled";
1208 };
1209
1210 ecspi5: ecspi@0228c000 {
1211 #address-cells = <1>;
1212 #size-cells = <0>;
1213 compatible = "fsl,imx6sx-ecspi", "fsl,imx51-ecspi";
1214 reg = <0x0228c000 0x4000>;
1215 interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
1216 clocks = <&clks IMX6SX_CLK_ECSPI5>,
1217 <&clks IMX6SX_CLK_ECSPI5>;
1218 clock-names = "ipg", "per";
1219 status = "disabled";
1220 };
1221
1222 uart6: serial@022a0000 {
1223 compatible = "fsl,imx6sx-uart", "fsl,imx21-uart";
1224 reg = <0x022a0000 0x4000>;
1225 interrupts = <GIC_SPI 17 IRQ_TYPE_LEVEL_HIGH>;
1226 clocks = <&clks IMX6SX_CLK_UART_IPG>,
1227 <&clks IMX6SX_CLK_UART_SERIAL>;
1228 clock-names = "ipg", "per";
1229 dmas = <&sdma 0 4 0>, <&sdma 47 4 0>;
1230 dma-names = "rx", "tx";
1231 status = "disabled";
1232 };
1233
1234 pwm5: pwm@022a4000 {
1235 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
1236 reg = <0x022a4000 0x4000>;
1237 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
1238 clocks = <&clks IMX6SX_CLK_PWM5>,
1239 <&clks IMX6SX_CLK_PWM5>;
1240 clock-names = "ipg", "per";
1241 #pwm-cells = <2>;
1242 };
1243
1244 pwm6: pwm@022a8000 {
1245 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
1246 reg = <0x022a8000 0x4000>;
1247 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
1248 clocks = <&clks IMX6SX_CLK_PWM6>,
1249 <&clks IMX6SX_CLK_PWM6>;
1250 clock-names = "ipg", "per";
1251 #pwm-cells = <2>;
1252 };
1253
1254 pwm7: pwm@022ac000 {
1255 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
1256 reg = <0x022ac000 0x4000>;
1257 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
1258 clocks = <&clks IMX6SX_CLK_PWM7>,
1259 <&clks IMX6SX_CLK_PWM7>;
1260 clock-names = "ipg", "per";
1261 #pwm-cells = <2>;
1262 };
1263
1264 pwm8: pwm@0022b0000 {
1265 compatible = "fsl,imx6sx-pwm", "fsl,imx27-pwm";
1266 reg = <0x0022b0000 0x4000>;
1267 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
1268 clocks = <&clks IMX6SX_CLK_PWM8>,
1269 <&clks IMX6SX_CLK_PWM8>;
1270 clock-names = "ipg", "per";
1271 #pwm-cells = <2>;
1272 };
1273 };
1274
1275 pcie: pcie@0x08000000 {
1276 compatible = "fsl,imx6sx-pcie", "snps,dw-pcie";
1277 reg = <0x08ffc000 0x4000>; /* DBI */
1278 #address-cells = <3>;
1279 #size-cells = <2>;
1280 device_type = "pci";
1281 /* configuration space */
1282 ranges = <0x00000800 0 0x08f00000 0x08f00000 0 0x00080000
1283 /* downstream I/O */
1284 0x81000000 0 0 0x08f80000 0 0x00010000
1285 /* non-prefetchable memory */
1286 0x82000000 0 0x08000000 0x08000000 0 0x00f00000>;
1287 num-lanes = <1>;
1288 interrupts = <GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>;
1289 clocks = <&clks IMX6SX_CLK_PCIE_REF_125M>,
1290 <&clks IMX6SX_CLK_PCIE_AXI>,
1291 <&clks IMX6SX_CLK_LVDS1_OUT>,
1292 <&clks IMX6SX_CLK_DISPLAY_AXI>;
1293 clock-names = "pcie_ref_125m", "pcie_axi",
1294 "lvds_gate", "display_axi";
1295 status = "disabled";
1296 };
1297 };
Marek Vasut51c578e2016-08-26 16:22:54 +02001298
1299 gpu-subsystem {
1300 compatible = "fsl,imx-gpu-subsystem";
1301 cores = <&gpu>;
1302 };
Shawn Guob1d17f62014-05-13 20:21:35 +08001303};