blob: c2f8fc7b70d967cae809f35bd82cf966eef12685 [file] [log] [blame]
Michal Simek44303df2015-10-30 15:39:18 +01001/*
2 * dts file for Xilinx ZynqMP
3 *
4 * (C) Copyright 2014 - 2015, Xilinx, Inc.
5 *
6 * Michal Simek <michal.simek@xilinx.com>
7 *
8 * SPDX-License-Identifier: GPL-2.0+
9 */
10/ {
11 compatible = "xlnx,zynqmp";
12 #address-cells = <2>;
Michal Simek85d11422016-04-07 15:07:38 +020013 #size-cells = <2>;
Michal Simek44303df2015-10-30 15:39:18 +010014
15 cpus {
16 #address-cells = <1>;
17 #size-cells = <0>;
18
19 cpu@0 {
20 compatible = "arm,cortex-a53", "arm,armv8";
21 device_type = "cpu";
22 enable-method = "psci";
23 reg = <0x0>;
24 };
25
26 cpu@1 {
27 compatible = "arm,cortex-a53", "arm,armv8";
28 device_type = "cpu";
29 enable-method = "psci";
30 reg = <0x1>;
31 };
32
33 cpu@2 {
34 compatible = "arm,cortex-a53", "arm,armv8";
35 device_type = "cpu";
36 enable-method = "psci";
37 reg = <0x2>;
38 };
39
40 cpu@3 {
41 compatible = "arm,cortex-a53", "arm,armv8";
42 device_type = "cpu";
43 enable-method = "psci";
44 reg = <0x3>;
45 };
46 };
47
Michal Simek69d09dd2016-09-09 08:46:39 +020048 dcc: dcc {
49 compatible = "arm,dcc";
50 status = "disabled";
51 u-boot,dm-pre-reloc;
52 };
53
Soren Brinkmann8f4e3972016-01-11 15:34:42 -080054 power-domains {
55 compatible = "xlnx,zynqmp-genpd";
56
57 pd_usb0: pd-usb0 {
58 #power-domain-cells = <0x0>;
59 pd-id = <0x16>;
60 };
61
62 pd_usb1: pd-usb1 {
63 #power-domain-cells = <0x0>;
64 pd-id = <0x17>;
65 };
66
67 pd_sata: pd-sata {
68 #power-domain-cells = <0x0>;
69 pd-id = <0x1c>;
70 };
71
72 pd_spi0: pd-spi0 {
73 #power-domain-cells = <0x0>;
74 pd-id = <0x23>;
75 };
76
77 pd_spi1: pd-spi1 {
78 #power-domain-cells = <0x0>;
79 pd-id = <0x24>;
80 };
81
82 pd_uart0: pd-uart0 {
83 #power-domain-cells = <0x0>;
84 pd-id = <0x21>;
85 };
86
87 pd_uart1: pd-uart1 {
88 #power-domain-cells = <0x0>;
89 pd-id = <0x22>;
90 };
91
92 pd_eth0: pd-eth0 {
93 #power-domain-cells = <0x0>;
94 pd-id = <0x1d>;
95 };
96
97 pd_eth1: pd-eth1 {
98 #power-domain-cells = <0x0>;
99 pd-id = <0x1e>;
100 };
101
102 pd_eth2: pd-eth2 {
103 #power-domain-cells = <0x0>;
104 pd-id = <0x1f>;
105 };
106
107 pd_eth3: pd-eth3 {
108 #power-domain-cells = <0x0>;
109 pd-id = <0x20>;
110 };
111
112 pd_i2c0: pd-i2c0 {
113 #power-domain-cells = <0x0>;
114 pd-id = <0x25>;
115 };
116
117 pd_i2c1: pd-i2c1 {
118 #power-domain-cells = <0x0>;
119 pd-id = <0x26>;
120 };
121
122 pd_dp: pd-dp {
123 /* fixme: what to attach to */
124 #power-domain-cells = <0x0>;
125 pd-id = <0x29>;
126 };
127
128 pd_gdma: pd-gdma {
129 #power-domain-cells = <0x0>;
130 pd-id = <0x2a>;
131 };
132
133 pd_adma: pd-adma {
134 #power-domain-cells = <0x0>;
135 pd-id = <0x2b>;
136 };
137
138 pd_ttc0: pd-ttc0 {
139 #power-domain-cells = <0x0>;
140 pd-id = <0x18>;
141 };
142
143 pd_ttc1: pd-ttc1 {
144 #power-domain-cells = <0x0>;
145 pd-id = <0x19>;
146 };
147
148 pd_ttc2: pd-ttc2 {
149 #power-domain-cells = <0x0>;
150 pd-id = <0x1a>;
151 };
152
153 pd_ttc3: pd-ttc3 {
154 #power-domain-cells = <0x0>;
155 pd-id = <0x1b>;
156 };
157
158 pd_sd0: pd-sd0 {
159 #power-domain-cells = <0x0>;
160 pd-id = <0x27>;
161 };
162
163 pd_sd1: pd-sd1 {
164 #power-domain-cells = <0x0>;
165 pd-id = <0x28>;
166 };
167
168 pd_nand: pd-nand {
169 #power-domain-cells = <0x0>;
170 pd-id = <0x2c>;
171 };
172
173 pd_qspi: pd-qspi {
174 #power-domain-cells = <0x0>;
175 pd-id = <0x2d>;
176 };
177
178 pd_gpio: pd-gpio {
179 #power-domain-cells = <0x0>;
180 pd-id = <0x2e>;
181 };
182
183 pd_can0: pd-can0 {
184 #power-domain-cells = <0x0>;
185 pd-id = <0x2f>;
186 };
187
188 pd_can1: pd-can1 {
189 #power-domain-cells = <0x0>;
190 pd-id = <0x30>;
191 };
Filip Drazic2af39322016-08-29 19:32:56 +0200192
193 pd_pcie: pd-pcie {
194 #power-domain-cells = <0x0>;
195 pd-id = <0x3b>;
196 };
197
198 pd_gpu: pd-gpu {
199 #power-domain-cells = <0x0>;
Filip Drazica4d7d562016-08-29 19:32:59 +0200200 pd-id = <0x3a 0x14 0x15>;
Filip Drazic2af39322016-08-29 19:32:56 +0200201 };
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800202 };
203
Michal Simek44303df2015-10-30 15:39:18 +0100204 pmu {
205 compatible = "arm,armv8-pmuv3";
Michal Simek14cd9ea2016-04-07 15:28:33 +0200206 interrupt-parent = <&gic>;
Michal Simek44303df2015-10-30 15:39:18 +0100207 interrupts = <0 143 4>,
208 <0 144 4>,
209 <0 145 4>,
210 <0 146 4>;
211 };
212
213 psci {
214 compatible = "arm,psci-0.2";
215 method = "smc";
216 };
217
218 firmware {
219 compatible = "xlnx,zynqmp-pm";
220 method = "smc";
221 };
222
223 timer {
224 compatible = "arm,armv8-timer";
225 interrupt-parent = <&gic>;
226 interrupts = <1 13 0xf01>,
227 <1 14 0xf01>,
228 <1 11 0xf01>,
229 <1 10 0xf01>;
230 };
231
Michal Simekc926e6f2016-11-11 13:21:04 +0100232 amba_apu: amba_apu@0 {
Michal Simek44303df2015-10-30 15:39:18 +0100233 compatible = "simple-bus";
234 #address-cells = <2>;
235 #size-cells = <1>;
Michal Simek85d11422016-04-07 15:07:38 +0200236 ranges = <0 0 0 0 0xffffffff>;
Michal Simek44303df2015-10-30 15:39:18 +0100237
238 gic: interrupt-controller@f9010000 {
239 compatible = "arm,gic-400", "arm,cortex-a15-gic";
240 #interrupt-cells = <3>;
241 reg = <0x0 0xf9010000 0x10000>,
Alexander Graf0a8c4f62016-05-12 13:44:01 +0200242 <0x0 0xf9020000 0x20000>,
Michal Simek44303df2015-10-30 15:39:18 +0100243 <0x0 0xf9040000 0x20000>,
Alexander Graf0a8c4f62016-05-12 13:44:01 +0200244 <0x0 0xf9060000 0x20000>;
Michal Simek44303df2015-10-30 15:39:18 +0100245 interrupt-controller;
246 interrupt-parent = <&gic>;
247 interrupts = <1 9 0xf04>;
248 };
249 };
250
Michal Simekc926e6f2016-11-11 13:21:04 +0100251 amba: amba@0 {
Michal Simek44303df2015-10-30 15:39:18 +0100252 compatible = "simple-bus";
Michal Simekc9811e12016-02-22 09:57:27 +0100253 u-boot,dm-pre-reloc;
Michal Simek44303df2015-10-30 15:39:18 +0100254 #address-cells = <2>;
255 #size-cells = <1>;
Michal Simek85d11422016-04-07 15:07:38 +0200256 ranges = <0 0 0 0 0xffffffff>;
Michal Simek44303df2015-10-30 15:39:18 +0100257
258 can0: can@ff060000 {
259 compatible = "xlnx,zynq-can-1.0";
260 status = "disabled";
261 clock-names = "can_clk", "pclk";
262 reg = <0x0 0xff060000 0x1000>;
263 interrupts = <0 23 4>;
264 interrupt-parent = <&gic>;
265 tx-fifo-depth = <0x40>;
266 rx-fifo-depth = <0x40>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800267 power-domains = <&pd_can0>;
Michal Simek44303df2015-10-30 15:39:18 +0100268 };
269
270 can1: can@ff070000 {
271 compatible = "xlnx,zynq-can-1.0";
272 status = "disabled";
273 clock-names = "can_clk", "pclk";
274 reg = <0x0 0xff070000 0x1000>;
275 interrupts = <0 24 4>;
276 interrupt-parent = <&gic>;
277 tx-fifo-depth = <0x40>;
278 rx-fifo-depth = <0x40>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800279 power-domains = <&pd_can1>;
Michal Simek44303df2015-10-30 15:39:18 +0100280 };
281
Michal Simekff50d212015-11-26 11:21:25 +0100282 cci: cci@fd6e0000 {
283 compatible = "arm,cci-400";
284 reg = <0x0 0xfd6e0000 0x9000>;
285 ranges = <0x0 0x0 0xfd6e0000 0x10000>;
286 #address-cells = <1>;
287 #size-cells = <1>;
288
289 pmu@9000 {
290 compatible = "arm,cci-400-pmu,r1";
291 reg = <0x9000 0x5000>;
292 interrupt-parent = <&gic>;
293 interrupts = <0 123 4>,
294 <0 123 4>,
295 <0 123 4>,
296 <0 123 4>,
297 <0 123 4>;
298 };
299 };
300
Michal Simek44303df2015-10-30 15:39:18 +0100301 /* GDMA */
302 fpd_dma_chan1: dma@fd500000 {
303 status = "disabled";
304 compatible = "xlnx,zynqmp-dma-1.0";
305 reg = <0x0 0xfd500000 0x1000>;
306 interrupt-parent = <&gic>;
307 interrupts = <0 124 4>;
VNSL Durgab34d11d2016-03-24 22:45:12 +0530308 clock-names = "clk_main", "clk_apb";
Michal Simek44303df2015-10-30 15:39:18 +0100309 xlnx,bus-width = <128>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800310 power-domains = <&pd_gdma>;
Michal Simek44303df2015-10-30 15:39:18 +0100311 };
312
313 fpd_dma_chan2: dma@fd510000 {
314 status = "disabled";
315 compatible = "xlnx,zynqmp-dma-1.0";
316 reg = <0x0 0xfd510000 0x1000>;
317 interrupt-parent = <&gic>;
318 interrupts = <0 125 4>;
VNSL Durgab34d11d2016-03-24 22:45:12 +0530319 clock-names = "clk_main", "clk_apb";
Michal Simek44303df2015-10-30 15:39:18 +0100320 xlnx,bus-width = <128>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800321 power-domains = <&pd_gdma>;
Michal Simek44303df2015-10-30 15:39:18 +0100322 };
323
324 fpd_dma_chan3: dma@fd520000 {
325 status = "disabled";
326 compatible = "xlnx,zynqmp-dma-1.0";
327 reg = <0x0 0xfd520000 0x1000>;
328 interrupt-parent = <&gic>;
329 interrupts = <0 126 4>;
VNSL Durgab34d11d2016-03-24 22:45:12 +0530330 clock-names = "clk_main", "clk_apb";
Michal Simek44303df2015-10-30 15:39:18 +0100331 xlnx,bus-width = <128>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800332 power-domains = <&pd_gdma>;
Michal Simek44303df2015-10-30 15:39:18 +0100333 };
334
335 fpd_dma_chan4: dma@fd530000 {
336 status = "disabled";
337 compatible = "xlnx,zynqmp-dma-1.0";
338 reg = <0x0 0xfd530000 0x1000>;
339 interrupt-parent = <&gic>;
340 interrupts = <0 127 4>;
VNSL Durgab34d11d2016-03-24 22:45:12 +0530341 clock-names = "clk_main", "clk_apb";
Michal Simek44303df2015-10-30 15:39:18 +0100342 xlnx,bus-width = <128>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800343 power-domains = <&pd_gdma>;
Michal Simek44303df2015-10-30 15:39:18 +0100344 };
345
346 fpd_dma_chan5: dma@fd540000 {
347 status = "disabled";
348 compatible = "xlnx,zynqmp-dma-1.0";
349 reg = <0x0 0xfd540000 0x1000>;
350 interrupt-parent = <&gic>;
351 interrupts = <0 128 4>;
VNSL Durgab34d11d2016-03-24 22:45:12 +0530352 clock-names = "clk_main", "clk_apb";
Michal Simek44303df2015-10-30 15:39:18 +0100353 xlnx,bus-width = <128>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800354 power-domains = <&pd_gdma>;
Michal Simek44303df2015-10-30 15:39:18 +0100355 };
356
357 fpd_dma_chan6: dma@fd550000 {
358 status = "disabled";
359 compatible = "xlnx,zynqmp-dma-1.0";
360 reg = <0x0 0xfd550000 0x1000>;
361 interrupt-parent = <&gic>;
362 interrupts = <0 129 4>;
VNSL Durgab34d11d2016-03-24 22:45:12 +0530363 clock-names = "clk_main", "clk_apb";
Michal Simek44303df2015-10-30 15:39:18 +0100364 xlnx,bus-width = <128>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800365 power-domains = <&pd_gdma>;
Michal Simek44303df2015-10-30 15:39:18 +0100366 };
367
368 fpd_dma_chan7: dma@fd560000 {
369 status = "disabled";
370 compatible = "xlnx,zynqmp-dma-1.0";
371 reg = <0x0 0xfd560000 0x1000>;
372 interrupt-parent = <&gic>;
373 interrupts = <0 130 4>;
VNSL Durgab34d11d2016-03-24 22:45:12 +0530374 clock-names = "clk_main", "clk_apb";
Michal Simek44303df2015-10-30 15:39:18 +0100375 xlnx,bus-width = <128>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800376 power-domains = <&pd_gdma>;
Michal Simek44303df2015-10-30 15:39:18 +0100377 };
378
379 fpd_dma_chan8: dma@fd570000 {
380 status = "disabled";
381 compatible = "xlnx,zynqmp-dma-1.0";
382 reg = <0x0 0xfd570000 0x1000>;
383 interrupt-parent = <&gic>;
384 interrupts = <0 131 4>;
VNSL Durgab34d11d2016-03-24 22:45:12 +0530385 clock-names = "clk_main", "clk_apb";
Michal Simek44303df2015-10-30 15:39:18 +0100386 xlnx,bus-width = <128>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800387 power-domains = <&pd_gdma>;
Michal Simek44303df2015-10-30 15:39:18 +0100388 };
389
390 gpu: gpu@fd4b0000 {
391 status = "disabled";
392 compatible = "arm,mali-400", "arm,mali-utgard";
393 reg = <0x0 0xfd4b0000 0x30000>;
394 interrupt-parent = <&gic>;
395 interrupts = <0 132 4>, <0 132 4>, <0 132 4>, <0 132 4>, <0 132 4>, <0 132 4>;
396 interrupt-names = "IRQGP", "IRQGPMMU", "IRQPP0", "IRQPPMMU0", "IRQPP1", "IRQPPMMU1";
Filip Drazic2af39322016-08-29 19:32:56 +0200397 power-domains = <&pd_gpu>;
Michal Simek44303df2015-10-30 15:39:18 +0100398 };
399
400 /* ADMA */
401 lpd_dma_chan1: dma@ffa80000 {
402 status = "disabled";
403 compatible = "xlnx,zynqmp-dma-1.0";
404 reg = <0x0 0xffa80000 0x1000>;
405 interrupt-parent = <&gic>;
406 interrupts = <0 77 4>;
Michal Simek44303df2015-10-30 15:39:18 +0100407 xlnx,bus-width = <64>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800408 power-domains = <&pd_adma>;
Michal Simek44303df2015-10-30 15:39:18 +0100409 };
410
411 lpd_dma_chan2: dma@ffa90000 {
412 status = "disabled";
413 compatible = "xlnx,zynqmp-dma-1.0";
414 reg = <0x0 0xffa90000 0x1000>;
415 interrupt-parent = <&gic>;
416 interrupts = <0 78 4>;
Michal Simek44303df2015-10-30 15:39:18 +0100417 xlnx,bus-width = <64>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800418 power-domains = <&pd_adma>;
Michal Simek44303df2015-10-30 15:39:18 +0100419 };
420
421 lpd_dma_chan3: dma@ffaa0000 {
422 status = "disabled";
423 compatible = "xlnx,zynqmp-dma-1.0";
424 reg = <0x0 0xffaa0000 0x1000>;
425 interrupt-parent = <&gic>;
426 interrupts = <0 79 4>;
Michal Simek44303df2015-10-30 15:39:18 +0100427 xlnx,bus-width = <64>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800428 power-domains = <&pd_adma>;
Michal Simek44303df2015-10-30 15:39:18 +0100429 };
430
431 lpd_dma_chan4: dma@ffab0000 {
432 status = "disabled";
433 compatible = "xlnx,zynqmp-dma-1.0";
434 reg = <0x0 0xffab0000 0x1000>;
435 interrupt-parent = <&gic>;
436 interrupts = <0 80 4>;
Michal Simek44303df2015-10-30 15:39:18 +0100437 xlnx,bus-width = <64>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800438 power-domains = <&pd_adma>;
Michal Simek44303df2015-10-30 15:39:18 +0100439 };
440
441 lpd_dma_chan5: dma@ffac0000 {
442 status = "disabled";
443 compatible = "xlnx,zynqmp-dma-1.0";
444 reg = <0x0 0xffac0000 0x1000>;
445 interrupt-parent = <&gic>;
446 interrupts = <0 81 4>;
Michal Simek44303df2015-10-30 15:39:18 +0100447 xlnx,bus-width = <64>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800448 power-domains = <&pd_adma>;
Michal Simek44303df2015-10-30 15:39:18 +0100449 };
450
451 lpd_dma_chan6: dma@ffad0000 {
452 status = "disabled";
453 compatible = "xlnx,zynqmp-dma-1.0";
454 reg = <0x0 0xffad0000 0x1000>;
455 interrupt-parent = <&gic>;
456 interrupts = <0 82 4>;
Michal Simek44303df2015-10-30 15:39:18 +0100457 xlnx,bus-width = <64>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800458 power-domains = <&pd_adma>;
Michal Simek44303df2015-10-30 15:39:18 +0100459 };
460
461 lpd_dma_chan7: dma@ffae0000 {
462 status = "disabled";
463 compatible = "xlnx,zynqmp-dma-1.0";
464 reg = <0x0 0xffae0000 0x1000>;
465 interrupt-parent = <&gic>;
466 interrupts = <0 83 4>;
Michal Simek44303df2015-10-30 15:39:18 +0100467 xlnx,bus-width = <64>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800468 power-domains = <&pd_adma>;
Michal Simek44303df2015-10-30 15:39:18 +0100469 };
470
471 lpd_dma_chan8: dma@ffaf0000 {
472 status = "disabled";
473 compatible = "xlnx,zynqmp-dma-1.0";
474 reg = <0x0 0xffaf0000 0x1000>;
475 interrupt-parent = <&gic>;
476 interrupts = <0 84 4>;
Michal Simek44303df2015-10-30 15:39:18 +0100477 xlnx,bus-width = <64>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800478 power-domains = <&pd_adma>;
Michal Simek44303df2015-10-30 15:39:18 +0100479 };
480
Naga Sureshkumar Relli90869002016-03-11 13:10:26 +0530481 mc: memory-controller@fd070000 {
482 compatible = "xlnx,zynqmp-ddrc-2.40a";
483 reg = <0x0 0xfd070000 0x30000>;
484 interrupt-parent = <&gic>;
485 interrupts = <0 112 4>;
486 };
487
Michal Simek44303df2015-10-30 15:39:18 +0100488 nand0: nand@ff100000 {
489 compatible = "arasan,nfc-v3p10";
490 status = "disabled";
491 reg = <0x0 0xff100000 0x1000>;
492 clock-names = "clk_sys", "clk_flash";
493 interrupt-parent = <&gic>;
494 interrupts = <0 14 4>;
495 #address-cells = <2>;
496 #size-cells = <1>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800497 power-domains = <&pd_nand>;
Michal Simek44303df2015-10-30 15:39:18 +0100498 };
499
500 gem0: ethernet@ff0b0000 {
Michal Simekda2ad782016-02-11 15:26:46 +0100501 compatible = "cdns,zynqmp-gem";
Michal Simek44303df2015-10-30 15:39:18 +0100502 status = "disabled";
503 interrupt-parent = <&gic>;
504 interrupts = <0 57 4>, <0 57 4>;
505 reg = <0x0 0xff0b0000 0x1000>;
506 clock-names = "pclk", "hclk", "tx_clk";
507 #address-cells = <1>;
508 #size-cells = <0>;
Edgar E. Iglesias7f1d7d92015-11-26 14:12:20 +0100509 #stream-id-cells = <1>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800510 power-domains = <&pd_eth0>;
Michal Simek44303df2015-10-30 15:39:18 +0100511 };
512
513 gem1: ethernet@ff0c0000 {
Michal Simekda2ad782016-02-11 15:26:46 +0100514 compatible = "cdns,zynqmp-gem";
Michal Simek44303df2015-10-30 15:39:18 +0100515 status = "disabled";
516 interrupt-parent = <&gic>;
517 interrupts = <0 59 4>, <0 59 4>;
518 reg = <0x0 0xff0c0000 0x1000>;
519 clock-names = "pclk", "hclk", "tx_clk";
520 #address-cells = <1>;
521 #size-cells = <0>;
Edgar E. Iglesias7f1d7d92015-11-26 14:12:20 +0100522 #stream-id-cells = <1>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800523 power-domains = <&pd_eth1>;
Michal Simek44303df2015-10-30 15:39:18 +0100524 };
525
526 gem2: ethernet@ff0d0000 {
Michal Simekda2ad782016-02-11 15:26:46 +0100527 compatible = "cdns,zynqmp-gem";
Michal Simek44303df2015-10-30 15:39:18 +0100528 status = "disabled";
529 interrupt-parent = <&gic>;
530 interrupts = <0 61 4>, <0 61 4>;
531 reg = <0x0 0xff0d0000 0x1000>;
532 clock-names = "pclk", "hclk", "tx_clk";
533 #address-cells = <1>;
534 #size-cells = <0>;
Edgar E. Iglesias7f1d7d92015-11-26 14:12:20 +0100535 #stream-id-cells = <1>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800536 power-domains = <&pd_eth2>;
Michal Simek44303df2015-10-30 15:39:18 +0100537 };
538
539 gem3: ethernet@ff0e0000 {
Michal Simekda2ad782016-02-11 15:26:46 +0100540 compatible = "cdns,zynqmp-gem";
Michal Simek44303df2015-10-30 15:39:18 +0100541 status = "disabled";
542 interrupt-parent = <&gic>;
543 interrupts = <0 63 4>, <0 63 4>;
544 reg = <0x0 0xff0e0000 0x1000>;
545 clock-names = "pclk", "hclk", "tx_clk";
546 #address-cells = <1>;
547 #size-cells = <0>;
Edgar E. Iglesias7f1d7d92015-11-26 14:12:20 +0100548 #stream-id-cells = <1>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800549 power-domains = <&pd_eth3>;
Michal Simek44303df2015-10-30 15:39:18 +0100550 };
551
552 gpio: gpio@ff0a0000 {
553 compatible = "xlnx,zynqmp-gpio-1.0";
554 status = "disabled";
555 #gpio-cells = <0x2>;
556 interrupt-parent = <&gic>;
557 interrupts = <0 16 4>;
Michal Simek9e826b62016-10-20 10:26:13 +0200558 interrupt-controller;
559 #interrupt-cells = <2>;
Michal Simek44303df2015-10-30 15:39:18 +0100560 reg = <0x0 0xff0a0000 0x1000>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800561 power-domains = <&pd_gpio>;
Michal Simek44303df2015-10-30 15:39:18 +0100562 };
563
564 i2c0: i2c@ff020000 {
565 compatible = "cdns,i2c-r1p10";
566 status = "disabled";
567 interrupt-parent = <&gic>;
568 interrupts = <0 17 4>;
569 reg = <0x0 0xff020000 0x1000>;
570 #address-cells = <1>;
571 #size-cells = <0>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800572 power-domains = <&pd_i2c0>;
Michal Simek44303df2015-10-30 15:39:18 +0100573 };
574
575 i2c1: i2c@ff030000 {
576 compatible = "cdns,i2c-r1p10";
577 status = "disabled";
578 interrupt-parent = <&gic>;
579 interrupts = <0 18 4>;
580 reg = <0x0 0xff030000 0x1000>;
581 #address-cells = <1>;
582 #size-cells = <0>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800583 power-domains = <&pd_i2c1>;
Michal Simek44303df2015-10-30 15:39:18 +0100584 };
585
586 pcie: pcie@fd0e0000 {
587 compatible = "xlnx,nwl-pcie-2.11";
588 status = "disabled";
589 #address-cells = <3>;
590 #size-cells = <2>;
591 #interrupt-cells = <1>;
Bharat Kumar Gogada7d6ca732016-07-19 20:49:29 +0530592 msi-controller;
Michal Simek44303df2015-10-30 15:39:18 +0100593 device_type = "pci";
594 interrupt-parent = <&gic>;
Michal Simek91a8b0e2016-01-20 12:59:23 +0100595 interrupts = <0 118 4>,
Bharat Kumar Gogada7d6ca732016-07-19 20:49:29 +0530596 <0 117 4>,
Michal Simek91a8b0e2016-01-20 12:59:23 +0100597 <0 116 4>,
598 <0 115 4>, /* MSI_1 [63...32] */
599 <0 114 4>; /* MSI_0 [31...0] */
Bharat Kumar Gogada7d6ca732016-07-19 20:49:29 +0530600 interrupt-names = "misc","dummy","intx", "msi1", "msi0";
601 msi-parent = <&pcie>;
Michal Simek44303df2015-10-30 15:39:18 +0100602 reg = <0x0 0xfd0e0000 0x1000>,
603 <0x0 0xfd480000 0x1000>,
604 <0x0 0xe0000000 0x1000000>;
605 reg-names = "breg", "pcireg", "cfg";
606 ranges = <0x02000000 0x00000000 0xe1000000 0x00000000 0xe1000000 0 0x0f000000>;
Bharat Kumar Gogada33aec512016-02-15 21:18:58 +0530607 interrupt-map-mask = <0x0 0x0 0x0 0x7>;
608 interrupt-map = <0x0 0x0 0x0 0x1 &pcie_intc 0x1>,
609 <0x0 0x0 0x0 0x2 &pcie_intc 0x2>,
610 <0x0 0x0 0x0 0x3 &pcie_intc 0x3>,
611 <0x0 0x0 0x0 0x4 &pcie_intc 0x4>;
Filip Drazic2af39322016-08-29 19:32:56 +0200612 power-domains = <&pd_pcie>;
Bharat Kumar Gogada33aec512016-02-15 21:18:58 +0530613 pcie_intc: legacy-interrupt-controller {
614 interrupt-controller;
615 #address-cells = <0>;
616 #interrupt-cells = <1>;
617 };
Michal Simek44303df2015-10-30 15:39:18 +0100618 };
619
620 qspi: spi@ff0f0000 {
621 compatible = "xlnx,zynqmp-qspi-1.0";
622 status = "disabled";
623 clock-names = "ref_clk", "pclk";
624 interrupts = <0 15 4>;
625 interrupt-parent = <&gic>;
626 num-cs = <1>;
Michal Simekc588d152016-04-07 15:01:33 +0200627 reg = <0x0 0xff0f0000 0x1000>,
628 <0x0 0xc0000000 0x8000000>;
Michal Simek44303df2015-10-30 15:39:18 +0100629 #address-cells = <1>;
630 #size-cells = <0>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800631 power-domains = <&pd_qspi>;
Michal Simek44303df2015-10-30 15:39:18 +0100632 };
633
634 rtc: rtc@ffa60000 {
635 compatible = "xlnx,zynqmp-rtc";
636 status = "disabled";
637 reg = <0x0 0xffa60000 0x100>;
638 interrupt-parent = <&gic>;
639 interrupts = <0 26 4>, <0 27 4>;
640 interrupt-names = "alarm", "sec";
641 };
642
643 sata: ahci@fd0c0000 {
644 compatible = "ceva,ahci-1v84";
645 status = "disabled";
646 reg = <0x0 0xfd0c0000 0x2000>;
647 interrupt-parent = <&gic>;
648 interrupts = <0 133 4>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800649 power-domains = <&pd_sata>;
Michal Simek44303df2015-10-30 15:39:18 +0100650 };
651
652 sdhci0: sdhci@ff160000 {
Michal Simekc9811e12016-02-22 09:57:27 +0100653 u-boot,dm-pre-reloc;
Michal Simek44303df2015-10-30 15:39:18 +0100654 compatible = "arasan,sdhci-8.9a";
655 status = "disabled";
656 interrupt-parent = <&gic>;
657 interrupts = <0 48 4>;
658 reg = <0x0 0xff160000 0x1000>;
659 clock-names = "clk_xin", "clk_ahb";
P L Sai Krishnabd750e72016-01-19 19:01:10 +0530660 broken-tuning;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800661 power-domains = <&pd_sd0>;
Michal Simek44303df2015-10-30 15:39:18 +0100662 };
663
664 sdhci1: sdhci@ff170000 {
Michal Simekc9811e12016-02-22 09:57:27 +0100665 u-boot,dm-pre-reloc;
Michal Simek44303df2015-10-30 15:39:18 +0100666 compatible = "arasan,sdhci-8.9a";
667 status = "disabled";
668 interrupt-parent = <&gic>;
669 interrupts = <0 49 4>;
670 reg = <0x0 0xff170000 0x1000>;
671 clock-names = "clk_xin", "clk_ahb";
P L Sai Krishnabd750e72016-01-19 19:01:10 +0530672 broken-tuning;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800673 power-domains = <&pd_sd1>;
Michal Simek44303df2015-10-30 15:39:18 +0100674 };
675
676 smmu: smmu@fd800000 {
677 compatible = "arm,mmu-500";
678 reg = <0x0 0xfd800000 0x20000>;
679 #global-interrupts = <1>;
680 interrupt-parent = <&gic>;
Edgar E. Iglesias88a85aa2015-11-26 14:12:19 +0100681 interrupts = <0 155 4>,
682 <0 155 4>, <0 155 4>, <0 155 4>, <0 155 4>,
683 <0 155 4>, <0 155 4>, <0 155 4>, <0 155 4>,
684 <0 155 4>, <0 155 4>, <0 155 4>, <0 155 4>,
685 <0 155 4>, <0 155 4>, <0 155 4>, <0 155 4>;
Edgar E. Iglesias7f1d7d92015-11-26 14:12:20 +0100686 mmu-masters = < &gem0 0x874
687 &gem1 0x875
688 &gem2 0x876
689 &gem3 0x877 >;
Michal Simek44303df2015-10-30 15:39:18 +0100690 };
691
692 spi0: spi@ff040000 {
693 compatible = "cdns,spi-r1p6";
694 status = "disabled";
695 interrupt-parent = <&gic>;
696 interrupts = <0 19 4>;
697 reg = <0x0 0xff040000 0x1000>;
698 clock-names = "ref_clk", "pclk";
699 #address-cells = <1>;
700 #size-cells = <0>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800701 power-domains = <&pd_spi0>;
Michal Simek44303df2015-10-30 15:39:18 +0100702 };
703
704 spi1: spi@ff050000 {
705 compatible = "cdns,spi-r1p6";
706 status = "disabled";
707 interrupt-parent = <&gic>;
708 interrupts = <0 20 4>;
709 reg = <0x0 0xff050000 0x1000>;
710 clock-names = "ref_clk", "pclk";
711 #address-cells = <1>;
712 #size-cells = <0>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800713 power-domains = <&pd_spi1>;
Michal Simek44303df2015-10-30 15:39:18 +0100714 };
715
716 ttc0: timer@ff110000 {
717 compatible = "cdns,ttc";
718 status = "disabled";
719 interrupt-parent = <&gic>;
720 interrupts = <0 36 4>, <0 37 4>, <0 38 4>;
721 reg = <0x0 0xff110000 0x1000>;
722 timer-width = <32>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800723 power-domains = <&pd_ttc0>;
Michal Simek44303df2015-10-30 15:39:18 +0100724 };
725
726 ttc1: timer@ff120000 {
727 compatible = "cdns,ttc";
728 status = "disabled";
729 interrupt-parent = <&gic>;
730 interrupts = <0 39 4>, <0 40 4>, <0 41 4>;
731 reg = <0x0 0xff120000 0x1000>;
732 timer-width = <32>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800733 power-domains = <&pd_ttc1>;
Michal Simek44303df2015-10-30 15:39:18 +0100734 };
735
736 ttc2: timer@ff130000 {
737 compatible = "cdns,ttc";
738 status = "disabled";
739 interrupt-parent = <&gic>;
740 interrupts = <0 42 4>, <0 43 4>, <0 44 4>;
741 reg = <0x0 0xff130000 0x1000>;
742 timer-width = <32>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800743 power-domains = <&pd_ttc2>;
Michal Simek44303df2015-10-30 15:39:18 +0100744 };
745
746 ttc3: timer@ff140000 {
747 compatible = "cdns,ttc";
748 status = "disabled";
749 interrupt-parent = <&gic>;
750 interrupts = <0 45 4>, <0 46 4>, <0 47 4>;
751 reg = <0x0 0xff140000 0x1000>;
752 timer-width = <32>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800753 power-domains = <&pd_ttc3>;
Michal Simek44303df2015-10-30 15:39:18 +0100754 };
755
756 uart0: serial@ff000000 {
Michal Simekc9811e12016-02-22 09:57:27 +0100757 u-boot,dm-pre-reloc;
Michal Simekca2f5872015-11-27 13:22:58 +0100758 compatible = "cdns,uart-r1p12", "xlnx,xuartps";
Michal Simek44303df2015-10-30 15:39:18 +0100759 status = "disabled";
760 interrupt-parent = <&gic>;
761 interrupts = <0 21 4>;
762 reg = <0x0 0xff000000 0x1000>;
763 clock-names = "uart_clk", "pclk";
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800764 power-domains = <&pd_uart0>;
Michal Simek44303df2015-10-30 15:39:18 +0100765 };
766
767 uart1: serial@ff010000 {
Michal Simekc9811e12016-02-22 09:57:27 +0100768 u-boot,dm-pre-reloc;
Michal Simekca2f5872015-11-27 13:22:58 +0100769 compatible = "cdns,uart-r1p12", "xlnx,xuartps";
Michal Simek44303df2015-10-30 15:39:18 +0100770 status = "disabled";
771 interrupt-parent = <&gic>;
772 interrupts = <0 22 4>;
773 reg = <0x0 0xff010000 0x1000>;
774 clock-names = "uart_clk", "pclk";
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800775 power-domains = <&pd_uart1>;
Michal Simek44303df2015-10-30 15:39:18 +0100776 };
777
Michal Simekc926e6f2016-11-11 13:21:04 +0100778 usb0: usb0 {
Michal Simeka84de482016-04-07 15:06:07 +0200779 #address-cells = <2>;
780 #size-cells = <1>;
Michal Simek44303df2015-10-30 15:39:18 +0100781 status = "disabled";
Michal Simeka84de482016-04-07 15:06:07 +0200782 compatible = "xlnx,zynqmp-dwc3";
783 clock-names = "bus_clk", "ref_clk";
784 clocks = <&clk125>, <&clk125>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800785 power-domains = <&pd_usb0>;
Michal Simeka84de482016-04-07 15:06:07 +0200786 ranges;
787
788 dwc3_0: dwc3@fe200000 {
789 compatible = "snps,dwc3";
790 status = "disabled";
791 reg = <0x0 0xfe200000 0x40000>;
792 interrupt-parent = <&gic>;
793 interrupts = <0 65 4>;
794 /* snps,quirk-frame-length-adjustment = <0x20>; */
795 snps,refclk_fladj;
796 };
Michal Simek44303df2015-10-30 15:39:18 +0100797 };
798
Michal Simekc926e6f2016-11-11 13:21:04 +0100799 usb1: usb1 {
Michal Simeka84de482016-04-07 15:06:07 +0200800 #address-cells = <2>;
801 #size-cells = <1>;
Michal Simek44303df2015-10-30 15:39:18 +0100802 status = "disabled";
Michal Simeka84de482016-04-07 15:06:07 +0200803 compatible = "xlnx,zynqmp-dwc3";
804 clock-names = "bus_clk", "ref_clk";
805 clocks = <&clk125>, <&clk125>;
Soren Brinkmann8f4e3972016-01-11 15:34:42 -0800806 power-domains = <&pd_usb1>;
Michal Simeka84de482016-04-07 15:06:07 +0200807 ranges;
808
809 dwc3_1: dwc3@fe300000 {
810 compatible = "snps,dwc3";
811 status = "disabled";
812 reg = <0x0 0xfe300000 0x40000>;
813 interrupt-parent = <&gic>;
814 interrupts = <0 70 4>;
815 /* snps,quirk-frame-length-adjustment = <0x20>; */
816 snps,refclk_fladj;
817 };
Michal Simek44303df2015-10-30 15:39:18 +0100818 };
819
820 watchdog0: watchdog@fd4d0000 {
821 compatible = "cdns,wdt-r1p2";
822 status = "disabled";
823 interrupt-parent = <&gic>;
Punnaiah Choudary Kallurid3fd4332015-11-04 12:34:17 +0530824 interrupts = <0 113 1>;
Michal Simek44303df2015-10-30 15:39:18 +0100825 reg = <0x0 0xfd4d0000 0x1000>;
826 timeout-sec = <10>;
827 };
828
829 xilinx_drm: xilinx_drm {
830 compatible = "xlnx,drm";
831 status = "disabled";
832 xlnx,encoder-slave = <&xlnx_dp>;
833 xlnx,connector-type = "DisplayPort";
834 xlnx,dp-sub = <&xlnx_dp_sub>;
835 planes {
836 xlnx,pixel-format = "rgb565";
837 plane0 {
838 dmas = <&xlnx_dpdma 3>;
Hyun Kwonbfe27982016-07-14 17:42:44 -0700839 dma-names = "dma0";
Michal Simek44303df2015-10-30 15:39:18 +0100840 };
841 plane1 {
Hyun Kwonbfe27982016-07-14 17:42:44 -0700842 dmas = <&xlnx_dpdma 0>,
843 <&xlnx_dpdma 1>,
844 <&xlnx_dpdma 2>;
845 dma-names = "dma0", "dma1", "dma2";
Michal Simek44303df2015-10-30 15:39:18 +0100846 };
847 };
848 };
849
Hyun Kwon695d75a2015-11-23 17:12:54 -0800850 xlnx_dp: dp@fd4a0000 {
Michal Simek44303df2015-10-30 15:39:18 +0100851 compatible = "xlnx,v-dp";
852 status = "disabled";
Michal Simek7418b7c2016-10-20 10:38:16 +0200853 reg = <0x0 0xfd4a0000 0x1000>;
Michal Simek44303df2015-10-30 15:39:18 +0100854 interrupts = <0 119 4>;
855 interrupt-parent = <&gic>;
856 clock-names = "aclk", "aud_clk";
857 xlnx,dp-version = "v1.2";
858 xlnx,max-lanes = <2>;
859 xlnx,max-link-rate = <540000>;
860 xlnx,max-bpc = <16>;
861 xlnx,enable-ycrcb;
862 xlnx,colormetry = "rgb";
863 xlnx,bpc = <8>;
864 xlnx,audio-chan = <2>;
865 xlnx,dp-sub = <&xlnx_dp_sub>;
Hyun Kwon939cfea2015-11-23 17:12:55 -0800866 xlnx,max-pclock-frequency = <300000>;
Michal Simek44303df2015-10-30 15:39:18 +0100867 };
868
869 xlnx_dp_snd_card: dp_snd_card {
870 compatible = "xlnx,dp-snd-card";
871 status = "disabled";
872 xlnx,dp-snd-pcm = <&xlnx_dp_snd_pcm0>, <&xlnx_dp_snd_pcm1>;
873 xlnx,dp-snd-codec = <&xlnx_dp_snd_codec0>;
874 };
875
876 xlnx_dp_snd_codec0: dp_snd_codec0 {
877 compatible = "xlnx,dp-snd-codec";
878 status = "disabled";
879 clock-names = "aud_clk";
880 };
881
882 xlnx_dp_snd_pcm0: dp_snd_pcm0 {
883 compatible = "xlnx,dp-snd-pcm";
884 status = "disabled";
885 dmas = <&xlnx_dpdma 4>;
886 dma-names = "tx";
887 };
888
889 xlnx_dp_snd_pcm1: dp_snd_pcm1 {
890 compatible = "xlnx,dp-snd-pcm";
891 status = "disabled";
892 dmas = <&xlnx_dpdma 5>;
893 dma-names = "tx";
894 };
895
Hyun Kwon695d75a2015-11-23 17:12:54 -0800896 xlnx_dp_sub: dp_sub@fd4aa000 {
Michal Simek44303df2015-10-30 15:39:18 +0100897 compatible = "xlnx,dp-sub";
898 status = "disabled";
Michal Simekc588d152016-04-07 15:01:33 +0200899 reg = <0x0 0xfd4aa000 0x1000>,
900 <0x0 0xfd4ab000 0x1000>,
901 <0x0 0xfd4ac000 0x1000>;
Michal Simek44303df2015-10-30 15:39:18 +0100902 reg-names = "blend", "av_buf", "aud";
903 xlnx,output-fmt = "rgb";
Hyun Kwon939cfea2015-11-23 17:12:55 -0800904 xlnx,vid-fmt = "yuyv";
905 xlnx,gfx-fmt = "rgb565";
Michal Simek44303df2015-10-30 15:39:18 +0100906 };
907
908 xlnx_dpdma: dma@fd4c0000 {
909 compatible = "xlnx,dpdma";
910 status = "disabled";
911 reg = <0x0 0xfd4c0000 0x1000>;
912 interrupts = <0 122 4>;
913 interrupt-parent = <&gic>;
914 clock-names = "axi_clk";
915 dma-channels = <6>;
916 #dma-cells = <1>;
Michal Simekc926e6f2016-11-11 13:21:04 +0100917 dma-video0channel {
Michal Simek44303df2015-10-30 15:39:18 +0100918 compatible = "xlnx,video0";
919 };
Michal Simekc926e6f2016-11-11 13:21:04 +0100920 dma-video1channel {
Michal Simek44303df2015-10-30 15:39:18 +0100921 compatible = "xlnx,video1";
922 };
Michal Simekc926e6f2016-11-11 13:21:04 +0100923 dma-video2channel {
Michal Simek44303df2015-10-30 15:39:18 +0100924 compatible = "xlnx,video2";
925 };
Michal Simekc926e6f2016-11-11 13:21:04 +0100926 dma-graphicschannel {
Michal Simek44303df2015-10-30 15:39:18 +0100927 compatible = "xlnx,graphics";
928 };
Michal Simekc926e6f2016-11-11 13:21:04 +0100929 dma-audio0channel {
Michal Simek44303df2015-10-30 15:39:18 +0100930 compatible = "xlnx,audio0";
931 };
Michal Simekc926e6f2016-11-11 13:21:04 +0100932 dma-audio1channel {
Michal Simek44303df2015-10-30 15:39:18 +0100933 compatible = "xlnx,audio1";
934 };
935 };
936 };
937};