]> git.sur5r.net Git - u-boot/blob - arch/arm/dts/ls1021a.dtsi
SPDX: Convert all of our single license tags to Linux Kernel style
[u-boot] / arch / arm / dts / ls1021a.dtsi
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 };