GNU Linux-libre 4.19.264-gnu1
[releases.git] / arch / arm64 / boot / dts / xilinx / zynqmp.dtsi
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * dts file for Xilinx ZynqMP
4  *
5  * (C) Copyright 2014 - 2015, Xilinx, Inc.
6  *
7  * Michal Simek <michal.simek@xilinx.com>
8  *
9  * This program is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU General Public License as
11  * published by the Free Software Foundation; either version 2 of
12  * the License, or (at your option) any later version.
13  */
14
15 / {
16         compatible = "xlnx,zynqmp";
17         #address-cells = <2>;
18         #size-cells = <2>;
19
20         cpus {
21                 #address-cells = <1>;
22                 #size-cells = <0>;
23
24                 cpu0: cpu@0 {
25                         compatible = "arm,cortex-a53", "arm,armv8";
26                         device_type = "cpu";
27                         enable-method = "psci";
28                         operating-points-v2 = <&cpu_opp_table>;
29                         reg = <0x0>;
30                         cpu-idle-states = <&CPU_SLEEP_0>;
31                 };
32
33                 cpu1: cpu@1 {
34                         compatible = "arm,cortex-a53", "arm,armv8";
35                         device_type = "cpu";
36                         enable-method = "psci";
37                         reg = <0x1>;
38                         operating-points-v2 = <&cpu_opp_table>;
39                         cpu-idle-states = <&CPU_SLEEP_0>;
40                 };
41
42                 cpu2: cpu@2 {
43                         compatible = "arm,cortex-a53", "arm,armv8";
44                         device_type = "cpu";
45                         enable-method = "psci";
46                         reg = <0x2>;
47                         operating-points-v2 = <&cpu_opp_table>;
48                         cpu-idle-states = <&CPU_SLEEP_0>;
49                 };
50
51                 cpu3: cpu@3 {
52                         compatible = "arm,cortex-a53", "arm,armv8";
53                         device_type = "cpu";
54                         enable-method = "psci";
55                         reg = <0x3>;
56                         operating-points-v2 = <&cpu_opp_table>;
57                         cpu-idle-states = <&CPU_SLEEP_0>;
58                 };
59
60                 idle-states {
61                         entry-method = "psci";
62
63                         CPU_SLEEP_0: cpu-sleep-0 {
64                                 compatible = "arm,idle-state";
65                                 arm,psci-suspend-param = <0x40000000>;
66                                 local-timer-stop;
67                                 entry-latency-us = <300>;
68                                 exit-latency-us = <600>;
69                                 min-residency-us = <10000>;
70                         };
71                 };
72         };
73
74         cpu_opp_table: cpu-opp-table {
75                 compatible = "operating-points-v2";
76                 opp-shared;
77                 opp00 {
78                         opp-hz = /bits/ 64 <1199999988>;
79                         opp-microvolt = <1000000>;
80                         clock-latency-ns = <500000>;
81                 };
82                 opp01 {
83                         opp-hz = /bits/ 64 <599999994>;
84                         opp-microvolt = <1000000>;
85                         clock-latency-ns = <500000>;
86                 };
87                 opp02 {
88                         opp-hz = /bits/ 64 <399999996>;
89                         opp-microvolt = <1000000>;
90                         clock-latency-ns = <500000>;
91                 };
92                 opp03 {
93                         opp-hz = /bits/ 64 <299999997>;
94                         opp-microvolt = <1000000>;
95                         clock-latency-ns = <500000>;
96                 };
97         };
98
99         dcc: dcc {
100                 compatible = "arm,dcc";
101                 status = "disabled";
102         };
103
104         pmu {
105                 compatible = "arm,armv8-pmuv3";
106                 interrupt-parent = <&gic>;
107                 interrupts = <0 143 4>,
108                              <0 144 4>,
109                              <0 145 4>,
110                              <0 146 4>;
111         };
112
113         psci {
114                 compatible = "arm,psci-0.2";
115                 method = "smc";
116         };
117
118         timer {
119                 compatible = "arm,armv8-timer";
120                 interrupt-parent = <&gic>;
121                 interrupts = <1 13 0xf08>,
122                              <1 14 0xf08>,
123                              <1 11 0xf08>,
124                              <1 10 0xf08>;
125         };
126
127         amba_apu: amba-apu@0 {
128                 compatible = "simple-bus";
129                 #address-cells = <2>;
130                 #size-cells = <1>;
131                 ranges = <0 0 0 0 0xffffffff>;
132
133                 gic: interrupt-controller@f9010000 {
134                         compatible = "arm,gic-400", "arm,cortex-a15-gic";
135                         #interrupt-cells = <3>;
136                         reg = <0x0 0xf9010000 0x10000>,
137                               <0x0 0xf9020000 0x20000>,
138                               <0x0 0xf9040000 0x20000>,
139                               <0x0 0xf9060000 0x20000>;
140                         interrupt-controller;
141                         interrupt-parent = <&gic>;
142                         interrupts = <1 9 0xf04>;
143                 };
144         };
145
146         amba: amba {
147                 compatible = "simple-bus";
148                 #address-cells = <2>;
149                 #size-cells = <2>;
150                 ranges;
151
152                 can0: can@ff060000 {
153                         compatible = "xlnx,zynq-can-1.0";
154                         status = "disabled";
155                         clock-names = "can_clk", "pclk";
156                         reg = <0x0 0xff060000 0x0 0x1000>;
157                         interrupts = <0 23 4>;
158                         interrupt-parent = <&gic>;
159                         tx-fifo-depth = <0x40>;
160                         rx-fifo-depth = <0x40>;
161                 };
162
163                 can1: can@ff070000 {
164                         compatible = "xlnx,zynq-can-1.0";
165                         status = "disabled";
166                         clock-names = "can_clk", "pclk";
167                         reg = <0x0 0xff070000 0x0 0x1000>;
168                         interrupts = <0 24 4>;
169                         interrupt-parent = <&gic>;
170                         tx-fifo-depth = <0x40>;
171                         rx-fifo-depth = <0x40>;
172                 };
173
174                 cci: cci@fd6e0000 {
175                         compatible = "arm,cci-400";
176                         reg = <0x0 0xfd6e0000 0x0 0x9000>;
177                         ranges = <0x0 0x0 0xfd6e0000 0x10000>;
178                         #address-cells = <1>;
179                         #size-cells = <1>;
180
181                         pmu@9000 {
182                                 compatible = "arm,cci-400-pmu,r1";
183                                 reg = <0x9000 0x5000>;
184                                 interrupt-parent = <&gic>;
185                                 interrupts = <0 123 4>,
186                                              <0 123 4>,
187                                              <0 123 4>,
188                                              <0 123 4>,
189                                              <0 123 4>;
190                         };
191                 };
192
193                 /* GDMA */
194                 fpd_dma_chan1: dma@fd500000 {
195                         status = "disabled";
196                         compatible = "xlnx,zynqmp-dma-1.0";
197                         reg = <0x0 0xfd500000 0x0 0x1000>;
198                         interrupt-parent = <&gic>;
199                         interrupts = <0 124 4>;
200                         clock-names = "clk_main", "clk_apb";
201                         xlnx,bus-width = <128>;
202                 };
203
204                 fpd_dma_chan2: dma@fd510000 {
205                         status = "disabled";
206                         compatible = "xlnx,zynqmp-dma-1.0";
207                         reg = <0x0 0xfd510000 0x0 0x1000>;
208                         interrupt-parent = <&gic>;
209                         interrupts = <0 125 4>;
210                         clock-names = "clk_main", "clk_apb";
211                         xlnx,bus-width = <128>;
212                 };
213
214                 fpd_dma_chan3: dma@fd520000 {
215                         status = "disabled";
216                         compatible = "xlnx,zynqmp-dma-1.0";
217                         reg = <0x0 0xfd520000 0x0 0x1000>;
218                         interrupt-parent = <&gic>;
219                         interrupts = <0 126 4>;
220                         clock-names = "clk_main", "clk_apb";
221                         xlnx,bus-width = <128>;
222                 };
223
224                 fpd_dma_chan4: dma@fd530000 {
225                         status = "disabled";
226                         compatible = "xlnx,zynqmp-dma-1.0";
227                         reg = <0x0 0xfd530000 0x0 0x1000>;
228                         interrupt-parent = <&gic>;
229                         interrupts = <0 127 4>;
230                         clock-names = "clk_main", "clk_apb";
231                         xlnx,bus-width = <128>;
232                 };
233
234                 fpd_dma_chan5: dma@fd540000 {
235                         status = "disabled";
236                         compatible = "xlnx,zynqmp-dma-1.0";
237                         reg = <0x0 0xfd540000 0x0 0x1000>;
238                         interrupt-parent = <&gic>;
239                         interrupts = <0 128 4>;
240                         clock-names = "clk_main", "clk_apb";
241                         xlnx,bus-width = <128>;
242                 };
243
244                 fpd_dma_chan6: dma@fd550000 {
245                         status = "disabled";
246                         compatible = "xlnx,zynqmp-dma-1.0";
247                         reg = <0x0 0xfd550000 0x0 0x1000>;
248                         interrupt-parent = <&gic>;
249                         interrupts = <0 129 4>;
250                         clock-names = "clk_main", "clk_apb";
251                         xlnx,bus-width = <128>;
252                 };
253
254                 fpd_dma_chan7: dma@fd560000 {
255                         status = "disabled";
256                         compatible = "xlnx,zynqmp-dma-1.0";
257                         reg = <0x0 0xfd560000 0x0 0x1000>;
258                         interrupt-parent = <&gic>;
259                         interrupts = <0 130 4>;
260                         clock-names = "clk_main", "clk_apb";
261                         xlnx,bus-width = <128>;
262                 };
263
264                 fpd_dma_chan8: dma@fd570000 {
265                         status = "disabled";
266                         compatible = "xlnx,zynqmp-dma-1.0";
267                         reg = <0x0 0xfd570000 0x0 0x1000>;
268                         interrupt-parent = <&gic>;
269                         interrupts = <0 131 4>;
270                         clock-names = "clk_main", "clk_apb";
271                         xlnx,bus-width = <128>;
272                 };
273
274                 /* LPDDMA default allows only secured access. inorder to enable
275                  * These dma channels, Users should ensure that these dma
276                  * Channels are allowed for non secure access.
277                  */
278                 lpd_dma_chan1: dma@ffa80000 {
279                         status = "disabled";
280                         compatible = "xlnx,zynqmp-dma-1.0";
281                         reg = <0x0 0xffa80000 0x0 0x1000>;
282                         interrupt-parent = <&gic>;
283                         interrupts = <0 77 4>;
284                         clock-names = "clk_main", "clk_apb";
285                         xlnx,bus-width = <64>;
286                 };
287
288                 lpd_dma_chan2: dma@ffa90000 {
289                         status = "disabled";
290                         compatible = "xlnx,zynqmp-dma-1.0";
291                         reg = <0x0 0xffa90000 0x0 0x1000>;
292                         interrupt-parent = <&gic>;
293                         interrupts = <0 78 4>;
294                         clock-names = "clk_main", "clk_apb";
295                         xlnx,bus-width = <64>;
296                 };
297
298                 lpd_dma_chan3: dma@ffaa0000 {
299                         status = "disabled";
300                         compatible = "xlnx,zynqmp-dma-1.0";
301                         reg = <0x0 0xffaa0000 0x0 0x1000>;
302                         interrupt-parent = <&gic>;
303                         interrupts = <0 79 4>;
304                         clock-names = "clk_main", "clk_apb";
305                         xlnx,bus-width = <64>;
306                 };
307
308                 lpd_dma_chan4: dma@ffab0000 {
309                         status = "disabled";
310                         compatible = "xlnx,zynqmp-dma-1.0";
311                         reg = <0x0 0xffab0000 0x0 0x1000>;
312                         interrupt-parent = <&gic>;
313                         interrupts = <0 80 4>;
314                         clock-names = "clk_main", "clk_apb";
315                         xlnx,bus-width = <64>;
316                 };
317
318                 lpd_dma_chan5: dma@ffac0000 {
319                         status = "disabled";
320                         compatible = "xlnx,zynqmp-dma-1.0";
321                         reg = <0x0 0xffac0000 0x0 0x1000>;
322                         interrupt-parent = <&gic>;
323                         interrupts = <0 81 4>;
324                         clock-names = "clk_main", "clk_apb";
325                         xlnx,bus-width = <64>;
326                 };
327
328                 lpd_dma_chan6: dma@ffad0000 {
329                         status = "disabled";
330                         compatible = "xlnx,zynqmp-dma-1.0";
331                         reg = <0x0 0xffad0000 0x0 0x1000>;
332                         interrupt-parent = <&gic>;
333                         interrupts = <0 82 4>;
334                         clock-names = "clk_main", "clk_apb";
335                         xlnx,bus-width = <64>;
336                 };
337
338                 lpd_dma_chan7: dma@ffae0000 {
339                         status = "disabled";
340                         compatible = "xlnx,zynqmp-dma-1.0";
341                         reg = <0x0 0xffae0000 0x0 0x1000>;
342                         interrupt-parent = <&gic>;
343                         interrupts = <0 83 4>;
344                         clock-names = "clk_main", "clk_apb";
345                         xlnx,bus-width = <64>;
346                 };
347
348                 lpd_dma_chan8: dma@ffaf0000 {
349                         status = "disabled";
350                         compatible = "xlnx,zynqmp-dma-1.0";
351                         reg = <0x0 0xffaf0000 0x0 0x1000>;
352                         interrupt-parent = <&gic>;
353                         interrupts = <0 84 4>;
354                         clock-names = "clk_main", "clk_apb";
355                         xlnx,bus-width = <64>;
356                 };
357
358                 gem0: ethernet@ff0b0000 {
359                         compatible = "cdns,zynqmp-gem", "cdns,gem";
360                         status = "disabled";
361                         interrupt-parent = <&gic>;
362                         interrupts = <0 57 4>, <0 57 4>;
363                         reg = <0x0 0xff0b0000 0x0 0x1000>;
364                         clock-names = "pclk", "hclk", "tx_clk";
365                         #address-cells = <1>;
366                         #size-cells = <0>;
367                 };
368
369                 gem1: ethernet@ff0c0000 {
370                         compatible = "cdns,zynqmp-gem", "cdns,gem";
371                         status = "disabled";
372                         interrupt-parent = <&gic>;
373                         interrupts = <0 59 4>, <0 59 4>;
374                         reg = <0x0 0xff0c0000 0x0 0x1000>;
375                         clock-names = "pclk", "hclk", "tx_clk";
376                         #address-cells = <1>;
377                         #size-cells = <0>;
378                 };
379
380                 gem2: ethernet@ff0d0000 {
381                         compatible = "cdns,zynqmp-gem", "cdns,gem";
382                         status = "disabled";
383                         interrupt-parent = <&gic>;
384                         interrupts = <0 61 4>, <0 61 4>;
385                         reg = <0x0 0xff0d0000 0x0 0x1000>;
386                         clock-names = "pclk", "hclk", "tx_clk";
387                         #address-cells = <1>;
388                         #size-cells = <0>;
389                 };
390
391                 gem3: ethernet@ff0e0000 {
392                         compatible = "cdns,zynqmp-gem", "cdns,gem";
393                         status = "disabled";
394                         interrupt-parent = <&gic>;
395                         interrupts = <0 63 4>, <0 63 4>;
396                         reg = <0x0 0xff0e0000 0x0 0x1000>;
397                         clock-names = "pclk", "hclk", "tx_clk";
398                         #address-cells = <1>;
399                         #size-cells = <0>;
400                 };
401
402                 gpio: gpio@ff0a0000 {
403                         compatible = "xlnx,zynqmp-gpio-1.0";
404                         status = "disabled";
405                         #gpio-cells = <0x2>;
406                         interrupt-parent = <&gic>;
407                         interrupts = <0 16 4>;
408                         interrupt-controller;
409                         #interrupt-cells = <2>;
410                         reg = <0x0 0xff0a0000 0x0 0x1000>;
411                 };
412
413                 i2c0: i2c@ff020000 {
414                         compatible = "cdns,i2c-r1p14";
415                         status = "disabled";
416                         interrupt-parent = <&gic>;
417                         interrupts = <0 17 4>;
418                         reg = <0x0 0xff020000 0x0 0x1000>;
419                         #address-cells = <1>;
420                         #size-cells = <0>;
421                 };
422
423                 i2c1: i2c@ff030000 {
424                         compatible = "cdns,i2c-r1p14";
425                         status = "disabled";
426                         interrupt-parent = <&gic>;
427                         interrupts = <0 18 4>;
428                         reg = <0x0 0xff030000 0x0 0x1000>;
429                         #address-cells = <1>;
430                         #size-cells = <0>;
431                 };
432
433                 pcie: pcie@fd0e0000 {
434                         compatible = "xlnx,nwl-pcie-2.11";
435                         status = "disabled";
436                         #address-cells = <3>;
437                         #size-cells = <2>;
438                         #interrupt-cells = <1>;
439                         msi-controller;
440                         device_type = "pci";
441                         interrupt-parent = <&gic>;
442                         interrupts = <0 118 4>,
443                                      <0 117 4>,
444                                      <0 116 4>,
445                                      <0 115 4>, /* MSI_1 [63...32] */
446                                      <0 114 4>; /* MSI_0 [31...0] */
447                         interrupt-names = "misc", "dummy", "intx",
448                                           "msi1", "msi0";
449                         msi-parent = <&pcie>;
450                         reg = <0x0 0xfd0e0000 0x0 0x1000>,
451                               <0x0 0xfd480000 0x0 0x1000>,
452                               <0x80 0x00000000 0x0 0x1000000>;
453                         reg-names = "breg", "pcireg", "cfg";
454                         ranges = <0x02000000 0x00000000 0xe0000000 0x00000000 0xe0000000 0x00000000 0x10000000  /* non-prefetchable memory */
455                                   0x43000000 0x00000006 0x00000000 0x00000006 0x00000000 0x00000002 0x00000000>;/* prefetchable memory */
456                         bus-range = <0x00 0xff>;
457                         interrupt-map-mask = <0x0 0x0 0x0 0x7>;
458                         interrupt-map = <0x0 0x0 0x0 0x1 &pcie_intc 0x1>,
459                                         <0x0 0x0 0x0 0x2 &pcie_intc 0x2>,
460                                         <0x0 0x0 0x0 0x3 &pcie_intc 0x3>,
461                                         <0x0 0x0 0x0 0x4 &pcie_intc 0x4>;
462                         pcie_intc: legacy-interrupt-controller {
463                                 interrupt-controller;
464                                 #address-cells = <0>;
465                                 #interrupt-cells = <1>;
466                         };
467                 };
468
469                 rtc: rtc@ffa60000 {
470                         compatible = "xlnx,zynqmp-rtc";
471                         status = "disabled";
472                         reg = <0x0 0xffa60000 0x0 0x100>;
473                         interrupt-parent = <&gic>;
474                         interrupts = <0 26 4>, <0 27 4>;
475                         interrupt-names = "alarm", "sec";
476                         calibration = <0x8000>;
477                 };
478
479                 sata: ahci@fd0c0000 {
480                         compatible = "ceva,ahci-1v84";
481                         status = "disabled";
482                         reg = <0x0 0xfd0c0000 0x0 0x2000>;
483                         interrupt-parent = <&gic>;
484                         interrupts = <0 133 4>;
485                 };
486
487                 sdhci0: sdhci@ff160000 {
488                         compatible = "arasan,sdhci-8.9a";
489                         status = "disabled";
490                         interrupt-parent = <&gic>;
491                         interrupts = <0 48 4>;
492                         reg = <0x0 0xff160000 0x0 0x1000>;
493                         clock-names = "clk_xin", "clk_ahb";
494                 };
495
496                 sdhci1: sdhci@ff170000 {
497                         compatible = "arasan,sdhci-8.9a";
498                         status = "disabled";
499                         interrupt-parent = <&gic>;
500                         interrupts = <0 49 4>;
501                         reg = <0x0 0xff170000 0x0 0x1000>;
502                         clock-names = "clk_xin", "clk_ahb";
503                 };
504
505                 smmu: smmu@fd800000 {
506                         compatible = "arm,mmu-500";
507                         reg = <0x0 0xfd800000 0x0 0x20000>;
508                         status = "disabled";
509                         #global-interrupts = <1>;
510                         interrupt-parent = <&gic>;
511                         interrupts = <0 155 4>,
512                                 <0 155 4>, <0 155 4>, <0 155 4>, <0 155 4>,
513                                 <0 155 4>, <0 155 4>, <0 155 4>, <0 155 4>,
514                                 <0 155 4>, <0 155 4>, <0 155 4>, <0 155 4>,
515                                 <0 155 4>, <0 155 4>, <0 155 4>, <0 155 4>;
516                 };
517
518                 spi0: spi@ff040000 {
519                         compatible = "cdns,spi-r1p6";
520                         status = "disabled";
521                         interrupt-parent = <&gic>;
522                         interrupts = <0 19 4>;
523                         reg = <0x0 0xff040000 0x0 0x1000>;
524                         clock-names = "ref_clk", "pclk";
525                         #address-cells = <1>;
526                         #size-cells = <0>;
527                 };
528
529                 spi1: spi@ff050000 {
530                         compatible = "cdns,spi-r1p6";
531                         status = "disabled";
532                         interrupt-parent = <&gic>;
533                         interrupts = <0 20 4>;
534                         reg = <0x0 0xff050000 0x0 0x1000>;
535                         clock-names = "ref_clk", "pclk";
536                         #address-cells = <1>;
537                         #size-cells = <0>;
538                 };
539
540                 ttc0: timer@ff110000 {
541                         compatible = "cdns,ttc";
542                         status = "disabled";
543                         interrupt-parent = <&gic>;
544                         interrupts = <0 36 4>, <0 37 4>, <0 38 4>;
545                         reg = <0x0 0xff110000 0x0 0x1000>;
546                         timer-width = <32>;
547                 };
548
549                 ttc1: timer@ff120000 {
550                         compatible = "cdns,ttc";
551                         status = "disabled";
552                         interrupt-parent = <&gic>;
553                         interrupts = <0 39 4>, <0 40 4>, <0 41 4>;
554                         reg = <0x0 0xff120000 0x0 0x1000>;
555                         timer-width = <32>;
556                 };
557
558                 ttc2: timer@ff130000 {
559                         compatible = "cdns,ttc";
560                         status = "disabled";
561                         interrupt-parent = <&gic>;
562                         interrupts = <0 42 4>, <0 43 4>, <0 44 4>;
563                         reg = <0x0 0xff130000 0x0 0x1000>;
564                         timer-width = <32>;
565                 };
566
567                 ttc3: timer@ff140000 {
568                         compatible = "cdns,ttc";
569                         status = "disabled";
570                         interrupt-parent = <&gic>;
571                         interrupts = <0 45 4>, <0 46 4>, <0 47 4>;
572                         reg = <0x0 0xff140000 0x0 0x1000>;
573                         timer-width = <32>;
574                 };
575
576                 uart0: serial@ff000000 {
577                         compatible = "xlnx,zynqmp-uart", "cdns,uart-r1p12";
578                         status = "disabled";
579                         interrupt-parent = <&gic>;
580                         interrupts = <0 21 4>;
581                         reg = <0x0 0xff000000 0x0 0x1000>;
582                         clock-names = "uart_clk", "pclk";
583                 };
584
585                 uart1: serial@ff010000 {
586                         compatible = "xlnx,zynqmp-uart", "cdns,uart-r1p12";
587                         status = "disabled";
588                         interrupt-parent = <&gic>;
589                         interrupts = <0 22 4>;
590                         reg = <0x0 0xff010000 0x0 0x1000>;
591                         clock-names = "uart_clk", "pclk";
592                 };
593
594                 usb0: usb@fe200000 {
595                         compatible = "snps,dwc3";
596                         status = "disabled";
597                         interrupt-parent = <&gic>;
598                         interrupts = <0 65 4>;
599                         reg = <0x0 0xfe200000 0x0 0x40000>;
600                         clock-names = "clk_xin", "clk_ahb";
601                 };
602
603                 usb1: usb@fe300000 {
604                         compatible = "snps,dwc3";
605                         status = "disabled";
606                         interrupt-parent = <&gic>;
607                         interrupts = <0 70 4>;
608                         reg = <0x0 0xfe300000 0x0 0x40000>;
609                         clock-names = "clk_xin", "clk_ahb";
610                 };
611
612                 watchdog0: watchdog@fd4d0000 {
613                         compatible = "cdns,wdt-r1p2";
614                         status = "disabled";
615                         interrupt-parent = <&gic>;
616                         interrupts = <0 113 1>;
617                         reg = <0x0 0xfd4d0000 0x0 0x1000>;
618                         timeout-sec = <10>;
619                 };
620         };
621 };