blob: c0ee12f1f17136808aa95ef017c504337ed86e6d [file] [log] [blame]
Shawn Guoe29fe212013-05-03 11:26:30 +08001/*
2 * Copyright 2013 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
Troy Kisky13088c22013-11-14 14:02:12 -070010#include <dt-bindings/interrupt-controller/irq.h>
Shawn Guoe29fe212013-05-03 11:26:30 +080011#include "skeleton.dtsi"
12#include "imx6sl-pinfunc.h"
13#include <dt-bindings/clock/imx6sl-clock.h>
14
15/ {
16 aliases {
Marek Vasut22970072014-02-28 12:58:41 +010017 ethernet0 = &fec;
Shawn Guoe29fe212013-05-03 11:26:30 +080018 gpio0 = &gpio1;
19 gpio1 = &gpio2;
20 gpio2 = &gpio3;
21 gpio3 = &gpio4;
22 gpio4 = &gpio5;
Fabio Estevam640a7f32013-09-13 18:13:00 -030023 serial0 = &uart1;
24 serial1 = &uart2;
25 serial2 = &uart3;
26 serial3 = &uart4;
27 serial4 = &uart5;
28 spi0 = &ecspi1;
29 spi1 = &ecspi2;
30 spi2 = &ecspi3;
31 spi3 = &ecspi4;
Peter Chen8189c512013-12-20 15:52:05 +080032 usbphy0 = &usbphy1;
33 usbphy1 = &usbphy2;
Shawn Guoe29fe212013-05-03 11:26:30 +080034 };
35
36 cpus {
37 #address-cells = <1>;
38 #size-cells = <0>;
39
40 cpu@0 {
41 compatible = "arm,cortex-a9";
42 device_type = "cpu";
43 reg = <0x0>;
44 next-level-cache = <&L2>;
John Tobiasb0d300d2013-12-19 12:35:36 -080045 operating-points = <
46 /* kHz uV */
47 996000 1275000
48 792000 1175000
49 396000 975000
50 >;
51 fsl,soc-operating-points = <
52 /* ARM kHz SOC-PU uV */
53 996000 1225000
54 792000 1175000
55 396000 1175000
56 >;
57 clock-latency = <61036>; /* two CLK32 periods */
58 clocks = <&clks IMX6SL_CLK_ARM>, <&clks IMX6SL_CLK_PLL2_PFD2>,
59 <&clks IMX6SL_CLK_STEP>, <&clks IMX6SL_CLK_PLL1_SW>,
60 <&clks IMX6SL_CLK_PLL1_SYS>;
61 clock-names = "arm", "pll2_pfd2_396m", "step",
62 "pll1_sw", "pll1_sys";
63 arm-supply = <&reg_arm>;
64 pu-supply = <&reg_pu>;
65 soc-supply = <&reg_soc>;
Shawn Guoe29fe212013-05-03 11:26:30 +080066 };
67 };
68
69 intc: interrupt-controller@00a01000 {
70 compatible = "arm,cortex-a9-gic";
71 #interrupt-cells = <3>;
Shawn Guoe29fe212013-05-03 11:26:30 +080072 interrupt-controller;
73 reg = <0x00a01000 0x1000>,
74 <0x00a00100 0x100>;
75 };
76
77 clocks {
78 #address-cells = <1>;
79 #size-cells = <0>;
80
81 ckil {
82 compatible = "fixed-clock";
Shawn Guo4b2b4042014-04-11 09:56:46 +080083 #clock-cells = <0>;
Shawn Guoe29fe212013-05-03 11:26:30 +080084 clock-frequency = <32768>;
85 };
86
87 osc {
88 compatible = "fixed-clock";
Shawn Guo4b2b4042014-04-11 09:56:46 +080089 #clock-cells = <0>;
Shawn Guoe29fe212013-05-03 11:26:30 +080090 clock-frequency = <24000000>;
91 };
92 };
93
94 soc {
95 #address-cells = <1>;
96 #size-cells = <1>;
97 compatible = "simple-bus";
98 interrupt-parent = <&intc>;
99 ranges;
100
Anson Huang248f15a2014-01-06 15:57:37 -0500101 ocram: sram@00900000 {
102 compatible = "mmio-sram";
103 reg = <0x00900000 0x20000>;
104 clocks = <&clks IMX6SL_CLK_OCRAM>;
105 };
106
Shawn Guoe29fe212013-05-03 11:26:30 +0800107 L2: l2-cache@00a02000 {
108 compatible = "arm,pl310-cache";
109 reg = <0x00a02000 0x1000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700110 interrupts = <0 92 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800111 cache-unified;
112 cache-level = <2>;
113 arm,tag-latency = <4 2 3>;
114 arm,data-latency = <4 2 3>;
115 };
116
117 pmu {
118 compatible = "arm,cortex-a9-pmu";
Troy Kisky13088c22013-11-14 14:02:12 -0700119 interrupts = <0 94 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800120 };
121
122 aips1: aips-bus@02000000 {
123 compatible = "fsl,aips-bus", "simple-bus";
124 #address-cells = <1>;
125 #size-cells = <1>;
126 reg = <0x02000000 0x100000>;
127 ranges;
128
129 spba: spba-bus@02000000 {
130 compatible = "fsl,spba-bus", "simple-bus";
131 #address-cells = <1>;
132 #size-cells = <1>;
133 reg = <0x02000000 0x40000>;
134 ranges;
135
136 spdif: spdif@02004000 {
137 reg = <0x02004000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700138 interrupts = <0 52 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800139 };
140
141 ecspi1: ecspi@02008000 {
142 #address-cells = <1>;
143 #size-cells = <0>;
144 compatible = "fsl,imx6sl-ecspi", "fsl,imx51-ecspi";
145 reg = <0x02008000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700146 interrupts = <0 31 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800147 clocks = <&clks IMX6SL_CLK_ECSPI1>,
148 <&clks IMX6SL_CLK_ECSPI1>;
149 clock-names = "ipg", "per";
150 status = "disabled";
151 };
152
153 ecspi2: ecspi@0200c000 {
154 #address-cells = <1>;
155 #size-cells = <0>;
156 compatible = "fsl,imx6sl-ecspi", "fsl,imx51-ecspi";
157 reg = <0x0200c000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700158 interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800159 clocks = <&clks IMX6SL_CLK_ECSPI2>,
160 <&clks IMX6SL_CLK_ECSPI2>;
161 clock-names = "ipg", "per";
162 status = "disabled";
163 };
164
165 ecspi3: ecspi@02010000 {
166 #address-cells = <1>;
167 #size-cells = <0>;
168 compatible = "fsl,imx6sl-ecspi", "fsl,imx51-ecspi";
169 reg = <0x02010000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700170 interrupts = <0 33 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800171 clocks = <&clks IMX6SL_CLK_ECSPI3>,
172 <&clks IMX6SL_CLK_ECSPI3>;
173 clock-names = "ipg", "per";
174 status = "disabled";
175 };
176
177 ecspi4: ecspi@02014000 {
178 #address-cells = <1>;
179 #size-cells = <0>;
180 compatible = "fsl,imx6sl-ecspi", "fsl,imx51-ecspi";
181 reg = <0x02014000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700182 interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800183 clocks = <&clks IMX6SL_CLK_ECSPI4>,
184 <&clks IMX6SL_CLK_ECSPI4>;
185 clock-names = "ipg", "per";
186 status = "disabled";
187 };
188
189 uart5: serial@02018000 {
Huang Shijie6eb85f92013-07-08 17:14:19 +0800190 compatible = "fsl,imx6sl-uart",
191 "fsl,imx6q-uart", "fsl,imx21-uart";
Shawn Guoe29fe212013-05-03 11:26:30 +0800192 reg = <0x02018000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700193 interrupts = <0 30 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800194 clocks = <&clks IMX6SL_CLK_UART>,
195 <&clks IMX6SL_CLK_UART_SERIAL>;
196 clock-names = "ipg", "per";
Huang Shijie72a5ceb2013-07-12 18:02:09 +0800197 dmas = <&sdma 33 4 0>, <&sdma 34 4 0>;
198 dma-names = "rx", "tx";
Shawn Guoe29fe212013-05-03 11:26:30 +0800199 status = "disabled";
200 };
201
202 uart1: serial@02020000 {
Huang Shijie6eb85f92013-07-08 17:14:19 +0800203 compatible = "fsl,imx6sl-uart",
204 "fsl,imx6q-uart", "fsl,imx21-uart";
Shawn Guoe29fe212013-05-03 11:26:30 +0800205 reg = <0x02020000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700206 interrupts = <0 26 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800207 clocks = <&clks IMX6SL_CLK_UART>,
208 <&clks IMX6SL_CLK_UART_SERIAL>;
209 clock-names = "ipg", "per";
Huang Shijie72a5ceb2013-07-12 18:02:09 +0800210 dmas = <&sdma 25 4 0>, <&sdma 26 4 0>;
211 dma-names = "rx", "tx";
Shawn Guoe29fe212013-05-03 11:26:30 +0800212 status = "disabled";
213 };
214
215 uart2: serial@02024000 {
Huang Shijie6eb85f92013-07-08 17:14:19 +0800216 compatible = "fsl,imx6sl-uart",
217 "fsl,imx6q-uart", "fsl,imx21-uart";
Shawn Guoe29fe212013-05-03 11:26:30 +0800218 reg = <0x02024000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700219 interrupts = <0 27 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800220 clocks = <&clks IMX6SL_CLK_UART>,
221 <&clks IMX6SL_CLK_UART_SERIAL>;
222 clock-names = "ipg", "per";
Huang Shijie72a5ceb2013-07-12 18:02:09 +0800223 dmas = <&sdma 27 4 0>, <&sdma 28 4 0>;
224 dma-names = "rx", "tx";
Shawn Guoe29fe212013-05-03 11:26:30 +0800225 status = "disabled";
226 };
227
228 ssi1: ssi@02028000 {
Markus Pargmann98ea6ad2014-01-17 10:07:42 +0100229 compatible = "fsl,imx6sl-ssi",
230 "fsl,imx51-ssi",
231 "fsl,imx21-ssi";
Shawn Guoe29fe212013-05-03 11:26:30 +0800232 reg = <0x02028000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700233 interrupts = <0 46 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800234 clocks = <&clks IMX6SL_CLK_SSI1>;
Shawn Guo5da826a2013-07-17 13:50:54 +0800235 dmas = <&sdma 37 1 0>,
236 <&sdma 38 1 0>;
237 dma-names = "rx", "tx";
Shawn Guoe29fe212013-05-03 11:26:30 +0800238 fsl,fifo-depth = <15>;
239 status = "disabled";
240 };
241
242 ssi2: ssi@0202c000 {
Markus Pargmann98ea6ad2014-01-17 10:07:42 +0100243 compatible = "fsl,imx6sl-ssi",
244 "fsl,imx51-ssi",
245 "fsl,imx21-ssi";
Shawn Guoe29fe212013-05-03 11:26:30 +0800246 reg = <0x0202c000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700247 interrupts = <0 47 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800248 clocks = <&clks IMX6SL_CLK_SSI2>;
Shawn Guo5da826a2013-07-17 13:50:54 +0800249 dmas = <&sdma 41 1 0>,
250 <&sdma 42 1 0>;
251 dma-names = "rx", "tx";
Shawn Guoe29fe212013-05-03 11:26:30 +0800252 fsl,fifo-depth = <15>;
253 status = "disabled";
254 };
255
256 ssi3: ssi@02030000 {
Markus Pargmann98ea6ad2014-01-17 10:07:42 +0100257 compatible = "fsl,imx6sl-ssi",
258 "fsl,imx51-ssi",
259 "fsl,imx21-ssi";
Shawn Guoe29fe212013-05-03 11:26:30 +0800260 reg = <0x02030000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700261 interrupts = <0 48 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800262 clocks = <&clks IMX6SL_CLK_SSI3>;
Shawn Guo5da826a2013-07-17 13:50:54 +0800263 dmas = <&sdma 45 1 0>,
264 <&sdma 46 1 0>;
265 dma-names = "rx", "tx";
Shawn Guoe29fe212013-05-03 11:26:30 +0800266 fsl,fifo-depth = <15>;
267 status = "disabled";
268 };
269
270 uart3: serial@02034000 {
Huang Shijie6eb85f92013-07-08 17:14:19 +0800271 compatible = "fsl,imx6sl-uart",
272 "fsl,imx6q-uart", "fsl,imx21-uart";
Shawn Guoe29fe212013-05-03 11:26:30 +0800273 reg = <0x02034000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700274 interrupts = <0 28 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800275 clocks = <&clks IMX6SL_CLK_UART>,
276 <&clks IMX6SL_CLK_UART_SERIAL>;
277 clock-names = "ipg", "per";
Huang Shijie72a5ceb2013-07-12 18:02:09 +0800278 dmas = <&sdma 29 4 0>, <&sdma 30 4 0>;
279 dma-names = "rx", "tx";
Shawn Guoe29fe212013-05-03 11:26:30 +0800280 status = "disabled";
281 };
282
283 uart4: serial@02038000 {
Huang Shijie6eb85f92013-07-08 17:14:19 +0800284 compatible = "fsl,imx6sl-uart",
285 "fsl,imx6q-uart", "fsl,imx21-uart";
Shawn Guoe29fe212013-05-03 11:26:30 +0800286 reg = <0x02038000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700287 interrupts = <0 29 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800288 clocks = <&clks IMX6SL_CLK_UART>,
289 <&clks IMX6SL_CLK_UART_SERIAL>;
290 clock-names = "ipg", "per";
Huang Shijie72a5ceb2013-07-12 18:02:09 +0800291 dmas = <&sdma 31 4 0>, <&sdma 32 4 0>;
292 dma-names = "rx", "tx";
Shawn Guoe29fe212013-05-03 11:26:30 +0800293 status = "disabled";
294 };
295 };
296
297 pwm1: pwm@02080000 {
298 #pwm-cells = <2>;
299 compatible = "fsl,imx6sl-pwm", "fsl,imx27-pwm";
300 reg = <0x02080000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700301 interrupts = <0 83 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800302 clocks = <&clks IMX6SL_CLK_PWM1>,
303 <&clks IMX6SL_CLK_PWM1>;
304 clock-names = "ipg", "per";
305 };
306
307 pwm2: pwm@02084000 {
308 #pwm-cells = <2>;
309 compatible = "fsl,imx6sl-pwm", "fsl,imx27-pwm";
310 reg = <0x02084000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700311 interrupts = <0 84 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800312 clocks = <&clks IMX6SL_CLK_PWM2>,
313 <&clks IMX6SL_CLK_PWM2>;
314 clock-names = "ipg", "per";
315 };
316
317 pwm3: pwm@02088000 {
318 #pwm-cells = <2>;
319 compatible = "fsl,imx6sl-pwm", "fsl,imx27-pwm";
320 reg = <0x02088000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700321 interrupts = <0 85 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800322 clocks = <&clks IMX6SL_CLK_PWM3>,
323 <&clks IMX6SL_CLK_PWM3>;
324 clock-names = "ipg", "per";
325 };
326
327 pwm4: pwm@0208c000 {
328 #pwm-cells = <2>;
329 compatible = "fsl,imx6sl-pwm", "fsl,imx27-pwm";
330 reg = <0x0208c000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700331 interrupts = <0 86 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800332 clocks = <&clks IMX6SL_CLK_PWM4>,
333 <&clks IMX6SL_CLK_PWM4>;
334 clock-names = "ipg", "per";
335 };
336
337 gpt: gpt@02098000 {
338 compatible = "fsl,imx6sl-gpt";
339 reg = <0x02098000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700340 interrupts = <0 55 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800341 clocks = <&clks IMX6SL_CLK_GPT>,
342 <&clks IMX6SL_CLK_GPT_SERIAL>;
343 clock-names = "ipg", "per";
344 };
345
346 gpio1: gpio@0209c000 {
347 compatible = "fsl,imx6sl-gpio", "fsl,imx35-gpio";
348 reg = <0x0209c000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700349 interrupts = <0 66 IRQ_TYPE_LEVEL_HIGH>,
350 <0 67 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800351 gpio-controller;
352 #gpio-cells = <2>;
353 interrupt-controller;
354 #interrupt-cells = <2>;
355 };
356
357 gpio2: gpio@020a0000 {
358 compatible = "fsl,imx6sl-gpio", "fsl,imx35-gpio";
359 reg = <0x020a0000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700360 interrupts = <0 68 IRQ_TYPE_LEVEL_HIGH>,
361 <0 69 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800362 gpio-controller;
363 #gpio-cells = <2>;
364 interrupt-controller;
365 #interrupt-cells = <2>;
366 };
367
368 gpio3: gpio@020a4000 {
369 compatible = "fsl,imx6sl-gpio", "fsl,imx35-gpio";
370 reg = <0x020a4000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700371 interrupts = <0 70 IRQ_TYPE_LEVEL_HIGH>,
372 <0 71 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800373 gpio-controller;
374 #gpio-cells = <2>;
375 interrupt-controller;
376 #interrupt-cells = <2>;
377 };
378
379 gpio4: gpio@020a8000 {
380 compatible = "fsl,imx6sl-gpio", "fsl,imx35-gpio";
381 reg = <0x020a8000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700382 interrupts = <0 72 IRQ_TYPE_LEVEL_HIGH>,
383 <0 73 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800384 gpio-controller;
385 #gpio-cells = <2>;
386 interrupt-controller;
387 #interrupt-cells = <2>;
388 };
389
390 gpio5: gpio@020ac000 {
391 compatible = "fsl,imx6sl-gpio", "fsl,imx35-gpio";
392 reg = <0x020ac000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700393 interrupts = <0 74 IRQ_TYPE_LEVEL_HIGH>,
394 <0 75 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800395 gpio-controller;
396 #gpio-cells = <2>;
397 interrupt-controller;
398 #interrupt-cells = <2>;
399 };
400
401 kpp: kpp@020b8000 {
Anson Huang4291b642014-01-14 17:30:28 +0800402 compatible = "fsl,imx6sl-kpp", "fsl,imx21-kpp";
Shawn Guoe29fe212013-05-03 11:26:30 +0800403 reg = <0x020b8000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700404 interrupts = <0 82 IRQ_TYPE_LEVEL_HIGH>;
Anson Huang4291b642014-01-14 17:30:28 +0800405 clocks = <&clks IMX6SL_CLK_DUMMY>;
Fabio Estevam1b6f2362014-06-24 21:13:44 -0300406 status = "disabled";
Shawn Guoe29fe212013-05-03 11:26:30 +0800407 };
408
409 wdog1: wdog@020bc000 {
410 compatible = "fsl,imx6sl-wdt", "fsl,imx21-wdt";
411 reg = <0x020bc000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700412 interrupts = <0 80 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800413 clocks = <&clks IMX6SL_CLK_DUMMY>;
414 };
415
416 wdog2: wdog@020c0000 {
417 compatible = "fsl,imx6sl-wdt", "fsl,imx21-wdt";
418 reg = <0x020c0000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700419 interrupts = <0 81 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800420 clocks = <&clks IMX6SL_CLK_DUMMY>;
421 status = "disabled";
422 };
423
424 clks: ccm@020c4000 {
425 compatible = "fsl,imx6sl-ccm";
426 reg = <0x020c4000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700427 interrupts = <0 87 IRQ_TYPE_LEVEL_HIGH>,
428 <0 88 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800429 #clock-cells = <1>;
430 };
431
432 anatop: anatop@020c8000 {
Shawn Guod8ce8232013-08-13 16:54:05 +0800433 compatible = "fsl,imx6sl-anatop",
434 "fsl,imx6q-anatop",
435 "syscon", "simple-bus";
Shawn Guoe29fe212013-05-03 11:26:30 +0800436 reg = <0x020c8000 0x1000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700437 interrupts = <0 49 IRQ_TYPE_LEVEL_HIGH>,
438 <0 54 IRQ_TYPE_LEVEL_HIGH>,
439 <0 127 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800440
441 regulator-1p1@110 {
442 compatible = "fsl,anatop-regulator";
443 regulator-name = "vdd1p1";
444 regulator-min-microvolt = <800000>;
445 regulator-max-microvolt = <1375000>;
446 regulator-always-on;
447 anatop-reg-offset = <0x110>;
448 anatop-vol-bit-shift = <8>;
449 anatop-vol-bit-width = <5>;
450 anatop-min-bit-val = <4>;
451 anatop-min-voltage = <800000>;
452 anatop-max-voltage = <1375000>;
453 };
454
455 regulator-3p0@120 {
456 compatible = "fsl,anatop-regulator";
457 regulator-name = "vdd3p0";
458 regulator-min-microvolt = <2800000>;
459 regulator-max-microvolt = <3150000>;
460 regulator-always-on;
461 anatop-reg-offset = <0x120>;
462 anatop-vol-bit-shift = <8>;
463 anatop-vol-bit-width = <5>;
464 anatop-min-bit-val = <0>;
465 anatop-min-voltage = <2625000>;
466 anatop-max-voltage = <3400000>;
467 };
468
469 regulator-2p5@130 {
470 compatible = "fsl,anatop-regulator";
471 regulator-name = "vdd2p5";
472 regulator-min-microvolt = <2100000>;
473 regulator-max-microvolt = <2850000>;
474 regulator-always-on;
475 anatop-reg-offset = <0x130>;
476 anatop-vol-bit-shift = <8>;
477 anatop-vol-bit-width = <5>;
478 anatop-min-bit-val = <0>;
479 anatop-min-voltage = <2100000>;
480 anatop-max-voltage = <2850000>;
481 };
482
483 reg_arm: regulator-vddcore@140 {
484 compatible = "fsl,anatop-regulator";
Fabio Estevam118c98a2013-12-19 21:08:52 -0200485 regulator-name = "vddarm";
Shawn Guoe29fe212013-05-03 11:26:30 +0800486 regulator-min-microvolt = <725000>;
487 regulator-max-microvolt = <1450000>;
488 regulator-always-on;
489 anatop-reg-offset = <0x140>;
490 anatop-vol-bit-shift = <0>;
491 anatop-vol-bit-width = <5>;
492 anatop-delay-reg-offset = <0x170>;
493 anatop-delay-bit-shift = <24>;
494 anatop-delay-bit-width = <2>;
495 anatop-min-bit-val = <1>;
496 anatop-min-voltage = <725000>;
497 anatop-max-voltage = <1450000>;
498 };
499
500 reg_pu: regulator-vddpu@140 {
501 compatible = "fsl,anatop-regulator";
502 regulator-name = "vddpu";
503 regulator-min-microvolt = <725000>;
504 regulator-max-microvolt = <1450000>;
505 regulator-always-on;
506 anatop-reg-offset = <0x140>;
507 anatop-vol-bit-shift = <9>;
508 anatop-vol-bit-width = <5>;
509 anatop-delay-reg-offset = <0x170>;
510 anatop-delay-bit-shift = <26>;
511 anatop-delay-bit-width = <2>;
512 anatop-min-bit-val = <1>;
513 anatop-min-voltage = <725000>;
514 anatop-max-voltage = <1450000>;
515 };
516
517 reg_soc: regulator-vddsoc@140 {
518 compatible = "fsl,anatop-regulator";
519 regulator-name = "vddsoc";
520 regulator-min-microvolt = <725000>;
521 regulator-max-microvolt = <1450000>;
522 regulator-always-on;
523 anatop-reg-offset = <0x140>;
524 anatop-vol-bit-shift = <18>;
525 anatop-vol-bit-width = <5>;
526 anatop-delay-reg-offset = <0x170>;
527 anatop-delay-bit-shift = <28>;
528 anatop-delay-bit-width = <2>;
529 anatop-min-bit-val = <1>;
530 anatop-min-voltage = <725000>;
531 anatop-max-voltage = <1450000>;
532 };
533 };
534
535 usbphy1: usbphy@020c9000 {
536 compatible = "fsl,imx6sl-usbphy", "fsl,imx23-usbphy";
537 reg = <0x020c9000 0x1000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700538 interrupts = <0 44 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800539 clocks = <&clks IMX6SL_CLK_USBPHY1>;
Peter Chen76a38852013-12-20 15:52:01 +0800540 fsl,anatop = <&anatop>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800541 };
542
543 usbphy2: usbphy@020ca000 {
544 compatible = "fsl,imx6sl-usbphy", "fsl,imx23-usbphy";
545 reg = <0x020ca000 0x1000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700546 interrupts = <0 45 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800547 clocks = <&clks IMX6SL_CLK_USBPHY2>;
Peter Chen76a38852013-12-20 15:52:01 +0800548 fsl,anatop = <&anatop>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800549 };
550
551 snvs@020cc000 {
552 compatible = "fsl,sec-v4.0-mon", "simple-bus";
553 #address-cells = <1>;
554 #size-cells = <1>;
555 ranges = <0 0x020cc000 0x4000>;
556
557 snvs-rtc-lp@34 {
558 compatible = "fsl,sec-v4.0-mon-rtc-lp";
559 reg = <0x34 0x58>;
Troy Kisky13088c22013-11-14 14:02:12 -0700560 interrupts = <0 19 IRQ_TYPE_LEVEL_HIGH>,
561 <0 20 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800562 };
563 };
564
565 epit1: epit@020d0000 {
566 reg = <0x020d0000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700567 interrupts = <0 56 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800568 };
569
570 epit2: epit@020d4000 {
571 reg = <0x020d4000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700572 interrupts = <0 57 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800573 };
574
575 src: src@020d8000 {
576 compatible = "fsl,imx6sl-src", "fsl,imx51-src";
577 reg = <0x020d8000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700578 interrupts = <0 91 IRQ_TYPE_LEVEL_HIGH>,
579 <0 96 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800580 #reset-cells = <1>;
581 };
582
583 gpc: gpc@020dc000 {
584 compatible = "fsl,imx6sl-gpc", "fsl,imx6q-gpc";
585 reg = <0x020dc000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700586 interrupts = <0 89 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800587 };
588
Fugang Duane03d10f2013-09-03 12:26:22 +0800589 gpr: iomuxc-gpr@020e0000 {
Shawn Guo5f7adc92013-10-18 23:27:37 +0800590 compatible = "fsl,imx6sl-iomuxc-gpr",
591 "fsl,imx6q-iomuxc-gpr", "syscon";
Fugang Duane03d10f2013-09-03 12:26:22 +0800592 reg = <0x020e0000 0x38>;
593 };
594
Shawn Guoe29fe212013-05-03 11:26:30 +0800595 iomuxc: iomuxc@020e0000 {
596 compatible = "fsl,imx6sl-iomuxc";
597 reg = <0x020e0000 0x4000>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800598 };
599
600 csi: csi@020e4000 {
601 reg = <0x020e4000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700602 interrupts = <0 7 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800603 };
604
605 spdc: spdc@020e8000 {
606 reg = <0x020e8000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700607 interrupts = <0 6 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800608 };
609
610 sdma: sdma@020ec000 {
611 compatible = "fsl,imx6sl-sdma", "fsl,imx35-sdma";
612 reg = <0x020ec000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700613 interrupts = <0 2 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800614 clocks = <&clks IMX6SL_CLK_SDMA>,
615 <&clks IMX6SL_CLK_SDMA>;
616 clock-names = "ipg", "ahb";
Huang Shijiefb72bb22013-07-02 10:15:29 +0800617 #dma-cells = <3>;
Shawn Guo44a26872013-08-13 08:55:02 +0800618 /* imx6sl reuses imx6q sdma firmware */
619 fsl,sdma-ram-script-name = "imx/sdma/sdma-imx6q.bin";
Shawn Guoe29fe212013-05-03 11:26:30 +0800620 };
621
622 pxp: pxp@020f0000 {
623 reg = <0x020f0000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700624 interrupts = <0 98 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800625 };
626
627 epdc: epdc@020f4000 {
628 reg = <0x020f4000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700629 interrupts = <0 97 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800630 };
631
632 lcdif: lcdif@020f8000 {
633 reg = <0x020f8000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700634 interrupts = <0 39 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800635 };
636
637 dcp: dcp@020fc000 {
638 reg = <0x020fc000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700639 interrupts = <0 99 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800640 };
641 };
642
643 aips2: aips-bus@02100000 {
644 compatible = "fsl,aips-bus", "simple-bus";
645 #address-cells = <1>;
646 #size-cells = <1>;
647 reg = <0x02100000 0x100000>;
648 ranges;
649
650 usbotg1: usb@02184000 {
651 compatible = "fsl,imx6sl-usb", "fsl,imx27-usb";
652 reg = <0x02184000 0x200>;
Troy Kisky13088c22013-11-14 14:02:12 -0700653 interrupts = <0 43 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800654 clocks = <&clks IMX6SL_CLK_USBOH3>;
655 fsl,usbphy = <&usbphy1>;
656 fsl,usbmisc = <&usbmisc 0>;
657 status = "disabled";
658 };
659
660 usbotg2: usb@02184200 {
661 compatible = "fsl,imx6sl-usb", "fsl,imx27-usb";
662 reg = <0x02184200 0x200>;
Troy Kisky13088c22013-11-14 14:02:12 -0700663 interrupts = <0 42 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800664 clocks = <&clks IMX6SL_CLK_USBOH3>;
665 fsl,usbphy = <&usbphy2>;
666 fsl,usbmisc = <&usbmisc 1>;
667 status = "disabled";
668 };
669
670 usbh: usb@02184400 {
671 compatible = "fsl,imx6sl-usb", "fsl,imx27-usb";
672 reg = <0x02184400 0x200>;
Troy Kisky13088c22013-11-14 14:02:12 -0700673 interrupts = <0 40 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800674 clocks = <&clks IMX6SL_CLK_USBOH3>;
675 fsl,usbmisc = <&usbmisc 2>;
676 status = "disabled";
677 };
678
679 usbmisc: usbmisc@02184800 {
680 #index-cells = <1>;
681 compatible = "fsl,imx6sl-usbmisc", "fsl,imx6q-usbmisc";
682 reg = <0x02184800 0x200>;
683 clocks = <&clks IMX6SL_CLK_USBOH3>;
684 };
685
686 fec: ethernet@02188000 {
687 compatible = "fsl,imx6sl-fec", "fsl,imx25-fec";
688 reg = <0x02188000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700689 interrupts = <0 114 IRQ_TYPE_LEVEL_HIGH>;
Fugang Duan8c562a12014-05-19 15:46:56 +0800690 clocks = <&clks IMX6SL_CLK_ENET>,
Shawn Guoe29fe212013-05-03 11:26:30 +0800691 <&clks IMX6SL_CLK_ENET_REF>;
692 clock-names = "ipg", "ahb";
693 status = "disabled";
694 };
695
696 usdhc1: usdhc@02190000 {
697 compatible = "fsl,imx6sl-usdhc", "fsl,imx6q-usdhc";
698 reg = <0x02190000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700699 interrupts = <0 22 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800700 clocks = <&clks IMX6SL_CLK_USDHC1>,
701 <&clks IMX6SL_CLK_USDHC1>,
702 <&clks IMX6SL_CLK_USDHC1>;
703 clock-names = "ipg", "ahb", "per";
704 bus-width = <4>;
705 status = "disabled";
706 };
707
708 usdhc2: usdhc@02194000 {
709 compatible = "fsl,imx6sl-usdhc", "fsl,imx6q-usdhc";
710 reg = <0x02194000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700711 interrupts = <0 23 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800712 clocks = <&clks IMX6SL_CLK_USDHC2>,
713 <&clks IMX6SL_CLK_USDHC2>,
714 <&clks IMX6SL_CLK_USDHC2>;
715 clock-names = "ipg", "ahb", "per";
716 bus-width = <4>;
717 status = "disabled";
718 };
719
720 usdhc3: usdhc@02198000 {
721 compatible = "fsl,imx6sl-usdhc", "fsl,imx6q-usdhc";
722 reg = <0x02198000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700723 interrupts = <0 24 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800724 clocks = <&clks IMX6SL_CLK_USDHC3>,
725 <&clks IMX6SL_CLK_USDHC3>,
726 <&clks IMX6SL_CLK_USDHC3>;
727 clock-names = "ipg", "ahb", "per";
728 bus-width = <4>;
729 status = "disabled";
730 };
731
732 usdhc4: usdhc@0219c000 {
733 compatible = "fsl,imx6sl-usdhc", "fsl,imx6q-usdhc";
734 reg = <0x0219c000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700735 interrupts = <0 25 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800736 clocks = <&clks IMX6SL_CLK_USDHC4>,
737 <&clks IMX6SL_CLK_USDHC4>,
738 <&clks IMX6SL_CLK_USDHC4>;
739 clock-names = "ipg", "ahb", "per";
740 bus-width = <4>;
741 status = "disabled";
742 };
743
744 i2c1: i2c@021a0000 {
745 #address-cells = <1>;
746 #size-cells = <0>;
747 compatible = "fsl,imx6sl-i2c", "fsl,imx21-i2c";
748 reg = <0x021a0000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700749 interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800750 clocks = <&clks IMX6SL_CLK_I2C1>;
751 status = "disabled";
752 };
753
754 i2c2: i2c@021a4000 {
755 #address-cells = <1>;
756 #size-cells = <0>;
757 compatible = "fsl,imx6sl-i2c", "fsl,imx21-i2c";
758 reg = <0x021a4000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700759 interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800760 clocks = <&clks IMX6SL_CLK_I2C2>;
761 status = "disabled";
762 };
763
764 i2c3: i2c@021a8000 {
765 #address-cells = <1>;
766 #size-cells = <0>;
767 compatible = "fsl,imx6sl-i2c", "fsl,imx21-i2c";
768 reg = <0x021a8000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700769 interrupts = <0 38 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800770 clocks = <&clks IMX6SL_CLK_I2C3>;
771 status = "disabled";
772 };
773
774 mmdc: mmdc@021b0000 {
775 compatible = "fsl,imx6sl-mmdc", "fsl,imx6q-mmdc";
776 reg = <0x021b0000 0x4000>;
777 };
778
779 rngb: rngb@021b4000 {
780 reg = <0x021b4000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700781 interrupts = <0 5 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800782 };
783
784 weim: weim@021b8000 {
785 reg = <0x021b8000 0x4000>;
Troy Kisky13088c22013-11-14 14:02:12 -0700786 interrupts = <0 14 IRQ_TYPE_LEVEL_HIGH>;
Shawn Guoe29fe212013-05-03 11:26:30 +0800787 };
788
789 ocotp: ocotp@021bc000 {
790 compatible = "fsl,imx6sl-ocotp";
791 reg = <0x021bc000 0x4000>;
792 };
793
794 audmux: audmux@021d8000 {
795 compatible = "fsl,imx6sl-audmux", "fsl,imx31-audmux";
796 reg = <0x021d8000 0x4000>;
797 status = "disabled";
798 };
799 };
800 };
801};