blob: 5b3fc6ad44da2523b7ebdf26e1c5b11ea94a6033 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
haikunddf79f32015-03-25 20:23:26 +08002/*
3 * Freescale ls1021a SOC common device tree source
4 *
5 * Copyright 2013-2015 Freescale Semiconductor, Inc.
haikunddf79f32015-03-25 20:23:26 +08006 */
7
haikunce35fc12015-03-24 21:16:31 +08008#include "skeleton.dtsi"
haikunddf79f32015-03-25 20:23:26 +08009#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";
haikunce35fc12015-03-24 21:16:31 +080060 #address-cells = <1>;
61 #size-cells = <1>;
haikunddf79f32015-03-25 20:23:26 +080062 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;
haikunce35fc12015-03-24 21:16:31 +080070 reg = <0x1401000 0x1000>,
71 <0x1402000 0x1000>,
72 <0x1404000 0x2000>,
73 <0x1406000 0x2000>;
haikunddf79f32015-03-25 20:23:26 +080074 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";
haikunce35fc12015-03-24 21:16:31 +080080 reg = <0x1530000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +080081 interrupts = <GIC_SPI 75 IRQ_TYPE_LEVEL_HIGH>;
82 };
83
84 dcfg: dcfg@1ee0000 {
85 compatible = "fsl,ls1021a-dcfg", "syscon";
haikunce35fc12015-03-24 21:16:31 +080086 reg = <0x1ee0000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +080087 big-endian;
88 };
89
90 esdhc: esdhc@1560000 {
91 compatible = "fsl,esdhc";
haikunce35fc12015-03-24 21:16:31 +080092 reg = <0x1560000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +080093 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";
haikunce35fc12015-03-24 21:16:31 +0800104 reg = <0x1570000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800105 big-endian;
106 };
107
108 clockgen: clocking@1ee1000 {
109 #address-cells = <1>;
110 #size-cells = <1>;
haikunce35fc12015-03-24 21:16:31 +0800111 ranges = <0x0 0x1ee1000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800112
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>;
haikunce35fc12015-03-24 21:16:31 +0800150 reg = <0x2100000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800151 interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
152 clock-names = "dspi";
153 clocks = <&platform_clk 1>;
Haikun.Wang@freescale.com6db79c42015-03-24 21:19:23 +0800154 num-cs = <6>;
haikunddf79f32015-03-25 20:23:26 +0800155 big-endian;
156 status = "disabled";
157 };
158
159 dspi1: dspi@2110000 {
160 compatible = "fsl,vf610-dspi";
161 #address-cells = <1>;
162 #size-cells = <0>;
haikunce35fc12015-03-24 21:16:31 +0800163 reg = <0x2110000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800164 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
165 clock-names = "dspi";
166 clocks = <&platform_clk 1>;
Haikun.Wang@freescale.com6db79c42015-03-24 21:19:23 +0800167 num-cs = <6>;
haikunddf79f32015-03-25 20:23:26 +0800168 big-endian;
169 status = "disabled";
170 };
171
Haikun.Wang@freescale.com863b4e12015-03-24 21:20:40 +0800172 qspi: quadspi@1550000 {
173 compatible = "fsl,vf610-qspi";
174 #address-cells = <1>;
175 #size-cells = <0>;
176 reg = <0x1550000 0x10000>,
177 <0x40000000 0x4000000>;
Yuan Yao93a1b7c2016-11-30 11:26:20 +0800178 reg-names = "QuadSPI", "QuadSPI-memory";
Haikun.Wang@freescale.com863b4e12015-03-24 21:20:40 +0800179 num-cs = <2>;
180 big-endian;
181 status = "disabled";
182 };
183
haikunddf79f32015-03-25 20:23:26 +0800184 i2c0: i2c@2180000 {
185 compatible = "fsl,vf610-i2c";
186 #address-cells = <1>;
187 #size-cells = <0>;
haikunce35fc12015-03-24 21:16:31 +0800188 reg = <0x2180000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800189 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>;
haikunce35fc12015-03-24 21:16:31 +0800199 reg = <0x2190000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800200 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>;
haikunce35fc12015-03-24 21:16:31 +0800210 reg = <0x21a0000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800211 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";
haikunce35fc12015-03-24 21:16:31 +0800219 reg = <0x21c0500 0x100>;
haikunddf79f32015-03-25 20:23:26 +0800220 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
haikunddf79f32015-03-25 20:23:26 +0800221 fifo-size = <15>;
222 status = "disabled";
223 };
224
225 uart1: serial@21c0600 {
226 compatible = "fsl,16550-FIFO64", "ns16550a";
haikunce35fc12015-03-24 21:16:31 +0800227 reg = <0x21c0600 0x100>;
haikunddf79f32015-03-25 20:23:26 +0800228 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
haikunddf79f32015-03-25 20:23:26 +0800229 fifo-size = <15>;
230 status = "disabled";
231 };
232
233 uart2: serial@21d0500 {
234 compatible = "fsl,16550-FIFO64", "ns16550a";
haikunce35fc12015-03-24 21:16:31 +0800235 reg = <0x21d0500 0x100>;
haikunddf79f32015-03-25 20:23:26 +0800236 interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
haikunddf79f32015-03-25 20:23:26 +0800237 fifo-size = <15>;
238 status = "disabled";
239 };
240
241 uart3: serial@21d0600 {
242 compatible = "fsl,16550-FIFO64", "ns16550a";
haikunce35fc12015-03-24 21:16:31 +0800243 reg = <0x21d0600 0x100>;
haikunddf79f32015-03-25 20:23:26 +0800244 interrupts = <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>;
haikunddf79f32015-03-25 20:23:26 +0800245 fifo-size = <15>;
246 status = "disabled";
247 };
248
249 lpuart0: serial@2950000 {
250 compatible = "fsl,ls1021a-lpuart";
haikunce35fc12015-03-24 21:16:31 +0800251 reg = <0x2950000 0x1000>;
haikunddf79f32015-03-25 20:23:26 +0800252 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";
haikunce35fc12015-03-24 21:16:31 +0800260 reg = <0x2960000 0x1000>;
haikunddf79f32015-03-25 20:23:26 +0800261 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";
haikunce35fc12015-03-24 21:16:31 +0800269 reg = <0x2970000 0x1000>;
haikunddf79f32015-03-25 20:23:26 +0800270 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";
haikunce35fc12015-03-24 21:16:31 +0800278 reg = <0x2980000 0x1000>;
haikunddf79f32015-03-25 20:23:26 +0800279 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";
haikunce35fc12015-03-24 21:16:31 +0800287 reg = <0x2990000 0x1000>;
haikunddf79f32015-03-25 20:23:26 +0800288 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";
haikunce35fc12015-03-24 21:16:31 +0800296 reg = <0x29a0000 0x1000>;
haikunddf79f32015-03-25 20:23:26 +0800297 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";
haikunce35fc12015-03-24 21:16:31 +0800305 reg = <0x2ad0000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800306 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";
haikunce35fc12015-03-24 21:16:31 +0800314 reg = <0x2b50000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800315 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";
haikunce35fc12015-03-24 21:16:31 +0800327 reg = <0x2b60000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800328 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";
haikunce35fc12015-03-24 21:16:31 +0800341 reg = <0x2c00000 0x10000>,
342 <0x2c10000 0x10000>,
343 <0x2c20000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800344 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>;
haikunce35fc12015-03-24 21:16:31 +0800359 reg = <0x2d24000 0x4000>;
haikunddf79f32015-03-25 20:23:26 +0800360 };
361
362 usb@8600000 {
363 compatible = "fsl-usb2-dr-v2.5", "fsl-usb2-dr";
haikunce35fc12015-03-24 21:16:31 +0800364 reg = <0x8600000 0x1000>;
haikunddf79f32015-03-25 20:23:26 +0800365 interrupts = <GIC_SPI 171 IRQ_TYPE_LEVEL_HIGH>;
366 dr_mode = "host";
367 phy_type = "ulpi";
368 };
369
370 usb3@3100000 {
Rajesh Bhagata866c212016-07-01 18:51:48 +0530371 compatible = "fsl,layerscape-dwc3";
haikunce35fc12015-03-24 21:16:31 +0800372 reg = <0x3100000 0x10000>;
haikunddf79f32015-03-25 20:23:26 +0800373 interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>;
374 dr_mode = "host";
375 };
Minghuan Lianadd73a12016-12-13 14:54:11 +0800376
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 };
haikunddf79f32015-03-25 20:23:26 +0800407 };
408};