blob: c5edfa9a68a603d1b281a72583b87e888bdafc50 [file] [log] [blame]
Jingchang Lu72392802014-10-31 17:01:08 +08001/*
2 * Copyright 2013-2014 Freescale Semiconductor, Inc.
3 *
4 * This file is dual-licensed: you can use it either under the terms
5 * of the GPL or the X11 license, at your option. Note that this dual
6 * licensing only applies to this file, and not this project as a
7 * whole.
8 *
9 * a) This file is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License as
11 * published by the Free Software Foundation; either version 2 of
12 * the License, or (at your option) any later version.
13 *
14 * This file is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public
20 * License along with this file; if not, write to the Free
21 * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
22 * MA 02110-1301 USA
23 *
24 * Or, alternatively,
25 *
26 * b) Permission is hereby granted, free of charge, to any person
27 * obtaining a copy of this software and associated documentation
28 * files (the "Software"), to deal in the Software without
29 * restriction, including without limitation the rights to use,
30 * copy, modify, merge, publish, distribute, sublicense, and/or
31 * sell copies of the Software, and to permit persons to whom the
32 * Software is furnished to do so, subject to the following
33 * conditions:
34 *
35 * The above copyright notice and this permission notice shall be
36 * included in all copies or substantial portions of the Software.
37 *
38 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
39 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
40 * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
41 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
42 * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
43 * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
44 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
45 * OTHER DEALINGS IN THE SOFTWARE.
46 */
47
48#include "skeleton64.dtsi"
49#include <dt-bindings/interrupt-controller/arm-gic.h>
Hongtao Jia4d9e9cbb2016-10-09 14:47:04 +080050#include <dt-bindings/thermal/thermal.h>
Jingchang Lu72392802014-10-31 17:01:08 +080051
52/ {
53 compatible = "fsl,ls1021a";
54 interrupt-parent = <&gic>;
55
56 aliases {
Horia Geantă816aa612015-08-12 10:42:41 +030057 crypto = &crypto;
Claudiu Manoild69cb5d2015-07-28 17:43:55 +030058 ethernet0 = &enet0;
59 ethernet1 = &enet1;
60 ethernet2 = &enet2;
Jingchang Lu72392802014-10-31 17:01:08 +080061 serial0 = &lpuart0;
62 serial1 = &lpuart1;
63 serial2 = &lpuart2;
64 serial3 = &lpuart3;
65 serial4 = &lpuart4;
66 serial5 = &lpuart5;
67 sysclk = &sysclk;
68 };
69
70 cpus {
71 #address-cells = <1>;
72 #size-cells = <0>;
73
Hongtao Jia4d9e9cbb2016-10-09 14:47:04 +080074 cpu0: cpu@f00 {
Jingchang Lu72392802014-10-31 17:01:08 +080075 compatible = "arm,cortex-a7";
76 device_type = "cpu";
77 reg = <0xf00>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +080078 clocks = <&clockgen 1 0>;
Hongtao Jia4d9e9cbb2016-10-09 14:47:04 +080079 #cooling-cells = <2>;
Jingchang Lu72392802014-10-31 17:01:08 +080080 };
81
Hongtao Jia4d9e9cbb2016-10-09 14:47:04 +080082 cpu1: cpu@f01 {
Jingchang Lu72392802014-10-31 17:01:08 +080083 compatible = "arm,cortex-a7";
84 device_type = "cpu";
85 reg = <0xf01>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +080086 clocks = <&clockgen 1 0>;
Jingchang Lu72392802014-10-31 17:01:08 +080087 };
88 };
89
Yuantian Tangb6f5e702017-06-09 14:25:45 +080090 sysclk: sysclk {
91 compatible = "fixed-clock";
92 #clock-cells = <0>;
93 clock-frequency = <100000000>;
94 clock-output-names = "sysclk";
95 };
96
Jingchang Lu72392802014-10-31 17:01:08 +080097 timer {
98 compatible = "arm,armv7-timer";
99 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
100 <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
101 <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
102 <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>;
103 };
104
105 pmu {
106 compatible = "arm,cortex-a7-pmu";
107 interrupts = <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>,
108 <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
Esben Haabendal67421392017-12-05 09:22:25 +0100109 interrupt-affinity = <&cpu0>, <&cpu1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800110 };
111
Rasmus Villemoes7eaec552017-12-05 09:12:47 +0100112 reboot {
113 compatible = "syscon-reboot";
114 regmap = <&dcfg>;
115 offset = <0xb0>;
116 mask = <0x02>;
117 };
118
Jingchang Lu72392802014-10-31 17:01:08 +0800119 soc {
120 compatible = "simple-bus";
121 #address-cells = <2>;
122 #size-cells = <2>;
123 device_type = "soc";
124 interrupt-parent = <&gic>;
125 ranges;
126
127 gic: interrupt-controller@1400000 {
Marc Zyngier387720c2017-01-18 09:27:28 +0000128 compatible = "arm,gic-400", "arm,cortex-a7-gic";
Jingchang Lu72392802014-10-31 17:01:08 +0800129 #interrupt-cells = <3>;
130 interrupt-controller;
131 reg = <0x0 0x1401000 0x0 0x1000>,
Marc Zyngier387720c2017-01-18 09:27:28 +0000132 <0x0 0x1402000 0x0 0x2000>,
Jingchang Lu72392802014-10-31 17:01:08 +0800133 <0x0 0x1404000 0x0 0x2000>,
134 <0x0 0x1406000 0x0 0x2000>;
135 interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_HIGH)>;
136
137 };
138
Minghuan Lianf4a458f2016-04-06 19:02:07 +0800139 msi1: msi-controller@1570e00 {
Minghuan Lianc9041ea2017-07-05 14:58:56 +0800140 compatible = "fsl,ls1021a-msi";
Minghuan Lianf4a458f2016-04-06 19:02:07 +0800141 reg = <0x0 0x1570e00 0x0 0x8>;
142 msi-controller;
143 interrupts = <GIC_SPI 179 IRQ_TYPE_LEVEL_HIGH>;
144 };
145
146 msi2: msi-controller@1570e08 {
Minghuan Lianc9041ea2017-07-05 14:58:56 +0800147 compatible = "fsl,ls1021a-msi";
Minghuan Lianf4a458f2016-04-06 19:02:07 +0800148 reg = <0x0 0x1570e08 0x0 0x8>;
149 msi-controller;
150 interrupts = <GIC_SPI 180 IRQ_TYPE_LEVEL_HIGH>;
151 };
152
Jingchang Lu72392802014-10-31 17:01:08 +0800153 ifc: ifc@1530000 {
154 compatible = "fsl,ifc", "simple-bus";
155 reg = <0x0 0x1530000 0x0 0x10000>;
156 interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
157 };
158
159 dcfg: dcfg@1ee0000 {
160 compatible = "fsl,ls1021a-dcfg", "syscon";
161 reg = <0x0 0x1ee0000 0x0 0x10000>;
162 big-endian;
163 };
164
SZ Lin85f8ee72017-09-12 14:49:25 +0800165 qspi: quadspi@1550000 {
166 compatible = "fsl,ls1021a-qspi";
167 #address-cells = <1>;
168 #size-cells = <0>;
169 reg = <0x0 0x1550000 0x0 0x10000>,
170 <0x0 0x40000000 0x0 0x40000000>;
171 reg-names = "QuadSPI", "QuadSPI-memory";
172 interrupts = <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>;
173 clock-names = "qspi_en", "qspi";
174 clocks = <&clockgen 4 1>, <&clockgen 4 1>;
175 big-endian;
176 status = "disabled";
177 };
178
Jingchang Lu72392802014-10-31 17:01:08 +0800179 esdhc: esdhc@1560000 {
Rasmus Villemoesd5c7b4d2017-11-16 13:15:26 +0100180 compatible = "fsl,ls1021a-esdhc", "fsl,esdhc";
Jingchang Lu72392802014-10-31 17:01:08 +0800181 reg = <0x0 0x1560000 0x0 0x10000>;
182 interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
183 clock-frequency = <0>;
184 voltage-ranges = <1800 1800 3300 3300>;
185 sdhci,auto-cmd12;
186 big-endian;
187 bus-width = <4>;
188 status = "disabled";
189 };
190
Tang Yuantian318f05e2015-12-15 15:14:14 +0800191 sata: sata@3200000 {
192 compatible = "fsl,ls1021a-ahci";
193 reg = <0x0 0x3200000 0x0 0x10000>,
194 <0x0 0x20220520 0x0 0x4>;
195 reg-names = "ahci", "sata-ecc";
196 interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800197 clocks = <&clockgen 4 1>;
Tang Yuantian318f05e2015-12-15 15:14:14 +0800198 dma-coherent;
199 status = "disabled";
200 };
201
Jingchang Lu72392802014-10-31 17:01:08 +0800202 scfg: scfg@1570000 {
203 compatible = "fsl,ls1021a-scfg", "syscon";
204 reg = <0x0 0x1570000 0x0 0x10000>;
Xiubo Li4fe6be02014-11-24 17:17:24 +0800205 big-endian;
Jingchang Lu72392802014-10-31 17:01:08 +0800206 };
207
Horia Geantă816aa612015-08-12 10:42:41 +0300208 crypto: crypto@1700000 {
209 compatible = "fsl,sec-v5.0", "fsl,sec-v4.0";
210 fsl,sec-era = <7>;
211 #address-cells = <1>;
212 #size-cells = <1>;
213 reg = <0x0 0x1700000 0x0 0x100000>;
214 ranges = <0x0 0x0 0x1700000 0x100000>;
215 interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
216
217 sec_jr0: jr@10000 {
218 compatible = "fsl,sec-v5.0-job-ring",
219 "fsl,sec-v4.0-job-ring";
220 reg = <0x10000 0x10000>;
221 interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
222 };
223
224 sec_jr1: jr@20000 {
225 compatible = "fsl,sec-v5.0-job-ring",
226 "fsl,sec-v4.0-job-ring";
227 reg = <0x20000 0x10000>;
228 interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>;
229 };
230
231 sec_jr2: jr@30000 {
232 compatible = "fsl,sec-v5.0-job-ring",
233 "fsl,sec-v4.0-job-ring";
234 reg = <0x30000 0x10000>;
235 interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
236 };
237
238 sec_jr3: jr@40000 {
239 compatible = "fsl,sec-v5.0-job-ring",
240 "fsl,sec-v4.0-job-ring";
241 reg = <0x40000 0x10000>;
242 interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
243 };
244
245 };
246
Jingchang Lu72392802014-10-31 17:01:08 +0800247 clockgen: clocking@1ee1000 {
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800248 compatible = "fsl,ls1021a-clockgen";
249 reg = <0x0 0x1ee1000 0x0 0x1000>;
250 #clock-cells = <2>;
251 clocks = <&sysclk>;
Jingchang Lu72392802014-10-31 17:01:08 +0800252 };
253
Hongtao Jia4d9e9cbb2016-10-09 14:47:04 +0800254 tmu: tmu@1f00000 {
255 compatible = "fsl,qoriq-tmu";
256 reg = <0x0 0x1f00000 0x0 0x10000>;
257 interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
258 fsl,tmu-range = <0xb0000 0xa0026 0x80048 0x30061>;
259 fsl,tmu-calibration = <0x00000000 0x0000000f
260 0x00000001 0x00000017
261 0x00000002 0x0000001e
262 0x00000003 0x00000026
263 0x00000004 0x0000002e
264 0x00000005 0x00000035
265 0x00000006 0x0000003d
266 0x00000007 0x00000044
267 0x00000008 0x0000004c
268 0x00000009 0x00000053
269 0x0000000a 0x0000005b
270 0x0000000b 0x00000064
271
272 0x00010000 0x00000011
273 0x00010001 0x0000001c
274 0x00010002 0x00000024
275 0x00010003 0x0000002b
276 0x00010004 0x00000034
277 0x00010005 0x00000039
278 0x00010006 0x00000042
279 0x00010007 0x0000004c
280 0x00010008 0x00000051
281 0x00010009 0x0000005a
282 0x0001000a 0x00000063
283
284 0x00020000 0x00000013
285 0x00020001 0x00000019
286 0x00020002 0x00000024
287 0x00020003 0x0000002c
288 0x00020004 0x00000035
289 0x00020005 0x0000003d
290 0x00020006 0x00000046
291 0x00020007 0x00000050
292 0x00020008 0x00000059
293
294 0x00030000 0x00000002
295 0x00030001 0x0000000d
296 0x00030002 0x00000019
297 0x00030003 0x00000024>;
298 #thermal-sensor-cells = <1>;
299 };
300
301 thermal-zones {
302 cpu_thermal: cpu-thermal {
303 polling-delay-passive = <1000>;
304 polling-delay = <5000>;
305
306 thermal-sensors = <&tmu 0>;
307
308 trips {
309 cpu_alert: cpu-alert {
310 temperature = <85000>;
311 hysteresis = <2000>;
312 type = "passive";
313 };
314 cpu_crit: cpu-crit {
315 temperature = <95000>;
316 hysteresis = <2000>;
317 type = "critical";
318 };
319 };
320
321 cooling-maps {
322 map0 {
323 trip = <&cpu_alert>;
324 cooling-device =
325 <&cpu0 THERMAL_NO_LIMIT
326 THERMAL_NO_LIMIT>;
327 };
328 };
329 };
330 };
331
Jingchang Lu72392802014-10-31 17:01:08 +0800332 dspi0: dspi@2100000 {
Haikun Wangc47d6e382015-07-08 10:43:40 +0800333 compatible = "fsl,ls1021a-v1.0-dspi";
Jingchang Lu72392802014-10-31 17:01:08 +0800334 #address-cells = <1>;
335 #size-cells = <0>;
336 reg = <0x0 0x2100000 0x0 0x10000>;
337 interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
338 clock-names = "dspi";
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800339 clocks = <&clockgen 4 1>;
Alexander Stein5b9f9672016-03-23 10:49:06 +0100340 spi-num-chipselects = <6>;
Jingchang Lu72392802014-10-31 17:01:08 +0800341 big-endian;
342 status = "disabled";
343 };
344
345 dspi1: dspi@2110000 {
Haikun Wangc47d6e382015-07-08 10:43:40 +0800346 compatible = "fsl,ls1021a-v1.0-dspi";
Jingchang Lu72392802014-10-31 17:01:08 +0800347 #address-cells = <1>;
348 #size-cells = <0>;
349 reg = <0x0 0x2110000 0x0 0x10000>;
350 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
351 clock-names = "dspi";
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800352 clocks = <&clockgen 4 1>;
Alexander Stein5b9f9672016-03-23 10:49:06 +0100353 spi-num-chipselects = <6>;
Jingchang Lu72392802014-10-31 17:01:08 +0800354 big-endian;
355 status = "disabled";
356 };
357
358 i2c0: i2c@2180000 {
359 compatible = "fsl,vf610-i2c";
360 #address-cells = <1>;
361 #size-cells = <0>;
362 reg = <0x0 0x2180000 0x0 0x10000>;
363 interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
364 clock-names = "i2c";
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800365 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800366 status = "disabled";
367 };
368
369 i2c1: i2c@2190000 {
370 compatible = "fsl,vf610-i2c";
371 #address-cells = <1>;
372 #size-cells = <0>;
373 reg = <0x0 0x2190000 0x0 0x10000>;
374 interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
375 clock-names = "i2c";
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800376 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800377 status = "disabled";
378 };
379
380 i2c2: i2c@21a0000 {
381 compatible = "fsl,vf610-i2c";
382 #address-cells = <1>;
383 #size-cells = <0>;
384 reg = <0x0 0x21a0000 0x0 0x10000>;
385 interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
386 clock-names = "i2c";
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800387 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800388 status = "disabled";
389 };
390
391 uart0: serial@21c0500 {
392 compatible = "fsl,16550-FIFO64", "ns16550a";
393 reg = <0x0 0x21c0500 0x0 0x100>;
394 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
395 clock-frequency = <0>;
396 fifo-size = <15>;
397 status = "disabled";
398 };
399
400 uart1: serial@21c0600 {
401 compatible = "fsl,16550-FIFO64", "ns16550a";
402 reg = <0x0 0x21c0600 0x0 0x100>;
403 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
404 clock-frequency = <0>;
405 fifo-size = <15>;
406 status = "disabled";
407 };
408
409 uart2: serial@21d0500 {
410 compatible = "fsl,16550-FIFO64", "ns16550a";
411 reg = <0x0 0x21d0500 0x0 0x100>;
412 interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
413 clock-frequency = <0>;
414 fifo-size = <15>;
415 status = "disabled";
416 };
417
418 uart3: serial@21d0600 {
419 compatible = "fsl,16550-FIFO64", "ns16550a";
420 reg = <0x0 0x21d0600 0x0 0x100>;
421 interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
422 clock-frequency = <0>;
423 fifo-size = <15>;
424 status = "disabled";
425 };
426
Liu Gangc54dd442016-03-23 17:47:20 +0800427 gpio0: gpio@2300000 {
428 compatible = "fsl,ls1021a-gpio", "fsl,qoriq-gpio";
429 reg = <0x0 0x2300000 0x0 0x10000>;
430 interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
431 gpio-controller;
432 #gpio-cells = <2>;
433 interrupt-controller;
434 #interrupt-cells = <2>;
435 };
436
437 gpio1: gpio@2310000 {
438 compatible = "fsl,ls1021a-gpio", "fsl,qoriq-gpio";
439 reg = <0x0 0x2310000 0x0 0x10000>;
440 interrupts = <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>;
441 gpio-controller;
442 #gpio-cells = <2>;
443 interrupt-controller;
444 #interrupt-cells = <2>;
445 };
446
447 gpio2: gpio@2320000 {
448 compatible = "fsl,ls1021a-gpio", "fsl,qoriq-gpio";
449 reg = <0x0 0x2320000 0x0 0x10000>;
450 interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
451 gpio-controller;
452 #gpio-cells = <2>;
453 interrupt-controller;
454 #interrupt-cells = <2>;
455 };
456
457 gpio3: gpio@2330000 {
458 compatible = "fsl,ls1021a-gpio", "fsl,qoriq-gpio";
459 reg = <0x0 0x2330000 0x0 0x10000>;
460 interrupts = <GIC_SPI 166 IRQ_TYPE_LEVEL_HIGH>;
461 gpio-controller;
462 #gpio-cells = <2>;
463 interrupt-controller;
464 #interrupt-cells = <2>;
465 };
466
Jingchang Lu72392802014-10-31 17:01:08 +0800467 lpuart0: serial@2950000 {
468 compatible = "fsl,ls1021a-lpuart";
469 reg = <0x0 0x2950000 0x0 0x1000>;
470 interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
471 clocks = <&sysclk>;
472 clock-names = "ipg";
473 status = "disabled";
474 };
475
476 lpuart1: serial@2960000 {
477 compatible = "fsl,ls1021a-lpuart";
478 reg = <0x0 0x2960000 0x0 0x1000>;
479 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800480 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800481 clock-names = "ipg";
482 status = "disabled";
483 };
484
485 lpuart2: serial@2970000 {
486 compatible = "fsl,ls1021a-lpuart";
487 reg = <0x0 0x2970000 0x0 0x1000>;
488 interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800489 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800490 clock-names = "ipg";
491 status = "disabled";
492 };
493
494 lpuart3: serial@2980000 {
495 compatible = "fsl,ls1021a-lpuart";
496 reg = <0x0 0x2980000 0x0 0x1000>;
497 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800498 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800499 clock-names = "ipg";
500 status = "disabled";
501 };
502
503 lpuart4: serial@2990000 {
504 compatible = "fsl,ls1021a-lpuart";
505 reg = <0x0 0x2990000 0x0 0x1000>;
506 interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800507 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800508 clock-names = "ipg";
509 status = "disabled";
510 };
511
512 lpuart5: serial@29a0000 {
513 compatible = "fsl,ls1021a-lpuart";
514 reg = <0x0 0x29a0000 0x0 0x1000>;
515 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800516 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800517 clock-names = "ipg";
518 status = "disabled";
519 };
520
521 wdog0: watchdog@2ad0000 {
522 compatible = "fsl,imx21-wdt";
523 reg = <0x0 0x2ad0000 0x0 0x10000>;
524 interrupts = <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800525 clocks = <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800526 clock-names = "wdog-en";
527 big-endian;
528 };
529
530 sai1: sai@2b50000 {
Alison Wang50897cb2015-07-15 16:02:46 +0800531 #sound-dai-cells = <0>;
Jingchang Lu72392802014-10-31 17:01:08 +0800532 compatible = "fsl,vf610-sai";
533 reg = <0x0 0x2b50000 0x0 0x10000>;
534 interrupts = <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800535 clocks = <&clockgen 4 1>, <&clockgen 4 1>,
536 <&clockgen 4 1>, <&clockgen 4 1>;
Alison Wang50897cb2015-07-15 16:02:46 +0800537 clock-names = "bus", "mclk1", "mclk2", "mclk3";
Jingchang Lu72392802014-10-31 17:01:08 +0800538 dma-names = "tx", "rx";
539 dmas = <&edma0 1 47>,
540 <&edma0 1 46>;
Jingchang Lu72392802014-10-31 17:01:08 +0800541 status = "disabled";
542 };
543
544 sai2: sai@2b60000 {
Alison Wang50897cb2015-07-15 16:02:46 +0800545 #sound-dai-cells = <0>;
Jingchang Lu72392802014-10-31 17:01:08 +0800546 compatible = "fsl,vf610-sai";
547 reg = <0x0 0x2b60000 0x0 0x10000>;
548 interrupts = <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800549 clocks = <&clockgen 4 1>, <&clockgen 4 1>,
550 <&clockgen 4 1>, <&clockgen 4 1>;
Alison Wang50897cb2015-07-15 16:02:46 +0800551 clock-names = "bus", "mclk1", "mclk2", "mclk3";
Jingchang Lu72392802014-10-31 17:01:08 +0800552 dma-names = "tx", "rx";
553 dmas = <&edma0 1 45>,
554 <&edma0 1 44>;
Jingchang Lu72392802014-10-31 17:01:08 +0800555 status = "disabled";
556 };
557
558 edma0: edma@2c00000 {
559 #dma-cells = <2>;
560 compatible = "fsl,vf610-edma";
561 reg = <0x0 0x2c00000 0x0 0x10000>,
562 <0x0 0x2c10000 0x0 0x10000>,
563 <0x0 0x2c20000 0x0 0x10000>;
564 interrupts = <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
565 <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>;
566 interrupt-names = "edma-tx", "edma-err";
567 dma-channels = <32>;
568 big-endian;
569 clock-names = "dmamux0", "dmamux1";
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800570 clocks = <&clockgen 4 1>,
571 <&clockgen 4 1>;
Jingchang Lu72392802014-10-31 17:01:08 +0800572 };
573
Meng Yiab0087d2015-11-25 14:46:06 +0800574 dcu: dcu@2ce0000 {
575 compatible = "fsl,ls1021a-dcu";
576 reg = <0x0 0x2ce0000 0x0 0x10000>;
577 interrupts = <GIC_SPI 172 IRQ_TYPE_LEVEL_HIGH>;
Yuantian Tangb6f5e702017-06-09 14:25:45 +0800578 clocks = <&clockgen 4 0>,
579 <&clockgen 4 0>;
Stefan Agner5d01e992016-04-04 22:28:41 -0700580 clock-names = "dcu", "pix";
Meng Yiab0087d2015-11-25 14:46:06 +0800581 big-endian;
582 status = "disabled";
583 };
584
Jingchang Lu72392802014-10-31 17:01:08 +0800585 mdio0: mdio@2d24000 {
586 compatible = "gianfar";
587 device_type = "mdio";
588 #address-cells = <1>;
589 #size-cells = <0>;
590 reg = <0x0 0x2d24000 0x0 0x4000>;
591 };
592
Yangbo Lu3db66fd2016-02-24 17:26:54 +0800593 ptp_clock@2d10e00 {
594 compatible = "fsl,etsec-ptp";
595 reg = <0x0 0x2d10e00 0x0 0xb0>;
596 interrupts = <GIC_SPI 173 IRQ_TYPE_LEVEL_HIGH>;
597 fsl,tclk-period = <5>;
598 fsl,tmr-prsc = <2>;
599 fsl,tmr-add = <0xaaaaaaab>;
Yangbo Lubdba5012017-11-29 14:54:58 +0800600 fsl,tmr-fiper1 = <999999995>;
Yangbo Lu3db66fd2016-02-24 17:26:54 +0800601 fsl,tmr-fiper2 = <99990>;
602 fsl,max-adj = <499999999>;
603 };
604
Claudiu Manoild69cb5d2015-07-28 17:43:55 +0300605 enet0: ethernet@2d10000 {
606 compatible = "fsl,etsec2";
607 device_type = "network";
608 #address-cells = <2>;
609 #size-cells = <2>;
610 interrupt-parent = <&gic>;
611 model = "eTSEC";
612 fsl,magic-packet;
613 ranges;
Alison Wang70b5ea92015-09-14 14:45:28 +0800614 dma-coherent;
Claudiu Manoild69cb5d2015-07-28 17:43:55 +0300615
616 queue-group@2d10000 {
617 #address-cells = <2>;
618 #size-cells = <2>;
619 reg = <0x0 0x2d10000 0x0 0x1000>;
620 interrupts = <GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH>,
621 <GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH>,
622 <GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>;
623 };
624
625 queue-group@2d14000 {
626 #address-cells = <2>;
627 #size-cells = <2>;
628 reg = <0x0 0x2d14000 0x0 0x1000>;
629 interrupts = <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>,
630 <GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>,
631 <GIC_SPI 149 IRQ_TYPE_LEVEL_HIGH>;
632 };
633 };
634
635 enet1: ethernet@2d50000 {
636 compatible = "fsl,etsec2";
637 device_type = "network";
638 #address-cells = <2>;
639 #size-cells = <2>;
640 interrupt-parent = <&gic>;
641 model = "eTSEC";
642 ranges;
Alison Wang70b5ea92015-09-14 14:45:28 +0800643 dma-coherent;
Claudiu Manoild69cb5d2015-07-28 17:43:55 +0300644
645 queue-group@2d50000 {
646 #address-cells = <2>;
647 #size-cells = <2>;
648 reg = <0x0 0x2d50000 0x0 0x1000>;
649 interrupts = <GIC_SPI 150 IRQ_TYPE_LEVEL_HIGH>,
650 <GIC_SPI 152 IRQ_TYPE_LEVEL_HIGH>,
651 <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>;
652 };
653
654 queue-group@2d54000 {
655 #address-cells = <2>;
656 #size-cells = <2>;
657 reg = <0x0 0x2d54000 0x0 0x1000>;
658 interrupts = <GIC_SPI 154 IRQ_TYPE_LEVEL_HIGH>,
659 <GIC_SPI 155 IRQ_TYPE_LEVEL_HIGH>,
660 <GIC_SPI 156 IRQ_TYPE_LEVEL_HIGH>;
661 };
662 };
663
664 enet2: ethernet@2d90000 {
665 compatible = "fsl,etsec2";
666 device_type = "network";
667 #address-cells = <2>;
668 #size-cells = <2>;
669 interrupt-parent = <&gic>;
670 model = "eTSEC";
671 ranges;
Alison Wang70b5ea92015-09-14 14:45:28 +0800672 dma-coherent;
Claudiu Manoild69cb5d2015-07-28 17:43:55 +0300673
674 queue-group@2d90000 {
675 #address-cells = <2>;
676 #size-cells = <2>;
677 reg = <0x0 0x2d90000 0x0 0x1000>;
678 interrupts = <GIC_SPI 157 IRQ_TYPE_LEVEL_HIGH>,
679 <GIC_SPI 158 IRQ_TYPE_LEVEL_HIGH>,
680 <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>;
681 };
682
683 queue-group@2d94000 {
684 #address-cells = <2>;
685 #size-cells = <2>;
686 reg = <0x0 0x2d94000 0x0 0x1000>;
687 interrupts = <GIC_SPI 160 IRQ_TYPE_LEVEL_HIGH>,
688 <GIC_SPI 161 IRQ_TYPE_LEVEL_HIGH>,
689 <GIC_SPI 162 IRQ_TYPE_LEVEL_HIGH>;
690 };
691 };
692
Esben Haabendal31fa7632017-12-05 09:16:33 +0100693 usb2: usb@8600000 {
Jingchang Lu72392802014-10-31 17:01:08 +0800694 compatible = "fsl-usb2-dr-v2.5", "fsl-usb2-dr";
695 reg = <0x0 0x8600000 0x0 0x1000>;
696 interrupts = <GIC_SPI 171 IRQ_TYPE_LEVEL_HIGH>;
697 dr_mode = "host";
698 phy_type = "ulpi";
699 };
700
Esben Haabendal31fa7632017-12-05 09:16:33 +0100701 usb3: usb3@3100000 {
Jingchang Lu72392802014-10-31 17:01:08 +0800702 compatible = "snps,dwc3";
703 reg = <0x0 0x3100000 0x0 0x10000>;
704 interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
705 dr_mode = "host";
Rajesh Bhagat607e2662015-10-14 11:04:12 +0530706 snps,quirk-frame-length-adjustment = <0x20>;
Rajesh Bhagat6f0808c2016-06-10 11:53:44 +0530707 snps,dis_rxdet_inp3_quirk;
Jingchang Lu72392802014-10-31 17:01:08 +0800708 };
Minghuan Lianbc7abb42016-02-02 16:30:07 +0800709
710 pcie@3400000 {
711 compatible = "fsl,ls1021a-pcie", "snps,dw-pcie";
712 reg = <0x00 0x03400000 0x0 0x00010000 /* controller registers */
713 0x40 0x00000000 0x0 0x00002000>; /* configuration space */
714 reg-names = "regs", "config";
715 interrupts = <GIC_SPI 177 IRQ_TYPE_LEVEL_HIGH>; /* controller interrupt */
716 fsl,pcie-scfg = <&scfg 0>;
717 #address-cells = <3>;
718 #size-cells = <2>;
719 device_type = "pci";
720 num-lanes = <4>;
721 bus-range = <0x0 0xff>;
722 ranges = <0x81000000 0x0 0x00000000 0x40 0x00010000 0x0 0x00010000 /* downstream I/O */
723 0x82000000 0x0 0x40000000 0x40 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
Minghuan Liandf301582017-07-05 14:58:58 +0800724 msi-parent = <&msi1>, <&msi2>;
Minghuan Lianbc7abb42016-02-02 16:30:07 +0800725 #interrupt-cells = <1>;
726 interrupt-map-mask = <0 0 0 7>;
727 interrupt-map = <0000 0 0 1 &gic GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>,
728 <0000 0 0 2 &gic GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>,
729 <0000 0 0 3 &gic GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>,
730 <0000 0 0 4 &gic GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>;
731 };
732
733 pcie@3500000 {
734 compatible = "fsl,ls1021a-pcie", "snps,dw-pcie";
735 reg = <0x00 0x03500000 0x0 0x00010000 /* controller registers */
736 0x48 0x00000000 0x0 0x00002000>; /* configuration space */
737 reg-names = "regs", "config";
738 interrupts = <GIC_SPI 178 IRQ_TYPE_LEVEL_HIGH>;
739 fsl,pcie-scfg = <&scfg 1>;
740 #address-cells = <3>;
741 #size-cells = <2>;
742 device_type = "pci";
743 num-lanes = <4>;
744 bus-range = <0x0 0xff>;
745 ranges = <0x81000000 0x0 0x00000000 0x48 0x00010000 0x0 0x00010000 /* downstream I/O */
746 0x82000000 0x0 0x40000000 0x48 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
Minghuan Liandf301582017-07-05 14:58:58 +0800747 msi-parent = <&msi1>, <&msi2>;
Minghuan Lianbc7abb42016-02-02 16:30:07 +0800748 #interrupt-cells = <1>;
749 interrupt-map-mask = <0 0 0 7>;
750 interrupt-map = <0000 0 0 1 &gic GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>,
751 <0000 0 0 2 &gic GIC_SPI 189 IRQ_TYPE_LEVEL_HIGH>,
752 <0000 0 0 3 &gic GIC_SPI 191 IRQ_TYPE_LEVEL_HIGH>,
753 <0000 0 0 4 &gic GIC_SPI 193 IRQ_TYPE_LEVEL_HIGH>;
754 };
Jingchang Lu72392802014-10-31 17:01:08 +0800755 };
756};