]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - sys/gnu/dts/arm64/freescale/fsl-ls1088a.dtsi
dts: Import DTS for arm64
[FreeBSD/FreeBSD.git] / sys / gnu / dts / arm64 / freescale / fsl-ls1088a.dtsi
1 /*
2  * Device Tree Include file for NXP Layerscape-1088A family SoC.
3  *
4  * Copyright 2017 NXP
5  *
6  * Harninder Rai <harninder.rai@nxp.com>
7  *
8  * This file is dual-licensed: you can use it either under the terms
9  * of the GPLv2 or the X11 license, at your option. Note that this dual
10  * licensing only applies to this file, and not this project as a
11  * whole.
12  *
13  *  a) This library is free software; you can redistribute it and/or
14  *     modify it under the terms of the GNU General Public License as
15  *     published by the Free Software Foundation; either version 2 of the
16  *     License, or (at your option) any later version.
17  *
18  *     This library is distributed in the hope that it will be useful,
19  *     but WITHOUT ANY WARRANTY; without even the implied warranty of
20  *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21  *     GNU General Public License for more details.
22  *
23  * Or, alternatively,
24  *
25  *  b) Permission is hereby granted, free of charge, to any person
26  *     obtaining a copy of this software and associated documentation
27  *     files (the "Software"), to deal in the Software without
28  *     restriction, including without limitation the rights to use,
29  *     copy, modify, merge, publish, distribute, sublicense, and/or
30  *     sell copies of the Software, and to permit persons to whom the
31  *     Software is furnished to do so, subject to the following
32  *     conditions:
33  *
34  *     The above copyright notice and this permission notice shall be
35  *     included in all copies or substantial portions of the Software.
36  *
37  *     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
38  *     EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
39  *     OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
40  *     NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT
41  *     HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
42  *     WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
43  *     FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
44  *     OTHER DEALINGS IN THE SOFTWARE.
45  */
46 #include <dt-bindings/interrupt-controller/arm-gic.h>
47 #include <dt-bindings/thermal/thermal.h>
48
49 / {
50         compatible = "fsl,ls1088a";
51         interrupt-parent = <&gic>;
52         #address-cells = <2>;
53         #size-cells = <2>;
54
55         aliases {
56                 crypto = &crypto;
57         };
58
59         cpus {
60                 #address-cells = <1>;
61                 #size-cells = <0>;
62
63                 /* We have 2 clusters having 4 Cortex-A53 cores each */
64                 cpu0: cpu@0 {
65                         device_type = "cpu";
66                         compatible = "arm,cortex-a53";
67                         reg = <0x0>;
68                         clocks = <&clockgen 1 0>;
69                         cpu-idle-states = <&CPU_PH20>;
70                         #cooling-cells = <2>;
71                 };
72
73                 cpu1: cpu@1 {
74                         device_type = "cpu";
75                         compatible = "arm,cortex-a53";
76                         reg = <0x1>;
77                         clocks = <&clockgen 1 0>;
78                         cpu-idle-states = <&CPU_PH20>;
79                 };
80
81                 cpu2: cpu@2 {
82                         device_type = "cpu";
83                         compatible = "arm,cortex-a53";
84                         reg = <0x2>;
85                         clocks = <&clockgen 1 0>;
86                         cpu-idle-states = <&CPU_PH20>;
87                 };
88
89                 cpu3: cpu@3 {
90                         device_type = "cpu";
91                         compatible = "arm,cortex-a53";
92                         reg = <0x3>;
93                         clocks = <&clockgen 1 0>;
94                         cpu-idle-states = <&CPU_PH20>;
95                 };
96
97                 cpu4: cpu@100 {
98                         device_type = "cpu";
99                         compatible = "arm,cortex-a53";
100                         reg = <0x100>;
101                         clocks = <&clockgen 1 1>;
102                         cpu-idle-states = <&CPU_PH20>;
103                         #cooling-cells = <2>;
104                 };
105
106                 cpu5: cpu@101 {
107                         device_type = "cpu";
108                         compatible = "arm,cortex-a53";
109                         reg = <0x101>;
110                         clocks = <&clockgen 1 1>;
111                         cpu-idle-states = <&CPU_PH20>;
112                 };
113
114                 cpu6: cpu@102 {
115                         device_type = "cpu";
116                         compatible = "arm,cortex-a53";
117                         reg = <0x102>;
118                         clocks = <&clockgen 1 1>;
119                         cpu-idle-states = <&CPU_PH20>;
120                 };
121
122                 cpu7: cpu@103 {
123                         device_type = "cpu";
124                         compatible = "arm,cortex-a53";
125                         reg = <0x103>;
126                         clocks = <&clockgen 1 1>;
127                         cpu-idle-states = <&CPU_PH20>;
128                 };
129
130                 CPU_PH20: cpu-ph20 {
131                         compatible = "arm,idle-state";
132                         idle-state-name = "PH20";
133                         arm,psci-suspend-param = <0x0>;
134                         entry-latency-us = <1000>;
135                         exit-latency-us = <1000>;
136                         min-residency-us = <3000>;
137                 };
138         };
139
140         gic: interrupt-controller@6000000 {
141                 compatible = "arm,gic-v3";
142                 #interrupt-cells = <3>;
143                 interrupt-controller;
144                 reg = <0x0 0x06000000 0 0x10000>, /* GIC Dist */
145                       <0x0 0x06100000 0 0x100000>, /* GICR(RD_base+SGI_base)*/
146                       <0x0 0x0c0c0000 0 0x2000>, /* GICC */
147                       <0x0 0x0c0d0000 0 0x1000>, /* GICH */
148                       <0x0 0x0c0e0000 0 0x20000>; /* GICV */
149                 interrupts = <1 9 IRQ_TYPE_LEVEL_HIGH>;
150                 #address-cells = <2>;
151                 #size-cells = <2>;
152                 ranges;
153
154                 its: gic-its@6020000 {
155                         compatible = "arm,gic-v3-its";
156                         msi-controller;
157                         reg = <0x0 0x6020000 0 0x20000>;
158                 };
159         };
160
161         thermal-zones {
162                 cpu_thermal: cpu-thermal {
163                         polling-delay-passive = <1000>;
164                         polling-delay = <5000>;
165                         thermal-sensors = <&tmu 0>;
166
167                         trips {
168                                 cpu_alert: cpu-alert {
169                                         temperature = <85000>;
170                                         hysteresis = <2000>;
171                                         type = "passive";
172                                 };
173
174                                 cpu_crit: cpu-crit {
175                                         temperature = <95000>;
176                                         hysteresis = <2000>;
177                                         type = "critical";
178                                 };
179                         };
180
181                         cooling-maps {
182                                 map0 {
183                                         trip = <&cpu_alert>;
184                                         cooling-device =
185                                                 <&cpu0 THERMAL_NO_LIMIT
186                                                 THERMAL_NO_LIMIT>;
187                                 };
188
189                                 map1 {
190                                         trip = <&cpu_alert>;
191                                         cooling-device =
192                                                 <&cpu4 THERMAL_NO_LIMIT
193                                                 THERMAL_NO_LIMIT>;
194                                 };
195                         };
196                 };
197         };
198
199         timer {
200                 compatible = "arm,armv8-timer";
201                 interrupts = <1 13 IRQ_TYPE_LEVEL_LOW>,/* Physical Secure PPI */
202                              <1 14 IRQ_TYPE_LEVEL_LOW>,/* Physical Non-Secure PPI */
203                              <1 11 IRQ_TYPE_LEVEL_LOW>,/* Virtual PPI */
204                              <1 10 IRQ_TYPE_LEVEL_LOW>;/* Hypervisor PPI */
205         };
206
207         fsl_mc: fsl-mc@80c000000 {
208                 compatible = "fsl,qoriq-mc";
209                 reg = <0x00000008 0x0c000000 0 0x40>,    /* MC portal base */
210                       <0x00000000 0x08340000 0 0x40000>; /* MC control reg */
211                 msi-parent = <&its>;
212                 #address-cells = <3>;
213                 #size-cells = <1>;
214
215                 /*
216                  * Region type 0x0 - MC portals
217                  * Region type 0x1 - QBMAN portals
218                  */
219                 ranges = <0x0 0x0 0x0 0x8 0x0c000000 0x4000000
220                           0x1 0x0 0x0 0x8 0x18000000 0x8000000>;
221
222                 dpmacs {
223                         #address-cells = <1>;
224                         #size-cells = <0>;
225
226                         dpmac1: dpmac@1 {
227                                 compatible = "fsl,qoriq-mc-dpmac";
228                                 reg = <1>;
229                         };
230
231                         dpmac2: dpmac@2 {
232                                 compatible = "fsl,qoriq-mc-dpmac";
233                                 reg = <2>;
234                         };
235
236                         dpmac3: dpmac@3 {
237                                 compatible = "fsl,qoriq-mc-dpmac";
238                                 reg = <3>;
239                         };
240
241                         dpmac4: dpmac@4 {
242                                 compatible = "fsl,qoriq-mc-dpmac";
243                                 reg = <4>;
244                         };
245
246                         dpmac5: dpmac@5 {
247                                 compatible = "fsl,qoriq-mc-dpmac";
248                                 reg = <5>;
249                         };
250
251                         dpmac6: dpmac@6 {
252                                 compatible = "fsl,qoriq-mc-dpmac";
253                                 reg = <6>;
254                         };
255
256                         dpmac7: dpmac@7 {
257                                 compatible = "fsl,qoriq-mc-dpmac";
258                                 reg = <7>;
259                         };
260
261                         dpmac8: dpmac@8 {
262                                 compatible = "fsl,qoriq-mc-dpmac";
263                                 reg = <8>;
264                         };
265
266                         dpmac9: dpmac@9 {
267                                 compatible = "fsl,qoriq-mc-dpmac";
268                                 reg = <9>;
269                         };
270
271                         dpmac10: dpmac@a {
272                                 compatible = "fsl,qoriq-mc-dpmac";
273                                 reg = <0xa>;
274                         };
275                 };
276         };
277
278         psci {
279                 compatible = "arm,psci-0.2";
280                 method = "smc";
281         };
282
283         sysclk: sysclk {
284                 compatible = "fixed-clock";
285                 #clock-cells = <0>;
286                 clock-frequency = <100000000>;
287                 clock-output-names = "sysclk";
288         };
289
290         soc {
291                 compatible = "simple-bus";
292                 #address-cells = <2>;
293                 #size-cells = <2>;
294                 ranges;
295
296                 clockgen: clocking@1300000 {
297                         compatible = "fsl,ls1088a-clockgen";
298                         reg = <0 0x1300000 0 0xa0000>;
299                         #clock-cells = <2>;
300                         clocks = <&sysclk>;
301                 };
302
303                 dcfg: dcfg@1e00000 {
304                         compatible = "fsl,ls1088a-dcfg", "syscon";
305                         reg = <0x0 0x1e00000 0x0 0x10000>;
306                         little-endian;
307                 };
308
309                 tmu: tmu@1f80000 {
310                         compatible = "fsl,qoriq-tmu";
311                         reg = <0x0 0x1f80000 0x0 0x10000>;
312                         interrupts = <0 23 0x4>;
313                         fsl,tmu-range = <0xb0000 0x9002a 0x6004c 0x30062>;
314                         fsl,tmu-calibration =
315                                 /* Calibration data group 1 */
316                                 <0x00000000 0x00000026
317                                 0x00000001 0x0000002d
318                                 0x00000002 0x00000032
319                                 0x00000003 0x00000039
320                                 0x00000004 0x0000003f
321                                 0x00000005 0x00000046
322                                 0x00000006 0x0000004d
323                                 0x00000007 0x00000054
324                                 0x00000008 0x0000005a
325                                 0x00000009 0x00000061
326                                 0x0000000a 0x0000006a
327                                 0x0000000b 0x00000071
328                                 /* Calibration data group 2 */
329                                 0x00010000 0x00000025
330                                 0x00010001 0x0000002c
331                                 0x00010002 0x00000035
332                                 0x00010003 0x0000003d
333                                 0x00010004 0x00000045
334                                 0x00010005 0x0000004e
335                                 0x00010006 0x00000057
336                                 0x00010007 0x00000061
337                                 0x00010008 0x0000006b
338                                 0x00010009 0x00000076
339                                 /* Calibration data group 3 */
340                                 0x00020000 0x00000029
341                                 0x00020001 0x00000033
342                                 0x00020002 0x0000003d
343                                 0x00020003 0x00000049
344                                 0x00020004 0x00000056
345                                 0x00020005 0x00000061
346                                 0x00020006 0x0000006d
347                                 /* Calibration data group 4 */
348                                 0x00030000 0x00000021
349                                 0x00030001 0x0000002a
350                                 0x00030002 0x0000003c
351                                 0x00030003 0x0000004e>;
352                         little-endian;
353                         #thermal-sensor-cells = <1>;
354                 };
355
356                 duart0: serial@21c0500 {
357                         compatible = "fsl,ns16550", "ns16550a";
358                         reg = <0x0 0x21c0500 0x0 0x100>;
359                         clocks = <&clockgen 4 3>;
360                         interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>;
361                         status = "disabled";
362                 };
363
364                 duart1: serial@21c0600 {
365                         compatible = "fsl,ns16550", "ns16550a";
366                         reg = <0x0 0x21c0600 0x0 0x100>;
367                         clocks = <&clockgen 4 3>;
368                         interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>;
369                         status = "disabled";
370                 };
371
372                 gpio0: gpio@2300000 {
373                         compatible = "fsl,qoriq-gpio";
374                         reg = <0x0 0x2300000 0x0 0x10000>;
375                         interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>;
376                         gpio-controller;
377                         #gpio-cells = <2>;
378                         interrupt-controller;
379                         #interrupt-cells = <2>;
380                 };
381
382                 gpio1: gpio@2310000 {
383                         compatible = "fsl,qoriq-gpio";
384                         reg = <0x0 0x2310000 0x0 0x10000>;
385                         interrupts = <0 36 IRQ_TYPE_LEVEL_HIGH>;
386                         gpio-controller;
387                         #gpio-cells = <2>;
388                         interrupt-controller;
389                         #interrupt-cells = <2>;
390                 };
391
392                 gpio2: gpio@2320000 {
393                         compatible = "fsl,qoriq-gpio";
394                         reg = <0x0 0x2320000 0x0 0x10000>;
395                         interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>;
396                         gpio-controller;
397                         #gpio-cells = <2>;
398                         interrupt-controller;
399                         #interrupt-cells = <2>;
400                 };
401
402                 gpio3: gpio@2330000 {
403                         compatible = "fsl,qoriq-gpio";
404                         reg = <0x0 0x2330000 0x0 0x10000>;
405                         interrupts = <0 37 IRQ_TYPE_LEVEL_HIGH>;
406                         gpio-controller;
407                         #gpio-cells = <2>;
408                         interrupt-controller;
409                         #interrupt-cells = <2>;
410                 };
411
412                 ifc: ifc@2240000 {
413                         compatible = "fsl,ifc", "simple-bus";
414                         reg = <0x0 0x2240000 0x0 0x20000>;
415                         interrupts = <0 21 IRQ_TYPE_LEVEL_HIGH>;
416                         little-endian;
417                         #address-cells = <2>;
418                         #size-cells = <1>;
419                         status = "disabled";
420                 };
421
422                 i2c0: i2c@2000000 {
423                         compatible = "fsl,vf610-i2c";
424                         #address-cells = <1>;
425                         #size-cells = <0>;
426                         reg = <0x0 0x2000000 0x0 0x10000>;
427                         interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>;
428                         clocks = <&clockgen 4 3>;
429                         status = "disabled";
430                 };
431
432                 i2c1: i2c@2010000 {
433                         compatible = "fsl,vf610-i2c";
434                         #address-cells = <1>;
435                         #size-cells = <0>;
436                         reg = <0x0 0x2010000 0x0 0x10000>;
437                         interrupts = <0 34 IRQ_TYPE_LEVEL_HIGH>;
438                         clocks = <&clockgen 4 3>;
439                         status = "disabled";
440                 };
441
442                 i2c2: i2c@2020000 {
443                         compatible = "fsl,vf610-i2c";
444                         #address-cells = <1>;
445                         #size-cells = <0>;
446                         reg = <0x0 0x2020000 0x0 0x10000>;
447                         interrupts = <0 35 IRQ_TYPE_LEVEL_HIGH>;
448                         clocks = <&clockgen 4 3>;
449                         status = "disabled";
450                 };
451
452                 i2c3: i2c@2030000 {
453                         compatible = "fsl,vf610-i2c";
454                         #address-cells = <1>;
455                         #size-cells = <0>;
456                         reg = <0x0 0x2030000 0x0 0x10000>;
457                         interrupts = <0 35 IRQ_TYPE_LEVEL_HIGH>;
458                         clocks = <&clockgen 4 3>;
459                         status = "disabled";
460                 };
461
462                 esdhc: esdhc@2140000 {
463                         compatible = "fsl,ls1088a-esdhc", "fsl,esdhc";
464                         reg = <0x0 0x2140000 0x0 0x10000>;
465                         interrupts = <0 28 0x4>; /* Level high type */
466                         clock-frequency = <0>;
467                         voltage-ranges = <1800 1800 3300 3300>;
468                         sdhci,auto-cmd12;
469                         little-endian;
470                         bus-width = <4>;
471                         status = "disabled";
472                 };
473
474                 usb0: usb3@3100000 {
475                         compatible = "snps,dwc3";
476                         reg = <0x0 0x3100000 0x0 0x10000>;
477                         interrupts = <0 80 IRQ_TYPE_LEVEL_HIGH>;
478                         dr_mode = "host";
479                         snps,quirk-frame-length-adjustment = <0x20>;
480                         snps,dis_rxdet_inp3_quirk;
481                         status = "disabled";
482                 };
483
484                 usb1: usb3@3110000 {
485                         compatible = "snps,dwc3";
486                         reg = <0x0 0x3110000 0x0 0x10000>;
487                         interrupts = <0 81 IRQ_TYPE_LEVEL_HIGH>;
488                         dr_mode = "host";
489                         snps,quirk-frame-length-adjustment = <0x20>;
490                         snps,dis_rxdet_inp3_quirk;
491                         status = "disabled";
492                 };
493
494                 sata: sata@3200000 {
495                         compatible = "fsl,ls1088a-ahci";
496                         reg = <0x0 0x3200000 0x0 0x10000>,
497                                 <0x7 0x100520 0x0 0x4>;
498                         reg-names = "ahci", "sata-ecc";
499                         interrupts = <0 133 IRQ_TYPE_LEVEL_HIGH>;
500                         clocks = <&clockgen 4 3>;
501                         dma-coherent;
502                         status = "disabled";
503                 };
504
505                 crypto: crypto@8000000 {
506                         compatible = "fsl,sec-v5.0", "fsl,sec-v4.0";
507                         fsl,sec-era = <8>;
508                         #address-cells = <1>;
509                         #size-cells = <1>;
510                         ranges = <0x0 0x00 0x8000000 0x100000>;
511                         reg = <0x00 0x8000000 0x0 0x100000>;
512                         interrupts = <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>;
513                         dma-coherent;
514
515                         sec_jr0: jr@10000 {
516                                 compatible = "fsl,sec-v5.0-job-ring",
517                                              "fsl,sec-v4.0-job-ring";
518                                 reg        = <0x10000 0x10000>;
519                                 interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>;
520                         };
521
522                         sec_jr1: jr@20000 {
523                                 compatible = "fsl,sec-v5.0-job-ring",
524                                              "fsl,sec-v4.0-job-ring";
525                                 reg        = <0x20000 0x10000>;
526                                 interrupts = <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>;
527                         };
528
529                         sec_jr2: jr@30000 {
530                                 compatible = "fsl,sec-v5.0-job-ring",
531                                              "fsl,sec-v4.0-job-ring";
532                                 reg        = <0x30000 0x10000>;
533                                 interrupts = <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>;
534                         };
535
536                         sec_jr3: jr@40000 {
537                                 compatible = "fsl,sec-v5.0-job-ring",
538                                              "fsl,sec-v4.0-job-ring";
539                                 reg        = <0x40000 0x10000>;
540                                 interrupts = <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
541                         };
542                 };
543
544                 pcie@3400000 {
545                         compatible = "fsl,ls1088a-pcie", "snps,dw-pcie";
546                         reg = <0x00 0x03400000 0x0 0x00100000   /* controller registers */
547                                0x20 0x00000000 0x0 0x00002000>; /* configuration space */
548                         reg-names = "regs", "config";
549                         interrupts = <0 108 IRQ_TYPE_LEVEL_HIGH>; /* aer interrupt */
550                         interrupt-names = "aer";
551                         #address-cells = <3>;
552                         #size-cells = <2>;
553                         device_type = "pci";
554                         dma-coherent;
555                         num-lanes = <4>;
556                         bus-range = <0x0 0xff>;
557                         ranges = <0x81000000 0x0 0x00000000 0x20 0x00010000 0x0 0x00010000   /* downstream I/O */
558                                   0x82000000 0x0 0x40000000 0x20 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
559                         msi-parent = <&its>;
560                         #interrupt-cells = <1>;
561                         interrupt-map-mask = <0 0 0 7>;
562                         interrupt-map = <0000 0 0 1 &gic 0 0 0 109 IRQ_TYPE_LEVEL_HIGH>,
563                                         <0000 0 0 2 &gic 0 0 0 110 IRQ_TYPE_LEVEL_HIGH>,
564                                         <0000 0 0 3 &gic 0 0 0 111 IRQ_TYPE_LEVEL_HIGH>,
565                                         <0000 0 0 4 &gic 0 0 0 112 IRQ_TYPE_LEVEL_HIGH>;
566                 };
567
568                 pcie@3500000 {
569                         compatible = "fsl,ls1088a-pcie", "snps,dw-pcie";
570                         reg = <0x00 0x03500000 0x0 0x00100000   /* controller registers */
571                                0x28 0x00000000 0x0 0x00002000>; /* configuration space */
572                         reg-names = "regs", "config";
573                         interrupts = <0 113 IRQ_TYPE_LEVEL_HIGH>; /* aer interrupt */
574                         interrupt-names = "aer";
575                         #address-cells = <3>;
576                         #size-cells = <2>;
577                         device_type = "pci";
578                         dma-coherent;
579                         num-lanes = <4>;
580                         bus-range = <0x0 0xff>;
581                         ranges = <0x81000000 0x0 0x00000000 0x28 0x00010000 0x0 0x00010000   /* downstream I/O */
582                                   0x82000000 0x0 0x40000000 0x28 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
583                         msi-parent = <&its>;
584                         #interrupt-cells = <1>;
585                         interrupt-map-mask = <0 0 0 7>;
586                         interrupt-map = <0000 0 0 1 &gic 0 0 0 114 IRQ_TYPE_LEVEL_HIGH>,
587                                         <0000 0 0 2 &gic 0 0 0 115 IRQ_TYPE_LEVEL_HIGH>,
588                                         <0000 0 0 3 &gic 0 0 0 116 IRQ_TYPE_LEVEL_HIGH>,
589                                         <0000 0 0 4 &gic 0 0 0 117 IRQ_TYPE_LEVEL_HIGH>;
590                 };
591
592                 pcie@3600000 {
593                         compatible = "fsl,ls1088a-pcie", "snps,dw-pcie";
594                         reg = <0x00 0x03600000 0x0 0x00100000   /* controller registers */
595                                0x30 0x00000000 0x0 0x00002000>; /* configuration space */
596                         reg-names = "regs", "config";
597                         interrupts = <0 118 IRQ_TYPE_LEVEL_HIGH>; /* aer interrupt */
598                         interrupt-names = "aer";
599                         #address-cells = <3>;
600                         #size-cells = <2>;
601                         device_type = "pci";
602                         dma-coherent;
603                         num-lanes = <8>;
604                         bus-range = <0x0 0xff>;
605                         ranges = <0x81000000 0x0 0x00000000 0x30 0x00010000 0x0 0x00010000   /* downstream I/O */
606                                   0x82000000 0x0 0x40000000 0x30 0x40000000 0x0 0x40000000>; /* non-prefetchable memory */
607                         msi-parent = <&its>;
608                         #interrupt-cells = <1>;
609                         interrupt-map-mask = <0 0 0 7>;
610                         interrupt-map = <0000 0 0 1 &gic 0 0 0 119 IRQ_TYPE_LEVEL_HIGH>,
611                                         <0000 0 0 2 &gic 0 0 0 120 IRQ_TYPE_LEVEL_HIGH>,
612                                         <0000 0 0 3 &gic 0 0 0 121 IRQ_TYPE_LEVEL_HIGH>,
613                                         <0000 0 0 4 &gic 0 0 0 122 IRQ_TYPE_LEVEL_HIGH>;
614                 };
615
616                 cluster1_core0_watchdog: wdt@c000000 {
617                         compatible = "arm,sp805-wdt", "arm,primecell";
618                         reg = <0x0 0xc000000 0x0 0x1000>;
619                         clocks = <&clockgen 4 3>, <&clockgen 4 3>;
620                         clock-names = "apb_pclk", "wdog_clk";
621                 };
622
623                 cluster1_core1_watchdog: wdt@c010000 {
624                         compatible = "arm,sp805-wdt", "arm,primecell";
625                         reg = <0x0 0xc010000 0x0 0x1000>;
626                         clocks = <&clockgen 4 3>, <&clockgen 4 3>;
627                         clock-names = "apb_pclk", "wdog_clk";
628                 };
629
630                 cluster1_core2_watchdog: wdt@c020000 {
631                         compatible = "arm,sp805-wdt", "arm,primecell";
632                         reg = <0x0 0xc020000 0x0 0x1000>;
633                         clocks = <&clockgen 4 3>, <&clockgen 4 3>;
634                         clock-names = "apb_pclk", "wdog_clk";
635                 };
636
637                 cluster1_core3_watchdog: wdt@c030000 {
638                         compatible = "arm,sp805-wdt", "arm,primecell";
639                         reg = <0x0 0xc030000 0x0 0x1000>;
640                         clocks = <&clockgen 4 3>, <&clockgen 4 3>;
641                         clock-names = "apb_pclk", "wdog_clk";
642                 };
643
644                 cluster2_core0_watchdog: wdt@c100000 {
645                         compatible = "arm,sp805-wdt", "arm,primecell";
646                         reg = <0x0 0xc100000 0x0 0x1000>;
647                         clocks = <&clockgen 4 3>, <&clockgen 4 3>;
648                         clock-names = "apb_pclk", "wdog_clk";
649                 };
650
651                 cluster2_core1_watchdog: wdt@c110000 {
652                         compatible = "arm,sp805-wdt", "arm,primecell";
653                         reg = <0x0 0xc110000 0x0 0x1000>;
654                         clocks = <&clockgen 4 3>, <&clockgen 4 3>;
655                         clock-names = "apb_pclk", "wdog_clk";
656                 };
657
658                 cluster2_core2_watchdog: wdt@c120000 {
659                         compatible = "arm,sp805-wdt", "arm,primecell";
660                         reg = <0x0 0xc120000 0x0 0x1000>;
661                         clocks = <&clockgen 4 3>, <&clockgen 4 3>;
662                         clock-names = "apb_pclk", "wdog_clk";
663                 };
664
665                 cluster2_core3_watchdog: wdt@c130000 {
666                         compatible = "arm,sp805-wdt", "arm,primecell";
667                         reg = <0x0 0xc130000 0x0 0x1000>;
668                         clocks = <&clockgen 4 3>, <&clockgen 4 3>;
669                         clock-names = "apb_pclk", "wdog_clk";
670                 };
671         };
672
673         firmware {
674                 optee {
675                         compatible = "linaro,optee-tz";
676                         method = "smc";
677                 };
678         };
679
680 };