1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2/*
3 * Copyright (C) 2016 Marvell Technology Group Ltd.
4 *
5 * Device Tree file for Marvell Armada CP11x.
6 */
7
8#include <dt-bindings/interrupt-controller/mvebu-icu.h>
9#include <dt-bindings/thermal/thermal.h>
10
11#include "armada-common.dtsi"
12
13#define CP11X_PCIEx_CONF_BASE(iface)	(CP11X_PCIEx_MEM_BASE(iface) + CP11X_PCIEx_MEM_SIZE(iface))
14
15/ {
16	/*
17	 * The contents of the node are defined below, in order to
18	 * save one indentation level
19	 */
20	CP11X_NAME: CP11X_NAME { };
21
22	/*
23	 * CPs only have one sensor in the thermal IC.
24	 *
25	 * The cooling maps are empty as there are no cooling devices.
26	 */
27	thermal-zones {
28		CP11X_LABEL(thermal_ic): CP11X_NODE_NAME(ic-thermal) {
29			polling-delay-passive = <0>; /* Interrupt driven */
30			polling-delay = <0>; /* Interrupt driven */
31
32			thermal-sensors = <&CP11X_LABEL(thermal) 0>;
33
34			trips {
35				CP11X_LABEL(crit): crit {
36					temperature = <100000>; /* mC degrees */
37					hysteresis = <2000>; /* mC degrees */
38					type = "critical";
39				};
40			};
41
42			cooling-maps { };
43		};
44	};
45};
46
47&CP11X_NAME {
48	#address-cells = <2>;
49	#size-cells = <2>;
50	compatible = "simple-bus";
51	interrupt-parent = <&CP11X_LABEL(icu_nsr)>;
52	ranges;
53
54	config-space@CP11X_BASE {
55		#address-cells = <1>;
56		#size-cells = <1>;
57		compatible = "simple-bus";
58		ranges = <0x0 0x0 ADDRESSIFY(CP11X_BASE) 0x2000000>;
59
60		CP11X_LABEL(ethernet): ethernet@0 {
61			#address-cells = <1>;
62			#size-cells = <0>;
63			compatible = "marvell,armada-7k-pp22";
64			reg = <0x0 0x100000>, <0x129000 0xb000>, <0x220000 0x800>;
65			clocks = <&CP11X_LABEL(clk) 1 3>, <&CP11X_LABEL(clk) 1 9>,
66				 <&CP11X_LABEL(clk) 1 5>, <&CP11X_LABEL(clk) 1 6>,
67				 <&CP11X_LABEL(clk) 1 18>;
68			clock-names = "pp_clk", "gop_clk",
69				      "mg_clk", "mg_core_clk", "axi_clk";
70			marvell,system-controller = <&CP11X_LABEL(syscon0)>;
71			status = "disabled";
72			dma-coherent;
73
74			CP11X_LABEL(eth0): ethernet-port@0 {
75				interrupts = <39 IRQ_TYPE_LEVEL_HIGH>,
76					<43 IRQ_TYPE_LEVEL_HIGH>,
77					<47 IRQ_TYPE_LEVEL_HIGH>,
78					<51 IRQ_TYPE_LEVEL_HIGH>,
79					<55 IRQ_TYPE_LEVEL_HIGH>,
80					<59 IRQ_TYPE_LEVEL_HIGH>,
81					<63 IRQ_TYPE_LEVEL_HIGH>,
82					<67 IRQ_TYPE_LEVEL_HIGH>,
83					<71 IRQ_TYPE_LEVEL_HIGH>,
84					<129 IRQ_TYPE_LEVEL_HIGH>;
85				interrupt-names = "hif0", "hif1", "hif2",
86					"hif3", "hif4", "hif5", "hif6", "hif7",
87					"hif8", "link";
88				reg = <0>;
89				port-id = <0>; /* For backward compatibility. */
90				gop-port-id = <0>;
91				status = "disabled";
92			};
93
94			CP11X_LABEL(eth1): ethernet-port@1 {
95				interrupts = <40 IRQ_TYPE_LEVEL_HIGH>,
96					<44 IRQ_TYPE_LEVEL_HIGH>,
97					<48 IRQ_TYPE_LEVEL_HIGH>,
98					<52 IRQ_TYPE_LEVEL_HIGH>,
99					<56 IRQ_TYPE_LEVEL_HIGH>,
100					<60 IRQ_TYPE_LEVEL_HIGH>,
101					<64 IRQ_TYPE_LEVEL_HIGH>,
102					<68 IRQ_TYPE_LEVEL_HIGH>,
103					<72 IRQ_TYPE_LEVEL_HIGH>,
104					<128 IRQ_TYPE_LEVEL_HIGH>;
105				interrupt-names = "hif0", "hif1", "hif2",
106					"hif3", "hif4", "hif5", "hif6", "hif7",
107					"hif8", "link";
108				reg = <1>;
109				port-id = <1>; /* For backward compatibility. */
110				gop-port-id = <2>;
111				status = "disabled";
112			};
113
114			CP11X_LABEL(eth2): ethernet-port@2 {
115				interrupts = <41 IRQ_TYPE_LEVEL_HIGH>,
116					<45 IRQ_TYPE_LEVEL_HIGH>,
117					<49 IRQ_TYPE_LEVEL_HIGH>,
118					<53 IRQ_TYPE_LEVEL_HIGH>,
119					<57 IRQ_TYPE_LEVEL_HIGH>,
120					<61 IRQ_TYPE_LEVEL_HIGH>,
121					<65 IRQ_TYPE_LEVEL_HIGH>,
122					<69 IRQ_TYPE_LEVEL_HIGH>,
123					<73 IRQ_TYPE_LEVEL_HIGH>,
124					<127 IRQ_TYPE_LEVEL_HIGH>;
125				interrupt-names = "hif0", "hif1", "hif2",
126					"hif3", "hif4", "hif5", "hif6", "hif7",
127					"hif8", "link";
128				reg = <2>;
129				port-id = <2>; /* For backward compatibility. */
130				gop-port-id = <3>;
131				status = "disabled";
132			};
133		};
134
135		CP11X_LABEL(comphy): phy@120000 {
136			compatible = "marvell,comphy-cp110";
137			reg = <0x120000 0x6000>;
138			marvell,system-controller = <&CP11X_LABEL(syscon0)>;
139			clocks = <&CP11X_LABEL(clk) 1 5>, <&CP11X_LABEL(clk) 1 6>,
140				 <&CP11X_LABEL(clk) 1 18>;
141			clock-names = "mg_clk", "mg_core_clk", "axi_clk";
142			#address-cells = <1>;
143			#size-cells = <0>;
144
145			CP11X_LABEL(comphy0): phy@0 {
146				reg = <0>;
147				#phy-cells = <1>;
148			};
149
150			CP11X_LABEL(comphy1): phy@1 {
151				reg = <1>;
152				#phy-cells = <1>;
153			};
154
155			CP11X_LABEL(comphy2): phy@2 {
156				reg = <2>;
157				#phy-cells = <1>;
158			};
159
160			CP11X_LABEL(comphy3): phy@3 {
161				reg = <3>;
162				#phy-cells = <1>;
163			};
164
165			CP11X_LABEL(comphy4): phy@4 {
166				reg = <4>;
167				#phy-cells = <1>;
168			};
169
170			CP11X_LABEL(comphy5): phy@5 {
171				reg = <5>;
172				#phy-cells = <1>;
173			};
174		};
175
176		CP11X_LABEL(mdio): mdio@12a200 {
177			#address-cells = <1>;
178			#size-cells = <0>;
179			compatible = "marvell,orion-mdio";
180			reg = <0x12a200 0x10>;
181			clocks = <&CP11X_LABEL(clk) 1 9>, <&CP11X_LABEL(clk) 1 5>,
182				 <&CP11X_LABEL(clk) 1 6>, <&CP11X_LABEL(clk) 1 18>;
183			status = "disabled";
184		};
185
186		CP11X_LABEL(xmdio): mdio@12a600 {
187			#address-cells = <1>;
188			#size-cells = <0>;
189			compatible = "marvell,xmdio";
190			reg = <0x12a600 0x10>;
191			clocks = <&CP11X_LABEL(clk) 1 5>,
192				 <&CP11X_LABEL(clk) 1 6>, <&CP11X_LABEL(clk) 1 18>;
193			status = "disabled";
194		};
195
196		CP11X_LABEL(icu): interrupt-controller@1e0000 {
197			compatible = "marvell,cp110-icu";
198			reg = <0x1e0000 0x440>;
199			#address-cells = <1>;
200			#size-cells = <1>;
201
202			CP11X_LABEL(icu_nsr): interrupt-controller@10 {
203				compatible = "marvell,cp110-icu-nsr";
204				reg = <0x10 0x20>;
205				#interrupt-cells = <2>;
206				interrupt-controller;
207				msi-parent = <&gicp>;
208			};
209
210			CP11X_LABEL(icu_sei): interrupt-controller@50 {
211				compatible = "marvell,cp110-icu-sei";
212				reg = <0x50 0x10>;
213				#interrupt-cells = <2>;
214				interrupt-controller;
215				msi-parent = <&sei>;
216			};
217		};
218
219		CP11X_LABEL(rtc): rtc@284000 {
220			compatible = "marvell,armada-8k-rtc";
221			reg = <0x284000 0x20>, <0x284080 0x24>;
222			reg-names = "rtc", "rtc-soc";
223			interrupts = <77 IRQ_TYPE_LEVEL_HIGH>;
224		};
225
226		CP11X_LABEL(syscon0): system-controller@440000 {
227			compatible = "syscon", "simple-mfd";
228			reg = <0x440000 0x2000>;
229
230			CP11X_LABEL(clk): clock {
231				compatible = "marvell,cp110-clock";
232				#clock-cells = <2>;
233			};
234
235			CP11X_LABEL(gpio1): gpio@100 {
236				compatible = "marvell,armada-8k-gpio";
237				offset = <0x100>;
238				ngpios = <32>;
239				gpio-controller;
240				#gpio-cells = <2>;
241				gpio-ranges = <&CP11X_LABEL(pinctrl) 0 0 32>;
242				marvell,pwm-offset = <0x1f0>;
243				#pwm-cells = <2>;
244				interrupt-controller;
245				interrupts = <86 IRQ_TYPE_LEVEL_HIGH>,
246					<85 IRQ_TYPE_LEVEL_HIGH>,
247					<84 IRQ_TYPE_LEVEL_HIGH>,
248					<83 IRQ_TYPE_LEVEL_HIGH>;
249				#interrupt-cells = <2>;
250				clock-names = "core", "axi";
251				clocks = <&CP11X_LABEL(clk) 1 21>,
252					 <&CP11X_LABEL(clk) 1 17>;
253				status = "disabled";
254			};
255
256			CP11X_LABEL(gpio2): gpio@140 {
257				compatible = "marvell,armada-8k-gpio";
258				offset = <0x140>;
259				ngpios = <31>;
260				gpio-controller;
261				#gpio-cells = <2>;
262				gpio-ranges = <&CP11X_LABEL(pinctrl) 0 32 31>;
263				marvell,pwm-offset = <0x1f0>;
264				#pwm-cells = <2>;
265				interrupt-controller;
266				interrupts = <82 IRQ_TYPE_LEVEL_HIGH>,
267					<81 IRQ_TYPE_LEVEL_HIGH>,
268					<80 IRQ_TYPE_LEVEL_HIGH>,
269					<79 IRQ_TYPE_LEVEL_HIGH>;
270				#interrupt-cells = <2>;
271				clock-names = "core", "axi";
272				clocks = <&CP11X_LABEL(clk) 1 21>,
273					 <&CP11X_LABEL(clk) 1 17>;
274				status = "disabled";
275			};
276		};
277
278		CP11X_LABEL(syscon1): system-controller@400000 {
279			compatible = "syscon", "simple-mfd";
280			reg = <0x400000 0x1000>;
281			#address-cells = <1>;
282			#size-cells = <1>;
283
284			CP11X_LABEL(thermal): thermal-sensor@70 {
285				compatible = "marvell,armada-cp110-thermal";
286				reg = <0x70 0x10>;
287				interrupts-extended =
288					<&CP11X_LABEL(icu_sei) 116 IRQ_TYPE_LEVEL_HIGH>;
289				#thermal-sensor-cells = <1>;
290			};
291		};
292
293		CP11X_LABEL(utmi): utmi@580000 {
294			compatible = "marvell,cp110-utmi-phy";
295			reg = <0x580000 0x2000>;
296			marvell,system-controller = <&CP11X_LABEL(syscon0)>;
297			#address-cells = <1>;
298			#size-cells = <0>;
299			status = "disabled";
300
301			CP11X_LABEL(utmi0): usb-phy@0 {
302				reg = <0>;
303				#phy-cells = <0>;
304			};
305
306			CP11X_LABEL(utmi1): usb-phy@1 {
307				reg = <1>;
308				#phy-cells = <0>;
309			};
310		};
311
312		CP11X_LABEL(usb3_0): usb@500000 {
313			compatible = "marvell,armada-8k-xhci",
314			"generic-xhci";
315			reg = <0x500000 0x4000>;
316			dma-coherent;
317			interrupts = <106 IRQ_TYPE_LEVEL_HIGH>;
318			clock-names = "core", "reg";
319			clocks = <&CP11X_LABEL(clk) 1 22>,
320				 <&CP11X_LABEL(clk) 1 16>;
321			status = "disabled";
322		};
323
324		CP11X_LABEL(usb3_1): usb@510000 {
325			compatible = "marvell,armada-8k-xhci",
326			"generic-xhci";
327			reg = <0x510000 0x4000>;
328			dma-coherent;
329			interrupts = <105 IRQ_TYPE_LEVEL_HIGH>;
330			clock-names = "core", "reg";
331			clocks = <&CP11X_LABEL(clk) 1 23>,
332				 <&CP11X_LABEL(clk) 1 16>;
333			status = "disabled";
334		};
335
336		CP11X_LABEL(sata0): sata@540000 {
337			compatible = "marvell,armada-8k-ahci",
338			"generic-ahci";
339			reg = <0x540000 0x30000>;
340			dma-coherent;
341			interrupts = <107 IRQ_TYPE_LEVEL_HIGH>;
342			clocks = <&CP11X_LABEL(clk) 1 15>,
343				 <&CP11X_LABEL(clk) 1 16>;
344			#address-cells = <1>;
345			#size-cells = <0>;
346			status = "disabled";
347
348			sata-port@0 {
349				reg = <0>;
350				status = "disabled";
351			};
352
353			sata-port@1 {
354				reg = <1>;
355				status = "disabled";
356			};
357		};
358
359		CP11X_LABEL(xor0): xor@6a0000 {
360			compatible = "marvell,armada-7k-xor", "marvell,xor-v2";
361			reg = <0x6a0000 0x1000>, <0x6b0000 0x1000>;
362			dma-coherent;
363			msi-parent = <&gic_v2m0>;
364			clock-names = "core", "reg";
365			clocks = <&CP11X_LABEL(clk) 1 8>,
366				 <&CP11X_LABEL(clk) 1 14>;
367		};
368
369		CP11X_LABEL(xor1): xor@6c0000 {
370			compatible = "marvell,armada-7k-xor", "marvell,xor-v2";
371			reg = <0x6c0000 0x1000>, <0x6d0000 0x1000>;
372			dma-coherent;
373			msi-parent = <&gic_v2m0>;
374			clock-names = "core", "reg";
375			clocks = <&CP11X_LABEL(clk) 1 7>,
376				 <&CP11X_LABEL(clk) 1 14>;
377		};
378
379		CP11X_LABEL(spi0): spi@700600 {
380			compatible = "marvell,armada-380-spi";
381			reg = <0x700600 0x50>;
382			#address-cells = <0x1>;
383			#size-cells = <0x0>;
384			clock-names = "core", "axi";
385			clocks = <&CP11X_LABEL(clk) 1 21>,
386				 <&CP11X_LABEL(clk) 1 17>;
387			status = "disabled";
388		};
389
390		CP11X_LABEL(spi1): spi@700680 {
391			compatible = "marvell,armada-380-spi";
392			reg = <0x700680 0x50>;
393			#address-cells = <1>;
394			#size-cells = <0>;
395			clock-names = "core", "axi";
396			clocks = <&CP11X_LABEL(clk) 1 21>,
397				 <&CP11X_LABEL(clk) 1 17>;
398			status = "disabled";
399		};
400
401		CP11X_LABEL(i2c0): i2c@701000 {
402			compatible = "marvell,mv78230-i2c";
403			reg = <0x701000 0x20>;
404			#address-cells = <1>;
405			#size-cells = <0>;
406			interrupts = <120 IRQ_TYPE_LEVEL_HIGH>;
407			clock-names = "core", "reg";
408			clocks = <&CP11X_LABEL(clk) 1 21>,
409				 <&CP11X_LABEL(clk) 1 17>;
410			status = "disabled";
411		};
412
413		CP11X_LABEL(i2c1): i2c@701100 {
414			compatible = "marvell,mv78230-i2c";
415			reg = <0x701100 0x20>;
416			#address-cells = <1>;
417			#size-cells = <0>;
418			interrupts = <121 IRQ_TYPE_LEVEL_HIGH>;
419			clock-names = "core", "reg";
420			clocks = <&CP11X_LABEL(clk) 1 21>,
421				 <&CP11X_LABEL(clk) 1 17>;
422			status = "disabled";
423		};
424
425		CP11X_LABEL(uart0): serial@702000 {
426			compatible = "snps,dw-apb-uart";
427			reg = <0x702000 0x100>;
428			reg-shift = <2>;
429			interrupts = <122 IRQ_TYPE_LEVEL_HIGH>;
430			reg-io-width = <1>;
431			clock-names = "baudclk", "apb_pclk";
432			clocks = <&CP11X_LABEL(clk) 1 21>,
433				 <&CP11X_LABEL(clk) 1 17>;
434			status = "disabled";
435		};
436
437		CP11X_LABEL(uart1): serial@702100 {
438			compatible = "snps,dw-apb-uart";
439			reg = <0x702100 0x100>;
440			reg-shift = <2>;
441			interrupts = <123 IRQ_TYPE_LEVEL_HIGH>;
442			reg-io-width = <1>;
443			clock-names = "baudclk", "apb_pclk";
444			clocks = <&CP11X_LABEL(clk) 1 21>,
445				 <&CP11X_LABEL(clk) 1 17>;
446			status = "disabled";
447		};
448
449		CP11X_LABEL(uart2): serial@702200 {
450			compatible = "snps,dw-apb-uart";
451			reg = <0x702200 0x100>;
452			reg-shift = <2>;
453			interrupts = <124 IRQ_TYPE_LEVEL_HIGH>;
454			reg-io-width = <1>;
455			clock-names = "baudclk", "apb_pclk";
456			clocks = <&CP11X_LABEL(clk) 1 21>,
457				 <&CP11X_LABEL(clk) 1 17>;
458			status = "disabled";
459		};
460
461		CP11X_LABEL(uart3): serial@702300 {
462			compatible = "snps,dw-apb-uart";
463			reg = <0x702300 0x100>;
464			reg-shift = <2>;
465			interrupts = <125 IRQ_TYPE_LEVEL_HIGH>;
466			reg-io-width = <1>;
467			clock-names = "baudclk", "apb_pclk";
468			clocks = <&CP11X_LABEL(clk) 1 21>,
469				 <&CP11X_LABEL(clk) 1 17>;
470			status = "disabled";
471		};
472
473		CP11X_LABEL(nand_controller): nand-controller@720000 {
474			/*
475			 * Due to the limitation of the pins available
476			 * this controller is only usable on the CPM
477			 * for A7K and on the CPS for A8K.
478			 */
479			compatible = "marvell,armada-8k-nand-controller",
480				"marvell,armada370-nand-controller";
481			reg = <0x720000 0x54>;
482			#address-cells = <1>;
483			#size-cells = <0>;
484			interrupts = <115 IRQ_TYPE_LEVEL_HIGH>;
485			clock-names = "core", "reg";
486			clocks = <&CP11X_LABEL(clk) 1 2>,
487				 <&CP11X_LABEL(clk) 1 17>;
488			marvell,system-controller = <&CP11X_LABEL(syscon0)>;
489			status = "disabled";
490		};
491
492		CP11X_LABEL(trng): trng@760000 {
493			compatible = "marvell,armada-8k-rng",
494			"inside-secure,safexcel-eip76";
495			reg = <0x760000 0x7d>;
496			interrupts = <95 IRQ_TYPE_LEVEL_HIGH>;
497			clock-names = "core", "reg";
498			clocks = <&CP11X_LABEL(clk) 1 25>,
499				 <&CP11X_LABEL(clk) 1 17>;
500			status = "okay";
501		};
502
503		CP11X_LABEL(sdhci0): mmc@780000 {
504			compatible = "marvell,armada-cp110-sdhci";
505			reg = <0x780000 0x300>;
506			interrupts = <27 IRQ_TYPE_LEVEL_HIGH>;
507			clock-names = "core", "axi";
508			clocks = <&CP11X_LABEL(clk) 1 4>, <&CP11X_LABEL(clk) 1 18>;
509			dma-coherent;
510			status = "disabled";
511		};
512
513		CP11X_LABEL(crypto): crypto@800000 {
514			compatible = "inside-secure,safexcel-eip197b";
515			reg = <0x800000 0x200000>;
516			interrupts = <88 IRQ_TYPE_LEVEL_HIGH>,
517				<89 IRQ_TYPE_LEVEL_HIGH>,
518				<90 IRQ_TYPE_LEVEL_HIGH>,
519				<91 IRQ_TYPE_LEVEL_HIGH>,
520				<92 IRQ_TYPE_LEVEL_HIGH>,
521				<87 IRQ_TYPE_LEVEL_HIGH>;
522			interrupt-names = "ring0", "ring1", "ring2", "ring3",
523					  "eip", "mem";
524			clock-names = "core", "reg";
525			clocks = <&CP11X_LABEL(clk) 1 26>,
526				 <&CP11X_LABEL(clk) 1 17>;
527			dma-coherent;
528		};
529	};
530
531	CP11X_LABEL(pcie0): pcie@CP11X_PCIE0_BASE {
532		compatible = "marvell,armada8k-pcie", "snps,dw-pcie";
533		reg = <0 ADDRESSIFY(CP11X_PCIE0_BASE) 0 0x10000>,
534		      <0 CP11X_PCIEx_CONF_BASE(0) 0 0x80000>;
535		reg-names = "ctrl", "config";
536		#address-cells = <3>;
537		#size-cells = <2>;
538		#interrupt-cells = <1>;
539		device_type = "pci";
540		dma-coherent;
541		msi-parent = <&gic_v2m0>;
542
543		bus-range = <0 0xff>;
544		/* non-prefetchable memory */
545		ranges = <0x82000000 0 CP11X_PCIEx_MEM_BASE(0) 0  CP11X_PCIEx_MEM_BASE(0) 0 CP11X_PCIEx_MEM_SIZE(0)>;
546		interrupt-map-mask = <0 0 0 0>;
547		interrupt-map = <0 0 0 0 &CP11X_LABEL(icu_nsr) 22 IRQ_TYPE_LEVEL_HIGH>;
548		interrupts = <22 IRQ_TYPE_LEVEL_HIGH>;
549		num-lanes = <1>;
550		clock-names = "core", "reg";
551		clocks = <&CP11X_LABEL(clk) 1 13>, <&CP11X_LABEL(clk) 1 14>;
552		status = "disabled";
553	};
554
555	CP11X_LABEL(pcie1): pcie@CP11X_PCIE1_BASE {
556		compatible = "marvell,armada8k-pcie", "snps,dw-pcie";
557		reg = <0 ADDRESSIFY(CP11X_PCIE1_BASE) 0 0x10000>,
558		      <0 CP11X_PCIEx_CONF_BASE(1) 0 0x80000>;
559		reg-names = "ctrl", "config";
560		#address-cells = <3>;
561		#size-cells = <2>;
562		#interrupt-cells = <1>;
563		device_type = "pci";
564		dma-coherent;
565		msi-parent = <&gic_v2m0>;
566
567		bus-range = <0 0xff>;
568		/* non-prefetchable memory */
569		ranges = <0x82000000 0 CP11X_PCIEx_MEM_BASE(1) 0  CP11X_PCIEx_MEM_BASE(1) 0 CP11X_PCIEx_MEM_SIZE(1)>;
570		interrupt-map-mask = <0 0 0 0>;
571		interrupt-map = <0 0 0 0 &CP11X_LABEL(icu_nsr) 24 IRQ_TYPE_LEVEL_HIGH>;
572		interrupts = <24 IRQ_TYPE_LEVEL_HIGH>;
573
574		num-lanes = <1>;
575		clock-names = "core", "reg";
576		clocks = <&CP11X_LABEL(clk) 1 11>, <&CP11X_LABEL(clk) 1 14>;
577		status = "disabled";
578	};
579
580	CP11X_LABEL(pcie2): pcie@CP11X_PCIE2_BASE {
581		compatible = "marvell,armada8k-pcie", "snps,dw-pcie";
582		reg = <0 ADDRESSIFY(CP11X_PCIE2_BASE) 0 0x10000>,
583		      <0 CP11X_PCIEx_CONF_BASE(2) 0 0x80000>;
584		reg-names = "ctrl", "config";
585		#address-cells = <3>;
586		#size-cells = <2>;
587		#interrupt-cells = <1>;
588		device_type = "pci";
589		dma-coherent;
590		msi-parent = <&gic_v2m0>;
591
592		bus-range = <0 0xff>;
593		/* non-prefetchable memory */
594		ranges = <0x82000000 0 CP11X_PCIEx_MEM_BASE(2) 0  CP11X_PCIEx_MEM_BASE(2) 0 CP11X_PCIEx_MEM_SIZE(2)>;
595		interrupt-map-mask = <0 0 0 0>;
596		interrupt-map = <0 0 0 0 &CP11X_LABEL(icu_nsr) 23 IRQ_TYPE_LEVEL_HIGH>;
597		interrupts = <23 IRQ_TYPE_LEVEL_HIGH>;
598
599		num-lanes = <1>;
600		clock-names = "core", "reg";
601		clocks = <&CP11X_LABEL(clk) 1 12>, <&CP11X_LABEL(clk) 1 14>;
602		status = "disabled";
603	};
604};
605