xref: /openbmc/u-boot/arch/arm/dts/ls1021a.dtsi (revision 88dc4099)
1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Freescale ls1021a SOC common device tree source
4 *
5 * Copyright 2013-2015 Freescale Semiconductor, Inc.
6 */
7
8#include "skeleton.dtsi"
9#include <dt-bindings/interrupt-controller/arm-gic.h>
10
11/ {
12	compatible = "fsl,ls1021a";
13	interrupt-parent = <&gic>;
14
15	aliases {
16		serial0 = &lpuart0;
17		serial1 = &lpuart1;
18		serial2 = &lpuart2;
19		serial3 = &lpuart3;
20		serial4 = &lpuart4;
21		serial5 = &lpuart5;
22		sysclk = &sysclk;
23	};
24
25	cpus {
26		#address-cells = <1>;
27		#size-cells = <0>;
28
29		cpu@f00 {
30			compatible = "arm,cortex-a7";
31			device_type = "cpu";
32			reg = <0xf00>;
33			clocks = <&cluster1_clk>;
34		};
35
36		cpu@f01 {
37			compatible = "arm,cortex-a7";
38			device_type = "cpu";
39			reg = <0xf01>;
40			clocks = <&cluster1_clk>;
41		};
42	};
43
44	timer {
45		compatible = "arm,armv7-timer";
46		interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
47			     <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
48			     <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
49			     <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>;
50	};
51
52	pmu {
53		compatible = "arm,cortex-a7-pmu";
54		interrupts = <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>,
55			     <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
56	};
57
58	soc {
59		compatible = "simple-bus";
60		#address-cells = <1>;
61		#size-cells = <1>;
62		device_type = "soc";
63		interrupt-parent = <&gic>;
64		ranges;
65
66		gic: interrupt-controller@1400000 {
67			compatible = "arm,cortex-a7-gic";
68			#interrupt-cells = <3>;
69			interrupt-controller;
70			reg = <0x1401000 0x1000>,
71			      <0x1402000 0x1000>,
72			      <0x1404000 0x2000>,
73			      <0x1406000 0x2000>;
74			interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_HIGH)>;
75
76		};
77
78		ifc: ifc@1530000 {
79			compatible = "fsl,ifc", "simple-bus";
80			reg = <0x1530000 0x10000>;
81			interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
82		};
83
84		dcfg: dcfg@1ee0000 {
85			compatible = "fsl,ls1021a-dcfg", "syscon";
86			reg = <0x1ee0000 0x10000>;
87			big-endian;
88		};
89
90		esdhc: esdhc@1560000 {
91			compatible = "fsl,esdhc";
92			reg = <0x1560000 0x10000>;
93			interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>;
94			clock-frequency = <0>;
95			voltage-ranges = <1800 1800 3300 3300>;
96			sdhci,auto-cmd12;
97			big-endian;
98			bus-width = <4>;
99			status = "disabled";
100		};
101
102		scfg: scfg@1570000 {
103			compatible = "fsl,ls1021a-scfg", "syscon";
104			reg = <0x1570000 0x10000>;
105			big-endian;
106		};
107
108		clockgen: clocking@1ee1000 {
109			#address-cells = <1>;
110			#size-cells = <1>;
111			ranges = <0x0 0x1ee1000 0x10000>;
112
113			sysclk: sysclk {
114				compatible = "fixed-clock";
115				#clock-cells = <0>;
116				clock-output-names = "sysclk";
117			};
118
119			cga_pll1: pll@800 {
120				compatible = "fsl,qoriq-core-pll-2.0";
121				#clock-cells = <1>;
122				reg = <0x800 0x10>;
123				clocks = <&sysclk>;
124				clock-output-names = "cga-pll1", "cga-pll1-div2",
125						     "cga-pll1-div4";
126			};
127
128			platform_clk: pll@c00 {
129				compatible = "fsl,qoriq-core-pll-2.0";
130				#clock-cells = <1>;
131				reg = <0xc00 0x10>;
132				clocks = <&sysclk>;
133				clock-output-names = "platform-clk", "platform-clk-div2";
134			};
135
136			cluster1_clk: clk0c0@0 {
137				compatible = "fsl,qoriq-core-mux-2.0";
138				#clock-cells = <0>;
139				reg = <0x0 0x10>;
140				clock-names = "pll1cga", "pll1cga-div2", "pll1cga-div4";
141				clocks = <&cga_pll1 0>, <&cga_pll1 1>, <&cga_pll1 2>;
142				clock-output-names = "cluster1-clk";
143			};
144		};
145
146		dspi0: dspi@2100000 {
147			compatible = "fsl,vf610-dspi";
148			#address-cells = <1>;
149			#size-cells = <0>;
150			reg = <0x2100000 0x10000>;
151			interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
152			clock-names = "dspi";
153			clocks = <&platform_clk 1>;
154			num-cs = <6>;
155			big-endian;
156			status = "disabled";
157		};
158
159		dspi1: dspi@2110000 {
160			compatible = "fsl,vf610-dspi";
161			#address-cells = <1>;
162			#size-cells = <0>;
163			reg = <0x2110000 0x10000>;
164			interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
165			clock-names = "dspi";
166			clocks = <&platform_clk 1>;
167			num-cs = <6>;
168			big-endian;
169			status = "disabled";
170		};
171
172		qspi: quadspi@1550000 {
173			compatible = "fsl,vf610-qspi";
174			#address-cells = <1>;
175			#size-cells = <0>;
176			reg = <0x1550000 0x10000>,
177				<0x40000000 0x4000000>;
178			reg-names = "QuadSPI", "QuadSPI-memory";
179			num-cs = <2>;
180			big-endian;
181			status = "disabled";
182		};
183
184		i2c0: i2c@2180000 {
185			compatible = "fsl,vf610-i2c";
186			#address-cells = <1>;
187			#size-cells = <0>;
188			reg = <0x2180000 0x10000>;
189			interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>;
190			clock-names = "i2c";
191			clocks = <&platform_clk 1>;
192			status = "disabled";
193		};
194
195		i2c1: i2c@2190000 {
196			compatible = "fsl,vf610-i2c";
197			#address-cells = <1>;
198			#size-cells = <0>;
199			reg = <0x2190000 0x10000>;
200			interrupts = <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>;
201			clock-names = "i2c";
202			clocks = <&platform_clk 1>;
203			status = "disabled";
204		};
205
206		i2c2: i2c@21a0000 {
207			compatible = "fsl,vf610-i2c";
208			#address-cells = <1>;
209			#size-cells = <0>;
210			reg = <0x21a0000 0x10000>;
211			interrupts = <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
212			clock-names = "i2c";
213			clocks = <&platform_clk 1>;
214			status = "disabled";
215		};
216
217		uart0: serial@21c0500 {
218			compatible = "fsl,16550-FIFO64", "ns16550a";
219			reg = <0x21c0500 0x100>;
220			interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
221			fifo-size = <15>;
222			status = "disabled";
223		};
224
225		uart1: serial@21c0600 {
226			compatible = "fsl,16550-FIFO64", "ns16550a";
227			reg = <0x21c0600 0x100>;
228			interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
229			fifo-size = <15>;
230			status = "disabled";
231		};
232
233		uart2: serial@21d0500 {
234			compatible = "fsl,16550-FIFO64", "ns16550a";
235			reg = <0x21d0500 0x100>;
236			interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
237			fifo-size = <15>;
238			status = "disabled";
239		};
240
241		uart3: serial@21d0600 {
242			compatible = "fsl,16550-FIFO64", "ns16550a";
243			reg = <0x21d0600 0x100>;
244			interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
245			fifo-size = <15>;
246			status = "disabled";
247		};
248
249		lpuart0: serial@2950000 {
250			compatible = "fsl,ls1021a-lpuart";
251			reg = <0x2950000 0x1000>;
252			interrupts = <GIC_SPI 80 IRQ_TYPE_LEVEL_HIGH>;
253			clocks = <&sysclk>;
254			clock-names = "ipg";
255			status = "disabled";
256		};
257
258		lpuart1: serial@2960000 {
259			compatible = "fsl,ls1021a-lpuart";
260			reg = <0x2960000 0x1000>;
261			interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
262			clocks = <&platform_clk 1>;
263			clock-names = "ipg";
264			status = "disabled";
265		};
266
267		lpuart2: serial@2970000 {
268			compatible = "fsl,ls1021a-lpuart";
269			reg = <0x2970000 0x1000>;
270			interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>;
271			clocks = <&platform_clk 1>;
272			clock-names = "ipg";
273			status = "disabled";
274		};
275
276		lpuart3: serial@2980000 {
277			compatible = "fsl,ls1021a-lpuart";
278			reg = <0x2980000 0x1000>;
279			interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
280			clocks = <&platform_clk 1>;
281			clock-names = "ipg";
282			status = "disabled";
283		};
284
285		lpuart4: serial@2990000 {
286			compatible = "fsl,ls1021a-lpuart";
287			reg = <0x2990000 0x1000>;
288			interrupts = <GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
289			clocks = <&platform_clk 1>;
290			clock-names = "ipg";
291			status = "disabled";
292		};
293
294		lpuart5: serial@29a0000 {
295			compatible = "fsl,ls1021a-lpuart";
296			reg = <0x29a0000 0x1000>;
297			interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
298			clocks = <&platform_clk 1>;
299			clock-names = "ipg";
300			status = "disabled";
301		};
302
303		wdog0: watchdog@2ad0000 {
304			compatible = "fsl,imx21-wdt";
305			reg = <0x2ad0000 0x10000>;
306			interrupts = <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>;
307			clocks = <&platform_clk 1>;
308			clock-names = "wdog-en";
309			big-endian;
310		};
311
312		sai1: sai@2b50000 {
313			compatible = "fsl,vf610-sai";
314			reg = <0x2b50000 0x10000>;
315			interrupts = <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>;
316			clocks = <&platform_clk 1>;
317			clock-names = "sai";
318			dma-names = "tx", "rx";
319			dmas = <&edma0 1 47>,
320			       <&edma0 1 46>;
321			big-endian;
322			status = "disabled";
323		};
324
325		sai2: sai@2b60000 {
326			compatible = "fsl,vf610-sai";
327			reg = <0x2b60000 0x10000>;
328			interrupts = <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>;
329			clocks = <&platform_clk 1>;
330			clock-names = "sai";
331			dma-names = "tx", "rx";
332			dmas = <&edma0 1 45>,
333			       <&edma0 1 44>;
334			big-endian;
335			status = "disabled";
336		};
337
338		edma0: edma@2c00000 {
339			#dma-cells = <2>;
340			compatible = "fsl,vf610-edma";
341			reg = <0x2c00000 0x10000>,
342			      <0x2c10000 0x10000>,
343			      <0x2c20000 0x10000>;
344			interrupts = <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
345				     <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>;
346			interrupt-names = "edma-tx", "edma-err";
347			dma-channels = <32>;
348			big-endian;
349			clock-names = "dmamux0", "dmamux1";
350			clocks = <&platform_clk 1>,
351				 <&platform_clk 1>;
352		};
353
354		mdio0: mdio@2d24000 {
355			compatible = "gianfar";
356			device_type = "mdio";
357			#address-cells = <1>;
358			#size-cells = <0>;
359			reg = <0x2d24000 0x4000>;
360		};
361
362		usb@8600000 {
363			compatible = "fsl-usb2-dr-v2.5", "fsl-usb2-dr";
364			reg = <0x8600000 0x1000>;
365			interrupts = <GIC_SPI 171 IRQ_TYPE_LEVEL_HIGH>;
366			dr_mode = "host";
367			phy_type = "ulpi";
368		};
369
370		usb3@3100000 {
371			compatible = "fsl,layerscape-dwc3";
372			reg = <0x3100000 0x10000>;
373			interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
374			dr_mode = "host";
375		};
376
377		pcie@3400000 {
378			compatible = "fsl,ls-pcie", "snps,dw-pcie";
379			reg = <0x03400000 0x20000   /* dbi registers */
380			       0x01570000 0x10000   /* pf controls registers */
381			       0x24000000 0x20000>; /* configuration space */
382			reg-names = "dbi", "ctrl", "config";
383			big-endian;
384			#address-cells = <3>;
385			#size-cells = <2>;
386			device_type = "pci";
387			bus-range = <0x0 0xff>;
388			ranges = <0x81000000 0x0 0x00000000 0x24020000 0x0 0x00010000   /* downstream I/O */
389				  0x82000000 0x0 0x28000000 0x28000000 0x0 0x08000000>; /* non-prefetchable memory */
390		};
391
392		pcie@3500000 {
393			compatible = "fsl,ls-pcie", "snps,dw-pcie";
394			reg = <0x03500000 0x10000    /* dbi registers */
395			       0x01570000 0x10000    /* pf controls registers */
396			       0x34000000 0x20000>;  /* configuration space */
397			reg-names = "dbi", "ctrl", "config";
398			big-endian;
399			#address-cells = <3>;
400			#size-cells = <2>;
401			device_type = "pci";
402			num-lanes = <2>;
403			bus-range = <0x0 0xff>;
404			ranges = <0x81000000 0x0 0x00000000 0x34020000 0x0 0x00010000   /* downstream I/O */
405				  0x82000000 0x0 0x38000000 0x38000000 0x0 0x08000000>; /* non-prefetchable memory */
406		};
407	};
408};
409