1 // SPDX-License-Identifier: GPL-2.0+ OR X11
3 * NXP ls1028a SOC common device tree source
5 * Copyright 2019-2020 NXP
9 #include <dt-bindings/interrupt-controller/arm-gic.h>
12 compatible = "fsl,ls1028a";
13 interrupt-parent = <&gic>;
18 compatible = "fixed-clock";
20 clock-frequency = <100000000>;
21 clock-output-names = "sysclk";
24 gic: interrupt-controller@6000000 {
25 compatible = "arm,gic-v3";
26 reg = <0x0 0x06000000 0 0x10000>, /* GIC Dist */
27 <0x0 0x06040000 0 0x40000>;
28 #interrupt-cells = <3>;
30 interrupts = <GIC_PPI 9 (GIC_CPU_MASK_RAW(0xf) |
35 compatible = "arm,armv8-timer";
36 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(2) |
38 <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(2) |
40 <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(2) |
42 <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(2) |
47 compatible = "fsl,ls-pcie", "fsl,ls1028-pcie", "snps,dw-pcie";
48 reg = <0x00 0x03400000 0x0 0x80000
49 0x00 0x03480000 0x0 0x40000 /* lut registers */
50 0x00 0x034c0000 0x0 0x40000 /* pf controls registers */
51 0x80 0x00000000 0x0 0x20000>; /* configuration space */
52 reg-names = "dbi", "lut", "ctrl", "config";
57 bus-range = <0x0 0xff>;
58 ranges = <0x81000000 0x0 0x00000000 0x80 0x00020000 0x0 0x00010000 /* downstream I/O */
59 0x82000000 0x0 0x40000000 0x80 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
63 compatible = "fsl,ls-pcie", "fsl,ls1028-pcie", "snps,dw-pcie";
64 reg = <0x00 0x03500000 0x0 0x80000
65 0x00 0x03580000 0x0 0x40000 /* lut registers */
66 0x00 0x035c0000 0x0 0x40000 /* pf controls registers */
67 0x88 0x00000000 0x0 0x20000>; /* configuration space */
68 reg-names = "dbi", "lut", "ctrl", "config";
73 bus-range = <0x0 0xff>;
74 ranges = <0x81000000 0x0 0x00000000 0x88 0x00020000 0x0 0x00010000 /* downstream I/O */
75 0x82000000 0x0 0x40000000 0x88 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
79 compatible = "pci-host-ecam-generic";
80 /* ECAM bus 0, HW has more space reserved but not populated */
81 bus-range = <0x0 0x0>;
82 reg = <0x01 0xf0000000 0x0 0x100000>;
86 ranges= <0x82000000 0x0 0x00000000 0x1 0xf8000000 0x0 0x160000>;
88 reg = <0x000000 0 0 0 0>;
92 reg = <0x000100 0 0 0 0>;
96 reg = <0x000200 0 0 0 0>;
98 phy-mode = "internal";
108 reg = <0x000300 0 0 0 0>;
117 mscc_felix: pci@0,5 {
118 reg = <0x000500 0 0 0 0>;
122 #address-cells = <1>;
125 mscc_felix_port0: port@0 {
130 mscc_felix_port1: port@1 {
135 mscc_felix_port2: port@2 {
140 mscc_felix_port3: port@3 {
145 mscc_felix_port4: port@4 {
147 phy-mode = "internal";
156 mscc_felix_port5: port@5 {
158 phy-mode = "internal";
171 reg = <0x000600 0 0 0 0>;
173 phy-mode = "internal";
178 compatible = "fsl,layerscape-dwc3";
179 reg = <0x0 0x3100000 0x0 0x10000>;
180 interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
186 compatible = "fsl,layerscape-dwc3";
187 reg = <0x0 0x3110000 0x0 0x10000>;
188 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
193 gpio0: gpio@2300000 {
194 compatible = "fsl,ls1028a-gpio","fsl,qoriq-gpio";
195 reg = <0x0 0x2300000 0x0 0x10000>;
196 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
199 interrupt-controller;
200 #interrupt-cells = <2>;
204 gpio1: gpio@2310000 {
205 compatible = "fsl,ls1028a-gpio","fsl,qoriq-gpio";
206 reg = <0x0 0x2310000 0x0 0x10000>;
207 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
210 interrupt-controller;
211 #interrupt-cells = <2>;
215 gpio2: gpio@2320000 {
216 compatible = "fsl,ls1028a-gpio","fsl,qoriq-gpio";
217 reg = <0x0 0x2320000 0x0 0x10000>;
218 interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
221 interrupt-controller;
222 #interrupt-cells = <2>;
227 compatible = "fsl,ls1028a-ahci";
228 reg = <0x0 0x3200000 0x0 0x10000 /* ccsr sata base */
229 0x7 0x100520 0x0 0x4>; /* ecc sata addr*/
230 reg-names = "sata-base", "ecc-addr";
231 interrupts = <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>;
235 cluster1_core0_watchdog: wdt@c000000 {
236 compatible = "arm,sp805-wdt";
237 reg = <0x0 0xc000000 0x0 0x1000>;
241 compatible = "simple-bus";
242 #address-cells = <2>;
246 clockgen: clocking@1300000 {
247 compatible = "fsl,ls1028a-clockgen";
248 reg = <0x0 0x1300000 0x0 0xa0000>;
254 compatible = "fsl,vf610-i2c";
255 #address-cells = <1>;
257 reg = <0x0 0x2000000 0x0 0x10000>;
258 interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
260 clocks = <&clockgen 4 0>;
265 compatible = "fsl,vf610-i2c";
266 #address-cells = <1>;
268 reg = <0x0 0x2010000 0x0 0x10000>;
269 interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
271 clocks = <&clockgen 4 0>;
276 compatible = "fsl,vf610-i2c";
277 #address-cells = <1>;
279 reg = <0x0 0x2020000 0x0 0x10000>;
280 interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
282 clocks = <&clockgen 4 0>;
287 compatible = "fsl,vf610-i2c";
288 #address-cells = <1>;
290 reg = <0x0 0x2030000 0x0 0x10000>;
291 interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
293 clocks = <&clockgen 4 0>;
298 compatible = "fsl,vf610-i2c";
299 #address-cells = <1>;
301 reg = <0x0 0x2040000 0x0 0x10000>;
302 interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
304 clocks = <&clockgen 4 0>;
309 compatible = "fsl,vf610-i2c";
310 #address-cells = <1>;
312 reg = <0x0 0x2050000 0x0 0x10000>;
313 interrupts = <GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH>;
315 clocks = <&clockgen 4 0>;
320 compatible = "fsl,vf610-i2c";
321 #address-cells = <1>;
323 reg = <0x0 0x2060000 0x0 0x10000>;
324 interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
326 clocks = <&clockgen 4 0>;
331 compatible = "fsl,vf610-i2c";
332 #address-cells = <1>;
334 reg = <0x0 0x2070000 0x0 0x10000>;
335 interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
337 clocks = <&clockgen 4 0>;
341 fspi: flexspi@20c0000 {
342 compatible = "nxp,lx2160a-fspi";
343 #address-cells = <1>;
345 reg = <0x0 0x20c0000 0x0 0x10000>,
346 <0x0 0x20000000 0x0 0x10000000>;
347 reg-names = "fspi_base", "fspi_mmap";
348 clocks = <&clockgen 4 3>, <&clockgen 4 3>;
349 clock-names = "fspi_en", "fspi";
350 interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
354 dspi0: dspi@2100000 {
355 compatible = "fsl,vf610-dspi";
356 #address-cells = <1>;
358 reg = <0x0 0x2100000 0x0 0x10000>;
359 interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
360 clock-names = "dspi";
361 clocks = <&clockgen 4 0>;
367 dspi1: dspi@2110000 {
368 compatible = "fsl,vf610-dspi";
369 #address-cells = <1>;
371 reg = <0x0 0x2110000 0x0 0x10000>;
372 interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
373 clock-names = "dspi";
374 clocks = <&clockgen 4 0>;
380 dspi2: dspi@2120000 {
381 compatible = "fsl,vf610-dspi";
382 #address-cells = <1>;
384 reg = <0x0 0x2120000 0x0 0x10000>;
385 interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
386 clock-names = "dspi";
387 clocks = <&clockgen 4 0>;
393 esdhc0: esdhc@2140000 {
394 compatible = "fsl,esdhc";
395 reg = <0x0 0x2140000 0x0 0x10000>;
396 interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
402 esdhc1: esdhc@2150000 {
403 compatible = "fsl,esdhc";
404 reg = <0x0 0x2150000 0x0 0x10000>;
405 interrupts = <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
412 serial0: serial@21c0500 {
413 device_type = "serial";
414 compatible = "fsl,ns16550", "ns16550a";
415 reg = <0x0 0x21c0500 0x0 0x100>;
416 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
420 serial1: serial@21c0600 {
421 device_type = "serial";
422 compatible = "fsl,ns16550", "ns16550a";
423 reg = <0x0 0x21c0600 0x0 0x100>;
424 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
428 lpuart0: serial@2260000 {
429 compatible = "fsl,ls1021a-lpuart";
430 reg = <0x0 0x2260000 0x0 0x1000>;
431 interrupts = <0 232 0x4>;
438 lpuart1: serial@2270000 {
439 compatible = "fsl,ls1021a-lpuart";
440 reg = <0x0 0x2270000 0x0 0x1000>;
441 interrupts = <0 233 0x4>;
448 lpuart2: serial@2280000 {
449 compatible = "fsl,ls1021a-lpuart";
450 reg = <0x0 0x2280000 0x0 0x1000>;
451 interrupts = <0 234 0x4>;
458 lpuart3: serial@2290000 {
459 compatible = "fsl,ls1021a-lpuart";
460 reg = <0x0 0x2290000 0x0 0x1000>;
461 interrupts = <0 235 0x4>;
468 lpuart4: serial@22a0000 {
469 compatible = "fsl,ls1021a-lpuart";
470 reg = <0x0 0x22a0000 0x0 0x1000>;
471 interrupts = <0 236 0x4>;
478 lpuart5: serial@22b0000 {
479 compatible = "fsl,ls1021a-lpuart";
480 reg = <0x0 0x22b0000 0x0 0x1000>;
481 interrupts = <0 237 0x4>;