1 // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
3 * Device Tree Include file for NXP Layerscape-1088A family SoC.
7 * Harninder Rai <harninder.rai@nxp.com>
10 #include <dt-bindings/interrupt-controller/arm-gic.h>
11 #include <dt-bindings/thermal/thermal.h>
14 compatible = "fsl,ls1088a";
15 interrupt-parent = <&gic>;
27 /* We have 2 clusters having 4 Cortex-A53 cores each */
30 compatible = "arm,cortex-a53";
32 clocks = <&clockgen 1 0>;
33 cpu-idle-states = <&CPU_PH20>;
39 compatible = "arm,cortex-a53";
41 clocks = <&clockgen 1 0>;
42 cpu-idle-states = <&CPU_PH20>;
48 compatible = "arm,cortex-a53";
50 clocks = <&clockgen 1 0>;
51 cpu-idle-states = <&CPU_PH20>;
57 compatible = "arm,cortex-a53";
59 clocks = <&clockgen 1 0>;
60 cpu-idle-states = <&CPU_PH20>;
66 compatible = "arm,cortex-a53";
68 clocks = <&clockgen 1 1>;
69 cpu-idle-states = <&CPU_PH20>;
75 compatible = "arm,cortex-a53";
77 clocks = <&clockgen 1 1>;
78 cpu-idle-states = <&CPU_PH20>;
84 compatible = "arm,cortex-a53";
86 clocks = <&clockgen 1 1>;
87 cpu-idle-states = <&CPU_PH20>;
93 compatible = "arm,cortex-a53";
95 clocks = <&clockgen 1 1>;
96 cpu-idle-states = <&CPU_PH20>;
101 compatible = "arm,idle-state";
102 idle-state-name = "PH20";
103 arm,psci-suspend-param = <0x0>;
104 entry-latency-us = <1000>;
105 exit-latency-us = <1000>;
106 min-residency-us = <3000>;
110 gic: interrupt-controller@6000000 {
111 compatible = "arm,gic-v3";
112 #interrupt-cells = <3>;
113 interrupt-controller;
114 reg = <0x0 0x06000000 0 0x10000>, /* GIC Dist */
115 <0x0 0x06100000 0 0x100000>, /* GICR(RD_base+SGI_base)*/
116 <0x0 0x0c0c0000 0 0x2000>, /* GICC */
117 <0x0 0x0c0d0000 0 0x1000>, /* GICH */
118 <0x0 0x0c0e0000 0 0x20000>; /* GICV */
119 interrupts = <1 9 IRQ_TYPE_LEVEL_HIGH>;
120 #address-cells = <2>;
124 its: gic-its@6020000 {
125 compatible = "arm,gic-v3-its";
127 reg = <0x0 0x6020000 0 0x20000>;
132 cpu_thermal: cpu-thermal {
133 polling-delay-passive = <1000>;
134 polling-delay = <5000>;
135 thermal-sensors = <&tmu 0>;
138 cpu_alert: cpu-alert {
139 temperature = <85000>;
145 temperature = <95000>;
155 <&cpu0 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
156 <&cpu1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
157 <&cpu2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
158 <&cpu3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
159 <&cpu4 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
160 <&cpu5 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
161 <&cpu6 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
162 <&cpu7 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
169 compatible = "arm,armv8-timer";
170 interrupts = <1 13 IRQ_TYPE_LEVEL_LOW>,/* Physical Secure PPI */
171 <1 14 IRQ_TYPE_LEVEL_LOW>,/* Physical Non-Secure PPI */
172 <1 11 IRQ_TYPE_LEVEL_LOW>,/* Virtual PPI */
173 <1 10 IRQ_TYPE_LEVEL_LOW>;/* Hypervisor PPI */
177 compatible = "arm,psci-0.2";
182 compatible = "fixed-clock";
184 clock-frequency = <100000000>;
185 clock-output-names = "sysclk";
189 compatible = "simple-bus";
190 #address-cells = <2>;
193 dma-ranges = <0x0 0x0 0x0 0x0 0x10000 0x00000000>;
195 clockgen: clocking@1300000 {
196 compatible = "fsl,ls1088a-clockgen";
197 reg = <0 0x1300000 0 0xa0000>;
203 compatible = "fsl,ls1088a-dcfg", "syscon";
204 reg = <0x0 0x1e00000 0x0 0x10000>;
209 compatible = "fsl,qoriq-tmu";
210 reg = <0x0 0x1f80000 0x0 0x10000>;
211 interrupts = <0 23 0x4>;
212 fsl,tmu-range = <0xb0000 0x9002a 0x6004c 0x30062>;
213 fsl,tmu-calibration =
214 /* Calibration data group 1 */
215 <0x00000000 0x00000026
216 0x00000001 0x0000002d
217 0x00000002 0x00000032
218 0x00000003 0x00000039
219 0x00000004 0x0000003f
220 0x00000005 0x00000046
221 0x00000006 0x0000004d
222 0x00000007 0x00000054
223 0x00000008 0x0000005a
224 0x00000009 0x00000061
225 0x0000000a 0x0000006a
226 0x0000000b 0x00000071
227 /* Calibration data group 2 */
228 0x00010000 0x00000025
229 0x00010001 0x0000002c
230 0x00010002 0x00000035
231 0x00010003 0x0000003d
232 0x00010004 0x00000045
233 0x00010005 0x0000004e
234 0x00010006 0x00000057
235 0x00010007 0x00000061
236 0x00010008 0x0000006b
237 0x00010009 0x00000076
238 /* Calibration data group 3 */
239 0x00020000 0x00000029
240 0x00020001 0x00000033
241 0x00020002 0x0000003d
242 0x00020003 0x00000049
243 0x00020004 0x00000056
244 0x00020005 0x00000061
245 0x00020006 0x0000006d
246 /* Calibration data group 4 */
247 0x00030000 0x00000021
248 0x00030001 0x0000002a
249 0x00030002 0x0000003c
250 0x00030003 0x0000004e>;
252 #thermal-sensor-cells = <1>;
255 duart0: serial@21c0500 {
256 compatible = "fsl,ns16550", "ns16550a";
257 reg = <0x0 0x21c0500 0x0 0x100>;
258 clocks = <&clockgen 4 3>;
259 interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>;
263 duart1: serial@21c0600 {
264 compatible = "fsl,ns16550", "ns16550a";
265 reg = <0x0 0x21c0600 0x0 0x100>;
266 clocks = <&clockgen 4 3>;
267 interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>;
271 gpio0: gpio@2300000 {
272 compatible = "fsl,qoriq-gpio";
273 reg = <0x0 0x2300000 0x0 0x10000>;
274 interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>;
277 interrupt-controller;
278 #interrupt-cells = <2>;
281 gpio1: gpio@2310000 {
282 compatible = "fsl,qoriq-gpio";
283 reg = <0x0 0x2310000 0x0 0x10000>;
284 interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>;
287 interrupt-controller;
288 #interrupt-cells = <2>;
291 gpio2: gpio@2320000 {
292 compatible = "fsl,qoriq-gpio";
293 reg = <0x0 0x2320000 0x0 0x10000>;
294 interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>;
297 interrupt-controller;
298 #interrupt-cells = <2>;
301 gpio3: gpio@2330000 {
302 compatible = "fsl,qoriq-gpio";
303 reg = <0x0 0x2330000 0x0 0x10000>;
304 interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>;
307 interrupt-controller;
308 #interrupt-cells = <2>;
312 compatible = "fsl,ifc", "simple-bus";
313 reg = <0x0 0x2240000 0x0 0x20000>;
314 interrupts = <0 21 IRQ_TYPE_LEVEL_HIGH>;
316 #address-cells = <2>;
322 compatible = "fsl,vf610-i2c";
323 #address-cells = <1>;
325 reg = <0x0 0x2000000 0x0 0x10000>;
326 interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>;
327 clocks = <&clockgen 4 3>;
332 compatible = "fsl,vf610-i2c";
333 #address-cells = <1>;
335 reg = <0x0 0x2010000 0x0 0x10000>;
336 interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>;
337 clocks = <&clockgen 4 3>;
342 compatible = "fsl,vf610-i2c";
343 #address-cells = <1>;
345 reg = <0x0 0x2020000 0x0 0x10000>;
346 interrupts = <0 35 IRQ_TYPE_LEVEL_HIGH>;
347 clocks = <&clockgen 4 3>;
352 compatible = "fsl,vf610-i2c";
353 #address-cells = <1>;
355 reg = <0x0 0x2030000 0x0 0x10000>;
356 interrupts = <0 35 IRQ_TYPE_LEVEL_HIGH>;
357 clocks = <&clockgen 4 3>;
361 esdhc: esdhc@2140000 {
362 compatible = "fsl,ls1088a-esdhc", "fsl,esdhc";
363 reg = <0x0 0x2140000 0x0 0x10000>;
364 interrupts = <0 28 0x4>; /* Level high type */
365 clock-frequency = <0>;
366 voltage-ranges = <1800 1800 3300 3300>;
374 compatible = "snps,dwc3";
375 reg = <0x0 0x3100000 0x0 0x10000>;
376 interrupts = <0 80 IRQ_TYPE_LEVEL_HIGH>;
378 snps,quirk-frame-length-adjustment = <0x20>;
379 snps,dis_rxdet_inp3_quirk;
384 compatible = "snps,dwc3";
385 reg = <0x0 0x3110000 0x0 0x10000>;
386 interrupts = <0 81 IRQ_TYPE_LEVEL_HIGH>;
388 snps,quirk-frame-length-adjustment = <0x20>;
389 snps,dis_rxdet_inp3_quirk;
394 compatible = "fsl,ls1088a-ahci";
395 reg = <0x0 0x3200000 0x0 0x10000>,
396 <0x7 0x100520 0x0 0x4>;
397 reg-names = "ahci", "sata-ecc";
398 interrupts = <0 133 IRQ_TYPE_LEVEL_HIGH>;
399 clocks = <&clockgen 4 3>;
404 crypto: crypto@8000000 {
405 compatible = "fsl,sec-v5.0", "fsl,sec-v4.0";
407 #address-cells = <1>;
409 ranges = <0x0 0x00 0x8000000 0x100000>;
410 reg = <0x00 0x8000000 0x0 0x100000>;
411 interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
415 compatible = "fsl,sec-v5.0-job-ring",
416 "fsl,sec-v4.0-job-ring";
417 reg = <0x10000 0x10000>;
418 interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>;
422 compatible = "fsl,sec-v5.0-job-ring",
423 "fsl,sec-v4.0-job-ring";
424 reg = <0x20000 0x10000>;
425 interrupts = <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>;
429 compatible = "fsl,sec-v5.0-job-ring",
430 "fsl,sec-v4.0-job-ring";
431 reg = <0x30000 0x10000>;
432 interrupts = <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>;
436 compatible = "fsl,sec-v5.0-job-ring",
437 "fsl,sec-v4.0-job-ring";
438 reg = <0x40000 0x10000>;
439 interrupts = <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
444 compatible = "fsl,ls1088a-pcie";
445 reg = <0x00 0x03400000 0x0 0x00100000 /* controller registers */
446 0x20 0x00000000 0x0 0x00002000>; /* configuration space */
447 reg-names = "regs", "config";
448 interrupts = <0 108 IRQ_TYPE_LEVEL_HIGH>; /* aer interrupt */
449 interrupt-names = "aer";
450 #address-cells = <3>;
455 bus-range = <0x0 0xff>;
456 ranges = <0x81000000 0x0 0x00000000 0x20 0x00010000 0x0 0x00010000 /* downstream I/O */
457 0x82000000 0x0 0x40000000 0x20 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
459 #interrupt-cells = <1>;
460 interrupt-map-mask = <0 0 0 7>;
461 interrupt-map = <0000 0 0 1 &gic 0 0 0 109 IRQ_TYPE_LEVEL_HIGH>,
462 <0000 0 0 2 &gic 0 0 0 110 IRQ_TYPE_LEVEL_HIGH>,
463 <0000 0 0 3 &gic 0 0 0 111 IRQ_TYPE_LEVEL_HIGH>,
464 <0000 0 0 4 &gic 0 0 0 112 IRQ_TYPE_LEVEL_HIGH>;
469 compatible = "fsl,ls1088a-pcie";
470 reg = <0x00 0x03500000 0x0 0x00100000 /* controller registers */
471 0x28 0x00000000 0x0 0x00002000>; /* configuration space */
472 reg-names = "regs", "config";
473 interrupts = <0 113 IRQ_TYPE_LEVEL_HIGH>; /* aer interrupt */
474 interrupt-names = "aer";
475 #address-cells = <3>;
480 bus-range = <0x0 0xff>;
481 ranges = <0x81000000 0x0 0x00000000 0x28 0x00010000 0x0 0x00010000 /* downstream I/O */
482 0x82000000 0x0 0x40000000 0x28 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
484 #interrupt-cells = <1>;
485 interrupt-map-mask = <0 0 0 7>;
486 interrupt-map = <0000 0 0 1 &gic 0 0 0 114 IRQ_TYPE_LEVEL_HIGH>,
487 <0000 0 0 2 &gic 0 0 0 115 IRQ_TYPE_LEVEL_HIGH>,
488 <0000 0 0 3 &gic 0 0 0 116 IRQ_TYPE_LEVEL_HIGH>,
489 <0000 0 0 4 &gic 0 0 0 117 IRQ_TYPE_LEVEL_HIGH>;
494 compatible = "fsl,ls1088a-pcie";
495 reg = <0x00 0x03600000 0x0 0x00100000 /* controller registers */
496 0x30 0x00000000 0x0 0x00002000>; /* configuration space */
497 reg-names = "regs", "config";
498 interrupts = <0 118 IRQ_TYPE_LEVEL_HIGH>; /* aer interrupt */
499 interrupt-names = "aer";
500 #address-cells = <3>;
505 bus-range = <0x0 0xff>;
506 ranges = <0x81000000 0x0 0x00000000 0x30 0x00010000 0x0 0x00010000 /* downstream I/O */
507 0x82000000 0x0 0x40000000 0x30 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
509 #interrupt-cells = <1>;
510 interrupt-map-mask = <0 0 0 7>;
511 interrupt-map = <0000 0 0 1 &gic 0 0 0 119 IRQ_TYPE_LEVEL_HIGH>,
512 <0000 0 0 2 &gic 0 0 0 120 IRQ_TYPE_LEVEL_HIGH>,
513 <0000 0 0 3 &gic 0 0 0 121 IRQ_TYPE_LEVEL_HIGH>,
514 <0000 0 0 4 &gic 0 0 0 122 IRQ_TYPE_LEVEL_HIGH>;
518 cluster1_core0_watchdog: wdt@c000000 {
519 compatible = "arm,sp805-wdt", "arm,primecell";
520 reg = <0x0 0xc000000 0x0 0x1000>;
521 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
522 clock-names = "apb_pclk", "wdog_clk";
525 cluster1_core1_watchdog: wdt@c010000 {
526 compatible = "arm,sp805-wdt", "arm,primecell";
527 reg = <0x0 0xc010000 0x0 0x1000>;
528 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
529 clock-names = "apb_pclk", "wdog_clk";
532 cluster1_core2_watchdog: wdt@c020000 {
533 compatible = "arm,sp805-wdt", "arm,primecell";
534 reg = <0x0 0xc020000 0x0 0x1000>;
535 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
536 clock-names = "apb_pclk", "wdog_clk";
539 cluster1_core3_watchdog: wdt@c030000 {
540 compatible = "arm,sp805-wdt", "arm,primecell";
541 reg = <0x0 0xc030000 0x0 0x1000>;
542 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
543 clock-names = "apb_pclk", "wdog_clk";
546 cluster2_core0_watchdog: wdt@c100000 {
547 compatible = "arm,sp805-wdt", "arm,primecell";
548 reg = <0x0 0xc100000 0x0 0x1000>;
549 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
550 clock-names = "apb_pclk", "wdog_clk";
553 cluster2_core1_watchdog: wdt@c110000 {
554 compatible = "arm,sp805-wdt", "arm,primecell";
555 reg = <0x0 0xc110000 0x0 0x1000>;
556 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
557 clock-names = "apb_pclk", "wdog_clk";
560 cluster2_core2_watchdog: wdt@c120000 {
561 compatible = "arm,sp805-wdt", "arm,primecell";
562 reg = <0x0 0xc120000 0x0 0x1000>;
563 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
564 clock-names = "apb_pclk", "wdog_clk";
567 cluster2_core3_watchdog: wdt@c130000 {
568 compatible = "arm,sp805-wdt", "arm,primecell";
569 reg = <0x0 0xc130000 0x0 0x1000>;
570 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
571 clock-names = "apb_pclk", "wdog_clk";
574 fsl_mc: fsl-mc@80c000000 {
575 compatible = "fsl,qoriq-mc";
576 reg = <0x00000008 0x0c000000 0 0x40>, /* MC portal base */
577 <0x00000000 0x08340000 0 0x40000>; /* MC control reg */
579 #address-cells = <3>;
583 * Region type 0x0 - MC portals
584 * Region type 0x1 - QBMAN portals
586 ranges = <0x0 0x0 0x0 0x8 0x0c000000 0x4000000
587 0x1 0x0 0x0 0x8 0x18000000 0x8000000>;
590 #address-cells = <1>;
594 compatible = "fsl,qoriq-mc-dpmac";
599 compatible = "fsl,qoriq-mc-dpmac";
604 compatible = "fsl,qoriq-mc-dpmac";
609 compatible = "fsl,qoriq-mc-dpmac";
614 compatible = "fsl,qoriq-mc-dpmac";
619 compatible = "fsl,qoriq-mc-dpmac";
624 compatible = "fsl,qoriq-mc-dpmac";
629 compatible = "fsl,qoriq-mc-dpmac";
634 compatible = "fsl,qoriq-mc-dpmac";
639 compatible = "fsl,qoriq-mc-dpmac";
648 compatible = "linaro,optee-tz";