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