xref: /OK3568_Linux_fs/kernel/arch/arm64/boot/dts/hisilicon/hip06.dtsi (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun// SPDX-License-Identifier: GPL-2.0-only
2*4882a593Smuzhiyun/**
3*4882a593Smuzhiyun * dts file for Hisilicon D03 Development Board
4*4882a593Smuzhiyun *
5*4882a593Smuzhiyun * Copyright (C) 2016 Hisilicon Ltd.
6*4882a593Smuzhiyun */
7*4882a593Smuzhiyun
8*4882a593Smuzhiyun#include <dt-bindings/interrupt-controller/arm-gic.h>
9*4882a593Smuzhiyun
10*4882a593Smuzhiyun/ {
11*4882a593Smuzhiyun	compatible = "hisilicon,hip06-d03";
12*4882a593Smuzhiyun	interrupt-parent = <&gic>;
13*4882a593Smuzhiyun	#address-cells = <2>;
14*4882a593Smuzhiyun	#size-cells = <2>;
15*4882a593Smuzhiyun
16*4882a593Smuzhiyun	psci {
17*4882a593Smuzhiyun		compatible = "arm,psci-0.2";
18*4882a593Smuzhiyun		method = "smc";
19*4882a593Smuzhiyun	};
20*4882a593Smuzhiyun
21*4882a593Smuzhiyun	cpus {
22*4882a593Smuzhiyun		#address-cells = <1>;
23*4882a593Smuzhiyun		#size-cells = <0>;
24*4882a593Smuzhiyun
25*4882a593Smuzhiyun		cpu-map {
26*4882a593Smuzhiyun			cluster0 {
27*4882a593Smuzhiyun				core0 {
28*4882a593Smuzhiyun					cpu = <&cpu0>;
29*4882a593Smuzhiyun				};
30*4882a593Smuzhiyun				core1 {
31*4882a593Smuzhiyun					cpu = <&cpu1>;
32*4882a593Smuzhiyun				};
33*4882a593Smuzhiyun				core2 {
34*4882a593Smuzhiyun					cpu = <&cpu2>;
35*4882a593Smuzhiyun				};
36*4882a593Smuzhiyun				core3 {
37*4882a593Smuzhiyun					cpu = <&cpu3>;
38*4882a593Smuzhiyun				};
39*4882a593Smuzhiyun			};
40*4882a593Smuzhiyun			cluster1 {
41*4882a593Smuzhiyun				core0 {
42*4882a593Smuzhiyun					cpu = <&cpu4>;
43*4882a593Smuzhiyun				};
44*4882a593Smuzhiyun				core1 {
45*4882a593Smuzhiyun					cpu = <&cpu5>;
46*4882a593Smuzhiyun				};
47*4882a593Smuzhiyun				core2 {
48*4882a593Smuzhiyun					cpu = <&cpu6>;
49*4882a593Smuzhiyun				};
50*4882a593Smuzhiyun				core3 {
51*4882a593Smuzhiyun					cpu = <&cpu7>;
52*4882a593Smuzhiyun				};
53*4882a593Smuzhiyun			};
54*4882a593Smuzhiyun			cluster2 {
55*4882a593Smuzhiyun				core0 {
56*4882a593Smuzhiyun					cpu = <&cpu8>;
57*4882a593Smuzhiyun				};
58*4882a593Smuzhiyun				core1 {
59*4882a593Smuzhiyun					cpu = <&cpu9>;
60*4882a593Smuzhiyun				};
61*4882a593Smuzhiyun				core2 {
62*4882a593Smuzhiyun					cpu = <&cpu10>;
63*4882a593Smuzhiyun				};
64*4882a593Smuzhiyun				core3 {
65*4882a593Smuzhiyun					cpu = <&cpu11>;
66*4882a593Smuzhiyun				};
67*4882a593Smuzhiyun			};
68*4882a593Smuzhiyun			cluster3 {
69*4882a593Smuzhiyun				core0 {
70*4882a593Smuzhiyun					cpu = <&cpu12>;
71*4882a593Smuzhiyun				};
72*4882a593Smuzhiyun				core1 {
73*4882a593Smuzhiyun					cpu = <&cpu13>;
74*4882a593Smuzhiyun				};
75*4882a593Smuzhiyun				core2 {
76*4882a593Smuzhiyun					cpu = <&cpu14>;
77*4882a593Smuzhiyun				};
78*4882a593Smuzhiyun				core3 {
79*4882a593Smuzhiyun					cpu = <&cpu15>;
80*4882a593Smuzhiyun				};
81*4882a593Smuzhiyun			};
82*4882a593Smuzhiyun		};
83*4882a593Smuzhiyun
84*4882a593Smuzhiyun		cpu0: cpu@10000 {
85*4882a593Smuzhiyun			device_type = "cpu";
86*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
87*4882a593Smuzhiyun			reg = <0x10000>;
88*4882a593Smuzhiyun			enable-method = "psci";
89*4882a593Smuzhiyun			next-level-cache = <&cluster0_l2>;
90*4882a593Smuzhiyun		};
91*4882a593Smuzhiyun
92*4882a593Smuzhiyun		cpu1: cpu@10001 {
93*4882a593Smuzhiyun			device_type = "cpu";
94*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
95*4882a593Smuzhiyun			reg = <0x10001>;
96*4882a593Smuzhiyun			enable-method = "psci";
97*4882a593Smuzhiyun			next-level-cache = <&cluster0_l2>;
98*4882a593Smuzhiyun		};
99*4882a593Smuzhiyun
100*4882a593Smuzhiyun		cpu2: cpu@10002 {
101*4882a593Smuzhiyun			device_type = "cpu";
102*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
103*4882a593Smuzhiyun			reg = <0x10002>;
104*4882a593Smuzhiyun			enable-method = "psci";
105*4882a593Smuzhiyun			next-level-cache = <&cluster0_l2>;
106*4882a593Smuzhiyun		};
107*4882a593Smuzhiyun
108*4882a593Smuzhiyun		cpu3: cpu@10003 {
109*4882a593Smuzhiyun			device_type = "cpu";
110*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
111*4882a593Smuzhiyun			reg = <0x10003>;
112*4882a593Smuzhiyun			enable-method = "psci";
113*4882a593Smuzhiyun			next-level-cache = <&cluster0_l2>;
114*4882a593Smuzhiyun		};
115*4882a593Smuzhiyun
116*4882a593Smuzhiyun		cpu4: cpu@10100 {
117*4882a593Smuzhiyun			device_type = "cpu";
118*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
119*4882a593Smuzhiyun			reg = <0x10100>;
120*4882a593Smuzhiyun			enable-method = "psci";
121*4882a593Smuzhiyun			next-level-cache = <&cluster1_l2>;
122*4882a593Smuzhiyun		};
123*4882a593Smuzhiyun
124*4882a593Smuzhiyun		cpu5: cpu@10101 {
125*4882a593Smuzhiyun			device_type = "cpu";
126*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
127*4882a593Smuzhiyun			reg = <0x10101>;
128*4882a593Smuzhiyun			enable-method = "psci";
129*4882a593Smuzhiyun			next-level-cache = <&cluster1_l2>;
130*4882a593Smuzhiyun		};
131*4882a593Smuzhiyun
132*4882a593Smuzhiyun		cpu6: cpu@10102 {
133*4882a593Smuzhiyun			device_type = "cpu";
134*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
135*4882a593Smuzhiyun			reg = <0x10102>;
136*4882a593Smuzhiyun			enable-method = "psci";
137*4882a593Smuzhiyun			next-level-cache = <&cluster1_l2>;
138*4882a593Smuzhiyun		};
139*4882a593Smuzhiyun
140*4882a593Smuzhiyun		cpu7: cpu@10103 {
141*4882a593Smuzhiyun			device_type = "cpu";
142*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
143*4882a593Smuzhiyun			reg = <0x10103>;
144*4882a593Smuzhiyun			enable-method = "psci";
145*4882a593Smuzhiyun			next-level-cache = <&cluster1_l2>;
146*4882a593Smuzhiyun		};
147*4882a593Smuzhiyun
148*4882a593Smuzhiyun		cpu8: cpu@10200 {
149*4882a593Smuzhiyun			device_type = "cpu";
150*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
151*4882a593Smuzhiyun			reg = <0x10200>;
152*4882a593Smuzhiyun			enable-method = "psci";
153*4882a593Smuzhiyun			next-level-cache = <&cluster2_l2>;
154*4882a593Smuzhiyun		};
155*4882a593Smuzhiyun
156*4882a593Smuzhiyun		cpu9: cpu@10201 {
157*4882a593Smuzhiyun			device_type = "cpu";
158*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
159*4882a593Smuzhiyun			reg = <0x10201>;
160*4882a593Smuzhiyun			enable-method = "psci";
161*4882a593Smuzhiyun			next-level-cache = <&cluster2_l2>;
162*4882a593Smuzhiyun		};
163*4882a593Smuzhiyun
164*4882a593Smuzhiyun		cpu10: cpu@10202 {
165*4882a593Smuzhiyun			device_type = "cpu";
166*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
167*4882a593Smuzhiyun			reg = <0x10202>;
168*4882a593Smuzhiyun			enable-method = "psci";
169*4882a593Smuzhiyun			next-level-cache = <&cluster2_l2>;
170*4882a593Smuzhiyun		};
171*4882a593Smuzhiyun
172*4882a593Smuzhiyun		cpu11: cpu@10203 {
173*4882a593Smuzhiyun			device_type = "cpu";
174*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
175*4882a593Smuzhiyun			reg = <0x10203>;
176*4882a593Smuzhiyun			enable-method = "psci";
177*4882a593Smuzhiyun			next-level-cache = <&cluster2_l2>;
178*4882a593Smuzhiyun		};
179*4882a593Smuzhiyun
180*4882a593Smuzhiyun		cpu12: cpu@10300 {
181*4882a593Smuzhiyun			device_type = "cpu";
182*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
183*4882a593Smuzhiyun			reg = <0x10300>;
184*4882a593Smuzhiyun			enable-method = "psci";
185*4882a593Smuzhiyun			next-level-cache = <&cluster3_l2>;
186*4882a593Smuzhiyun		};
187*4882a593Smuzhiyun
188*4882a593Smuzhiyun		cpu13: cpu@10301 {
189*4882a593Smuzhiyun			device_type = "cpu";
190*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
191*4882a593Smuzhiyun			reg = <0x10301>;
192*4882a593Smuzhiyun			enable-method = "psci";
193*4882a593Smuzhiyun			next-level-cache = <&cluster3_l2>;
194*4882a593Smuzhiyun		};
195*4882a593Smuzhiyun
196*4882a593Smuzhiyun		cpu14: cpu@10302 {
197*4882a593Smuzhiyun			device_type = "cpu";
198*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
199*4882a593Smuzhiyun			reg = <0x10302>;
200*4882a593Smuzhiyun			enable-method = "psci";
201*4882a593Smuzhiyun			next-level-cache = <&cluster3_l2>;
202*4882a593Smuzhiyun		};
203*4882a593Smuzhiyun
204*4882a593Smuzhiyun		cpu15: cpu@10303 {
205*4882a593Smuzhiyun			device_type = "cpu";
206*4882a593Smuzhiyun			compatible = "arm,cortex-a57";
207*4882a593Smuzhiyun			reg = <0x10303>;
208*4882a593Smuzhiyun			enable-method = "psci";
209*4882a593Smuzhiyun			next-level-cache = <&cluster3_l2>;
210*4882a593Smuzhiyun		};
211*4882a593Smuzhiyun
212*4882a593Smuzhiyun		cluster0_l2: l2-cache0 {
213*4882a593Smuzhiyun			compatible = "cache";
214*4882a593Smuzhiyun		};
215*4882a593Smuzhiyun
216*4882a593Smuzhiyun		cluster1_l2: l2-cache1 {
217*4882a593Smuzhiyun			compatible = "cache";
218*4882a593Smuzhiyun		};
219*4882a593Smuzhiyun
220*4882a593Smuzhiyun		cluster2_l2: l2-cache2 {
221*4882a593Smuzhiyun			compatible = "cache";
222*4882a593Smuzhiyun		};
223*4882a593Smuzhiyun
224*4882a593Smuzhiyun		cluster3_l2: l2-cache3 {
225*4882a593Smuzhiyun			compatible = "cache";
226*4882a593Smuzhiyun		};
227*4882a593Smuzhiyun	};
228*4882a593Smuzhiyun
229*4882a593Smuzhiyun	gic: interrupt-controller@4d000000 {
230*4882a593Smuzhiyun		compatible = "arm,gic-v3";
231*4882a593Smuzhiyun		#interrupt-cells = <3>;
232*4882a593Smuzhiyun		#address-cells = <2>;
233*4882a593Smuzhiyun		#size-cells = <2>;
234*4882a593Smuzhiyun		ranges;
235*4882a593Smuzhiyun		interrupt-controller;
236*4882a593Smuzhiyun		#redistributor-regions = <1>;
237*4882a593Smuzhiyun		redistributor-stride = <0x0 0x30000>;
238*4882a593Smuzhiyun		reg = <0x0 0x4d000000 0 0x10000>,	/* GICD */
239*4882a593Smuzhiyun		      <0x0 0x4d100000 0 0x300000>,	/* GICR */
240*4882a593Smuzhiyun		      <0x0 0xfe000000 0 0x10000>,	/* GICC */
241*4882a593Smuzhiyun		      <0x0 0xfe010000 0 0x10000>,       /* GICH */
242*4882a593Smuzhiyun		      <0x0 0xfe020000 0 0x10000>;       /* GICV */
243*4882a593Smuzhiyun		interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
244*4882a593Smuzhiyun
245*4882a593Smuzhiyun		its_dsa: interrupt-controller@c6000000 {
246*4882a593Smuzhiyun			compatible = "arm,gic-v3-its";
247*4882a593Smuzhiyun			msi-controller;
248*4882a593Smuzhiyun			#msi-cells = <1>;
249*4882a593Smuzhiyun			reg = <0x0 0xc6000000 0x0 0x40000>;
250*4882a593Smuzhiyun		};
251*4882a593Smuzhiyun	};
252*4882a593Smuzhiyun
253*4882a593Smuzhiyun	timer {
254*4882a593Smuzhiyun		compatible = "arm,armv8-timer";
255*4882a593Smuzhiyun		interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>,
256*4882a593Smuzhiyun			     <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>,
257*4882a593Smuzhiyun			     <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>,
258*4882a593Smuzhiyun			     <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>;
259*4882a593Smuzhiyun	};
260*4882a593Smuzhiyun
261*4882a593Smuzhiyun	pmu {
262*4882a593Smuzhiyun		compatible = "arm,cortex-a57-pmu";
263*4882a593Smuzhiyun		interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>;
264*4882a593Smuzhiyun	};
265*4882a593Smuzhiyun
266*4882a593Smuzhiyun	mbigen_pcie@a0080000 {
267*4882a593Smuzhiyun		compatible = "hisilicon,mbigen-v2";
268*4882a593Smuzhiyun		reg = <0x0 0xa0080000 0x0 0x10000>;
269*4882a593Smuzhiyun
270*4882a593Smuzhiyun		mbigen_usb: intc_usb {
271*4882a593Smuzhiyun			msi-parent = <&its_dsa 0x40080>;
272*4882a593Smuzhiyun			interrupt-controller;
273*4882a593Smuzhiyun			#interrupt-cells = <2>;
274*4882a593Smuzhiyun			num-pins = <2>;
275*4882a593Smuzhiyun		};
276*4882a593Smuzhiyun
277*4882a593Smuzhiyun		mbigen_sas1: intc_sas1 {
278*4882a593Smuzhiyun			msi-parent = <&its_dsa 0x40000>;
279*4882a593Smuzhiyun			interrupt-controller;
280*4882a593Smuzhiyun			#interrupt-cells = <2>;
281*4882a593Smuzhiyun			num-pins = <128>;
282*4882a593Smuzhiyun		};
283*4882a593Smuzhiyun
284*4882a593Smuzhiyun		mbigen_sas2: intc_sas2 {
285*4882a593Smuzhiyun			msi-parent = <&its_dsa 0x40040>;
286*4882a593Smuzhiyun			interrupt-controller;
287*4882a593Smuzhiyun			#interrupt-cells = <2>;
288*4882a593Smuzhiyun			num-pins = <128>;
289*4882a593Smuzhiyun		};
290*4882a593Smuzhiyun
291*4882a593Smuzhiyun		mbigen_pcie0: intc_pcie0 {
292*4882a593Smuzhiyun			msi-parent = <&its_dsa 0x40085>;
293*4882a593Smuzhiyun			interrupt-controller;
294*4882a593Smuzhiyun			#interrupt-cells = <2>;
295*4882a593Smuzhiyun			num-pins = <10>;
296*4882a593Smuzhiyun		};
297*4882a593Smuzhiyun	};
298*4882a593Smuzhiyun
299*4882a593Smuzhiyun	mbigen_dsa@c0080000 {
300*4882a593Smuzhiyun		compatible = "hisilicon,mbigen-v2";
301*4882a593Smuzhiyun		reg = <0x0 0xc0080000 0x0 0x10000>;
302*4882a593Smuzhiyun
303*4882a593Smuzhiyun		mbigen_dsaf0: intc_dsaf0 {
304*4882a593Smuzhiyun			msi-parent = <&its_dsa 0x40800>;
305*4882a593Smuzhiyun			interrupt-controller;
306*4882a593Smuzhiyun			#interrupt-cells = <2>;
307*4882a593Smuzhiyun			num-pins = <409>;
308*4882a593Smuzhiyun		};
309*4882a593Smuzhiyun
310*4882a593Smuzhiyun		mbigen_sas0: intc-sas0 {
311*4882a593Smuzhiyun			msi-parent = <&its_dsa 0x40900>;
312*4882a593Smuzhiyun			interrupt-controller;
313*4882a593Smuzhiyun			#interrupt-cells = <2>;
314*4882a593Smuzhiyun			num-pins = <128>;
315*4882a593Smuzhiyun		};
316*4882a593Smuzhiyun	};
317*4882a593Smuzhiyun
318*4882a593Smuzhiyun	/**
319*4882a593Smuzhiyun	 *  HiSilicon erratum 161010801: This describes the limitation
320*4882a593Smuzhiyun	 *  of HiSilicon platforms hip06/hip07 to support the SMMUv3
321*4882a593Smuzhiyun	 *  mappings for PCIe MSI transactions.
322*4882a593Smuzhiyun	 *  PCIe controller on these platforms has to differentiate the
323*4882a593Smuzhiyun	 *  MSI payload against other DMA payload and has to modify the
324*4882a593Smuzhiyun	 *  MSI payload. This makes it difficult for these platforms to
325*4882a593Smuzhiyun	 *  have a SMMU translation for MSI. In order to workaround this,
326*4882a593Smuzhiyun	 *  ARM SMMUv3 driver requires a quirk to treat the MSI regions
327*4882a593Smuzhiyun	 *  separately. Such a quirk is currently missing for DT based
328*4882a593Smuzhiyun	 *  systems. Hence please make sure that the smmu pcie node on
329*4882a593Smuzhiyun	 *  hip06 is disabled as this will break the PCIe functionality
330*4882a593Smuzhiyun	 *  when iommu-map entry is used along with the PCIe node.
331*4882a593Smuzhiyun	 *  Refer:https://www.spinics.net/lists/arm-kernel/msg602812.html
332*4882a593Smuzhiyun	 */
333*4882a593Smuzhiyun	smmu0: smmu_pcie {
334*4882a593Smuzhiyun		compatible = "arm,smmu-v3";
335*4882a593Smuzhiyun		reg = <0x0 0xa0040000 0x0 0x20000>;
336*4882a593Smuzhiyun		#iommu-cells = <1>;
337*4882a593Smuzhiyun		dma-coherent;
338*4882a593Smuzhiyun		smmu-cb-memtype = <0x0 0x1>;
339*4882a593Smuzhiyun		hisilicon,broken-prefetch-cmd;
340*4882a593Smuzhiyun		status = "disabled";
341*4882a593Smuzhiyun	};
342*4882a593Smuzhiyun
343*4882a593Smuzhiyun	soc {
344*4882a593Smuzhiyun		compatible = "simple-bus";
345*4882a593Smuzhiyun		#address-cells = <2>;
346*4882a593Smuzhiyun		#size-cells = <2>;
347*4882a593Smuzhiyun		ranges;
348*4882a593Smuzhiyun
349*4882a593Smuzhiyun		isa@a01b0000 {
350*4882a593Smuzhiyun			compatible = "hisilicon,hip06-lpc";
351*4882a593Smuzhiyun			#size-cells = <1>;
352*4882a593Smuzhiyun			#address-cells = <2>;
353*4882a593Smuzhiyun			reg = <0x0 0xa01b0000 0x0 0x1000>;
354*4882a593Smuzhiyun
355*4882a593Smuzhiyun			ipmi0: bt@e4 {
356*4882a593Smuzhiyun				compatible = "ipmi-bt";
357*4882a593Smuzhiyun				device_type = "ipmi";
358*4882a593Smuzhiyun				reg = <0x01 0xe4 0x04>;
359*4882a593Smuzhiyun				status = "disabled";
360*4882a593Smuzhiyun			};
361*4882a593Smuzhiyun
362*4882a593Smuzhiyun			uart0: lpc-uart@2f8 {
363*4882a593Smuzhiyun				compatible = "ns16550a";
364*4882a593Smuzhiyun				clock-frequency = <1843200>;
365*4882a593Smuzhiyun				reg = <0x01 0x2f8 0x08>;
366*4882a593Smuzhiyun				status = "disabled";
367*4882a593Smuzhiyun			};
368*4882a593Smuzhiyun		};
369*4882a593Smuzhiyun
370*4882a593Smuzhiyun		refclk: refclk {
371*4882a593Smuzhiyun			compatible = "fixed-clock";
372*4882a593Smuzhiyun			clock-frequency = <50000000>;
373*4882a593Smuzhiyun			#clock-cells = <0>;
374*4882a593Smuzhiyun		};
375*4882a593Smuzhiyun
376*4882a593Smuzhiyun		usb_ohci: ohci@a7030000 {
377*4882a593Smuzhiyun			compatible = "generic-ohci";
378*4882a593Smuzhiyun			reg = <0x0 0xa7030000 0x0 0x10000>;
379*4882a593Smuzhiyun			interrupt-parent = <&mbigen_usb>;
380*4882a593Smuzhiyun			interrupts = <640 4>;
381*4882a593Smuzhiyun			dma-coherent;
382*4882a593Smuzhiyun			status = "disabled";
383*4882a593Smuzhiyun		};
384*4882a593Smuzhiyun
385*4882a593Smuzhiyun		usb_ehci: ehci@a7020000 {
386*4882a593Smuzhiyun			compatible = "generic-ehci";
387*4882a593Smuzhiyun			reg = <0x0 0xa7020000 0x0 0x10000>;
388*4882a593Smuzhiyun			interrupt-parent = <&mbigen_usb>;
389*4882a593Smuzhiyun			interrupts = <641 4>;
390*4882a593Smuzhiyun			dma-coherent;
391*4882a593Smuzhiyun			status = "disabled";
392*4882a593Smuzhiyun		};
393*4882a593Smuzhiyun
394*4882a593Smuzhiyun		peri_c_subctrl: sub_ctrl_c@60000000 {
395*4882a593Smuzhiyun			compatible = "hisilicon,peri-subctrl","syscon";
396*4882a593Smuzhiyun			reg = <0 0x60000000 0x0 0x10000>;
397*4882a593Smuzhiyun		};
398*4882a593Smuzhiyun
399*4882a593Smuzhiyun		dsa_subctrl: dsa_subctrl@c0000000 {
400*4882a593Smuzhiyun			compatible = "hisilicon,dsa-subctrl", "syscon";
401*4882a593Smuzhiyun			reg = <0x0 0xc0000000 0x0 0x10000>;
402*4882a593Smuzhiyun		};
403*4882a593Smuzhiyun
404*4882a593Smuzhiyun		pcie_subctl: pcie_subctl@a0000000 {
405*4882a593Smuzhiyun			compatible = "hisilicon,pcie-sas-subctrl", "syscon";
406*4882a593Smuzhiyun			reg = <0x0 0xa0000000 0x0 0x10000>;
407*4882a593Smuzhiyun		};
408*4882a593Smuzhiyun
409*4882a593Smuzhiyun		serdes_ctrl: sds_ctrl@c2200000 {
410*4882a593Smuzhiyun			compatible = "syscon";
411*4882a593Smuzhiyun			reg = <0 0xc2200000 0x0 0x80000>;
412*4882a593Smuzhiyun		};
413*4882a593Smuzhiyun
414*4882a593Smuzhiyun		mdio@603c0000 {
415*4882a593Smuzhiyun			compatible = "hisilicon,hns-mdio";
416*4882a593Smuzhiyun			reg = <0x0 0x603c0000 0x0 0x1000>;
417*4882a593Smuzhiyun			subctrl-vbase = <&peri_c_subctrl 0x338 0xa38 0x531c 0x5a1c>;
418*4882a593Smuzhiyun			#address-cells = <1>;
419*4882a593Smuzhiyun			#size-cells = <0>;
420*4882a593Smuzhiyun
421*4882a593Smuzhiyun			phy0: ethernet-phy@0 {
422*4882a593Smuzhiyun				compatible = "ethernet-phy-ieee802.3-c22";
423*4882a593Smuzhiyun				reg = <0>;
424*4882a593Smuzhiyun			};
425*4882a593Smuzhiyun
426*4882a593Smuzhiyun			phy1: ethernet-phy@1 {
427*4882a593Smuzhiyun				compatible = "ethernet-phy-ieee802.3-c22";
428*4882a593Smuzhiyun				reg = <1>;
429*4882a593Smuzhiyun			};
430*4882a593Smuzhiyun		};
431*4882a593Smuzhiyun
432*4882a593Smuzhiyun		dsaf0: dsa@c7000000 {
433*4882a593Smuzhiyun			#address-cells = <1>;
434*4882a593Smuzhiyun			#size-cells = <0>;
435*4882a593Smuzhiyun			compatible = "hisilicon,hns-dsaf-v2";
436*4882a593Smuzhiyun			mode = "6port-16rss";
437*4882a593Smuzhiyun			reg = <0x0 0xc5000000 0x0 0x890000
438*4882a593Smuzhiyun			       0x0 0xc7000000 0x0 0x600000>;
439*4882a593Smuzhiyun			reg-names = "ppe-base", "dsaf-base";
440*4882a593Smuzhiyun			interrupt-parent = <&mbigen_dsaf0>;
441*4882a593Smuzhiyun			subctrl-syscon = <&dsa_subctrl>;
442*4882a593Smuzhiyun			reset-field-offset = <0>;
443*4882a593Smuzhiyun			interrupts =
444*4882a593Smuzhiyun			<576 1>, <577 1>, <578 1>, <579 1>, <580 1>,
445*4882a593Smuzhiyun			<581 1>, <582 1>, <583 1>, <584 1>, <585 1>,
446*4882a593Smuzhiyun			<586 1>, <587 1>, <588 1>, <589 1>, <590 1>,
447*4882a593Smuzhiyun			<591 1>, <592 1>, <593 1>, <594 1>, <595 1>,
448*4882a593Smuzhiyun			<596 1>, <597 1>, <598 1>, <599 1>, <600 1>,
449*4882a593Smuzhiyun			<960 1>, <961 1>, <962 1>, <963 1>, <964 1>,
450*4882a593Smuzhiyun			<965 1>, <966 1>, <967 1>, <968 1>, <969 1>,
451*4882a593Smuzhiyun			<970 1>, <971 1>, <972 1>, <973 1>, <974 1>,
452*4882a593Smuzhiyun			<975 1>, <976 1>, <977 1>, <978 1>, <979 1>,
453*4882a593Smuzhiyun			<980 1>, <981 1>, <982 1>, <983 1>, <984 1>,
454*4882a593Smuzhiyun			<985 1>, <986 1>, <987 1>, <988 1>, <989 1>,
455*4882a593Smuzhiyun			<990 1>, <991 1>, <992 1>, <993 1>, <994 1>,
456*4882a593Smuzhiyun			<995 1>, <996 1>, <997 1>, <998 1>, <999 1>,
457*4882a593Smuzhiyun			<1000 1>, <1001 1>, <1002 1>, <1003 1>, <1004 1>,
458*4882a593Smuzhiyun			<1005 1>, <1006 1>, <1007 1>, <1008 1>, <1009 1>,
459*4882a593Smuzhiyun			<1010 1>, <1011 1>, <1012 1>, <1013 1>, <1014 1>,
460*4882a593Smuzhiyun			<1015 1>, <1016 1>, <1017 1>, <1018 1>, <1019 1>,
461*4882a593Smuzhiyun			<1020 1>, <1021 1>, <1022 1>, <1023 1>, <1024 1>,
462*4882a593Smuzhiyun			<1025 1>, <1026 1>, <1027 1>, <1028 1>, <1029 1>,
463*4882a593Smuzhiyun			<1030 1>, <1031 1>, <1032 1>, <1033 1>, <1034 1>,
464*4882a593Smuzhiyun			<1035 1>, <1036 1>, <1037 1>, <1038 1>, <1039 1>,
465*4882a593Smuzhiyun			<1040 1>, <1041 1>, <1042 1>, <1043 1>, <1044 1>,
466*4882a593Smuzhiyun			<1045 1>, <1046 1>, <1047 1>, <1048 1>, <1049 1>,
467*4882a593Smuzhiyun			<1050 1>, <1051 1>, <1052 1>, <1053 1>, <1054 1>,
468*4882a593Smuzhiyun			<1055 1>, <1056 1>, <1057 1>, <1058 1>, <1059 1>,
469*4882a593Smuzhiyun			<1060 1>, <1061 1>, <1062 1>, <1063 1>, <1064 1>,
470*4882a593Smuzhiyun			<1065 1>, <1066 1>, <1067 1>, <1068 1>, <1069 1>,
471*4882a593Smuzhiyun			<1070 1>, <1071 1>, <1072 1>, <1073 1>, <1074 1>,
472*4882a593Smuzhiyun			<1075 1>, <1076 1>, <1077 1>, <1078 1>, <1079 1>,
473*4882a593Smuzhiyun			<1080 1>, <1081 1>, <1082 1>, <1083 1>, <1084 1>,
474*4882a593Smuzhiyun			<1085 1>, <1086 1>, <1087 1>, <1088 1>, <1089 1>,
475*4882a593Smuzhiyun			<1090 1>, <1091 1>, <1092 1>, <1093 1>, <1094 1>,
476*4882a593Smuzhiyun			<1095 1>, <1096 1>, <1097 1>, <1098 1>, <1099 1>,
477*4882a593Smuzhiyun			<1100 1>, <1101 1>, <1102 1>, <1103 1>, <1104 1>,
478*4882a593Smuzhiyun			<1105 1>, <1106 1>, <1107 1>, <1108 1>, <1109 1>,
479*4882a593Smuzhiyun			<1110 1>, <1111 1>, <1112 1>, <1113 1>, <1114 1>,
480*4882a593Smuzhiyun			<1115 1>, <1116 1>, <1117 1>, <1118 1>, <1119 1>,
481*4882a593Smuzhiyun			<1120 1>, <1121 1>, <1122 1>, <1123 1>, <1124 1>,
482*4882a593Smuzhiyun			<1125 1>, <1126 1>, <1127 1>, <1128 1>, <1129 1>,
483*4882a593Smuzhiyun			<1130 1>, <1131 1>, <1132 1>, <1133 1>, <1134 1>,
484*4882a593Smuzhiyun			<1135 1>, <1136 1>, <1137 1>, <1138 1>, <1139 1>,
485*4882a593Smuzhiyun			<1140 1>, <1141 1>, <1142 1>, <1143 1>, <1144 1>,
486*4882a593Smuzhiyun			<1145 1>, <1146 1>, <1147 1>, <1148 1>, <1149 1>,
487*4882a593Smuzhiyun			<1150 1>, <1151 1>, <1152 1>, <1153 1>, <1154 1>,
488*4882a593Smuzhiyun			<1155 1>, <1156 1>, <1157 1>, <1158 1>, <1159 1>,
489*4882a593Smuzhiyun			<1160 1>, <1161 1>, <1162 1>, <1163 1>, <1164 1>,
490*4882a593Smuzhiyun			<1165 1>, <1166 1>, <1167 1>, <1168 1>, <1169 1>,
491*4882a593Smuzhiyun			<1170 1>, <1171 1>, <1172 1>, <1173 1>, <1174 1>,
492*4882a593Smuzhiyun			<1175 1>, <1176 1>, <1177 1>, <1178 1>, <1179 1>,
493*4882a593Smuzhiyun			<1180 1>, <1181 1>, <1182 1>, <1183 1>, <1184 1>,
494*4882a593Smuzhiyun			<1185 1>, <1186 1>, <1187 1>, <1188 1>, <1189 1>,
495*4882a593Smuzhiyun			<1190 1>, <1191 1>, <1192 1>, <1193 1>, <1194 1>,
496*4882a593Smuzhiyun			<1195 1>, <1196 1>, <1197 1>, <1198 1>, <1199 1>,
497*4882a593Smuzhiyun			<1200 1>, <1201 1>, <1202 1>, <1203 1>, <1204 1>,
498*4882a593Smuzhiyun			<1205 1>, <1206 1>, <1207 1>, <1208 1>, <1209 1>,
499*4882a593Smuzhiyun			<1210 1>, <1211 1>, <1212 1>, <1213 1>, <1214 1>,
500*4882a593Smuzhiyun			<1215 1>, <1216 1>, <1217 1>, <1218 1>, <1219 1>,
501*4882a593Smuzhiyun			<1220 1>, <1221 1>, <1222 1>, <1223 1>, <1224 1>,
502*4882a593Smuzhiyun			<1225 1>, <1226 1>, <1227 1>, <1228 1>, <1229 1>,
503*4882a593Smuzhiyun			<1230 1>, <1231 1>, <1232 1>, <1233 1>, <1234 1>,
504*4882a593Smuzhiyun			<1235 1>, <1236 1>, <1237 1>, <1238 1>, <1239 1>,
505*4882a593Smuzhiyun			<1240 1>, <1241 1>, <1242 1>, <1243 1>, <1244 1>,
506*4882a593Smuzhiyun			<1245 1>, <1246 1>, <1247 1>, <1248 1>, <1249 1>,
507*4882a593Smuzhiyun			<1250 1>, <1251 1>, <1252 1>, <1253 1>, <1254 1>,
508*4882a593Smuzhiyun			<1255 1>, <1256 1>, <1257 1>, <1258 1>, <1259 1>,
509*4882a593Smuzhiyun			<1260 1>, <1261 1>, <1262 1>, <1263 1>, <1264 1>,
510*4882a593Smuzhiyun			<1265 1>, <1266 1>, <1267 1>, <1268 1>, <1269 1>,
511*4882a593Smuzhiyun			<1270 1>, <1271 1>, <1272 1>, <1273 1>, <1274 1>,
512*4882a593Smuzhiyun			<1275 1>, <1276 1>, <1277 1>, <1278 1>, <1279 1>,
513*4882a593Smuzhiyun			<1280 1>, <1281 1>, <1282 1>, <1283 1>, <1284 1>,
514*4882a593Smuzhiyun			<1285 1>, <1286 1>, <1287 1>, <1288 1>, <1289 1>,
515*4882a593Smuzhiyun			<1290 1>, <1291 1>, <1292 1>, <1293 1>, <1294 1>,
516*4882a593Smuzhiyun			<1295 1>, <1296 1>, <1297 1>, <1298 1>, <1299 1>,
517*4882a593Smuzhiyun			<1300 1>, <1301 1>, <1302 1>, <1303 1>, <1304 1>,
518*4882a593Smuzhiyun			<1305 1>, <1306 1>, <1307 1>, <1308 1>, <1309 1>,
519*4882a593Smuzhiyun			<1310 1>, <1311 1>, <1312 1>, <1313 1>, <1314 1>,
520*4882a593Smuzhiyun			<1315 1>, <1316 1>, <1317 1>, <1318 1>, <1319 1>,
521*4882a593Smuzhiyun			<1320 1>, <1321 1>, <1322 1>, <1323 1>, <1324 1>,
522*4882a593Smuzhiyun			<1325 1>, <1326 1>, <1327 1>, <1328 1>, <1329 1>,
523*4882a593Smuzhiyun			<1330 1>, <1331 1>, <1332 1>, <1333 1>, <1334 1>,
524*4882a593Smuzhiyun			<1335 1>, <1336 1>, <1337 1>, <1338 1>, <1339 1>,
525*4882a593Smuzhiyun			<1340 1>, <1341 1>, <1342 1>, <1343 1>;
526*4882a593Smuzhiyun
527*4882a593Smuzhiyun			desc-num = <0x400>;
528*4882a593Smuzhiyun			buf-size = <0x1000>;
529*4882a593Smuzhiyun			dma-coherent;
530*4882a593Smuzhiyun
531*4882a593Smuzhiyun			port@0 {
532*4882a593Smuzhiyun				reg = <0>;
533*4882a593Smuzhiyun				serdes-syscon = <&serdes_ctrl>;
534*4882a593Smuzhiyun				port-rst-offset = <0>;
535*4882a593Smuzhiyun				port-mode-offset = <0>;
536*4882a593Smuzhiyun				media-type = "fiber";
537*4882a593Smuzhiyun			};
538*4882a593Smuzhiyun
539*4882a593Smuzhiyun			port@1 {
540*4882a593Smuzhiyun				reg = <1>;
541*4882a593Smuzhiyun				serdes-syscon= <&serdes_ctrl>;
542*4882a593Smuzhiyun				port-rst-offset = <1>;
543*4882a593Smuzhiyun				port-mode-offset = <1>;
544*4882a593Smuzhiyun				media-type = "fiber";
545*4882a593Smuzhiyun			};
546*4882a593Smuzhiyun
547*4882a593Smuzhiyun			port@4 {
548*4882a593Smuzhiyun				reg = <4>;
549*4882a593Smuzhiyun				phy-handle = <&phy0>;
550*4882a593Smuzhiyun				serdes-syscon= <&serdes_ctrl>;
551*4882a593Smuzhiyun				port-rst-offset = <4>;
552*4882a593Smuzhiyun				port-mode-offset = <2>;
553*4882a593Smuzhiyun				media-type = "copper";
554*4882a593Smuzhiyun			};
555*4882a593Smuzhiyun
556*4882a593Smuzhiyun			port@5 {
557*4882a593Smuzhiyun				reg = <5>;
558*4882a593Smuzhiyun				phy-handle = <&phy1>;
559*4882a593Smuzhiyun				serdes-syscon= <&serdes_ctrl>;
560*4882a593Smuzhiyun				port-rst-offset = <5>;
561*4882a593Smuzhiyun				port-mode-offset = <3>;
562*4882a593Smuzhiyun				media-type = "copper";
563*4882a593Smuzhiyun			};
564*4882a593Smuzhiyun		};
565*4882a593Smuzhiyun
566*4882a593Smuzhiyun		eth0: ethernet-4{
567*4882a593Smuzhiyun			compatible = "hisilicon,hns-nic-v2";
568*4882a593Smuzhiyun			ae-handle = <&dsaf0>;
569*4882a593Smuzhiyun			port-idx-in-ae = <4>;
570*4882a593Smuzhiyun			local-mac-address = [00 00 00 00 00 00];
571*4882a593Smuzhiyun			status = "disabled";
572*4882a593Smuzhiyun			dma-coherent;
573*4882a593Smuzhiyun		};
574*4882a593Smuzhiyun
575*4882a593Smuzhiyun		eth1: ethernet-5{
576*4882a593Smuzhiyun			compatible = "hisilicon,hns-nic-v2";
577*4882a593Smuzhiyun			ae-handle = <&dsaf0>;
578*4882a593Smuzhiyun			port-idx-in-ae = <5>;
579*4882a593Smuzhiyun			local-mac-address = [00 00 00 00 00 00];
580*4882a593Smuzhiyun			status = "disabled";
581*4882a593Smuzhiyun			dma-coherent;
582*4882a593Smuzhiyun		};
583*4882a593Smuzhiyun
584*4882a593Smuzhiyun		eth2: ethernet-0{
585*4882a593Smuzhiyun			compatible = "hisilicon,hns-nic-v2";
586*4882a593Smuzhiyun			ae-handle = <&dsaf0>;
587*4882a593Smuzhiyun			port-idx-in-ae = <0>;
588*4882a593Smuzhiyun			local-mac-address = [00 00 00 00 00 00];
589*4882a593Smuzhiyun			status = "disabled";
590*4882a593Smuzhiyun			dma-coherent;
591*4882a593Smuzhiyun		};
592*4882a593Smuzhiyun
593*4882a593Smuzhiyun		eth3: ethernet-1{
594*4882a593Smuzhiyun			compatible = "hisilicon,hns-nic-v2";
595*4882a593Smuzhiyun			ae-handle = <&dsaf0>;
596*4882a593Smuzhiyun			port-idx-in-ae = <1>;
597*4882a593Smuzhiyun			local-mac-address = [00 00 00 00 00 00];
598*4882a593Smuzhiyun			status = "disabled";
599*4882a593Smuzhiyun			dma-coherent;
600*4882a593Smuzhiyun		};
601*4882a593Smuzhiyun
602*4882a593Smuzhiyun		sas0: sas@c3000000 {
603*4882a593Smuzhiyun			compatible = "hisilicon,hip06-sas-v2";
604*4882a593Smuzhiyun			reg = <0 0xc3000000 0 0x10000>;
605*4882a593Smuzhiyun			sas-addr = [50 01 88 20 16 00 00 00];
606*4882a593Smuzhiyun			hisilicon,sas-syscon = <&dsa_subctrl>;
607*4882a593Smuzhiyun			ctrl-reset-reg = <0xa60>;
608*4882a593Smuzhiyun			ctrl-reset-sts-reg = <0x5a30>;
609*4882a593Smuzhiyun			ctrl-clock-ena-reg = <0x338>;
610*4882a593Smuzhiyun			clocks = <&refclk 0>;
611*4882a593Smuzhiyun			queue-count = <16>;
612*4882a593Smuzhiyun			phy-count = <8>;
613*4882a593Smuzhiyun			dma-coherent;
614*4882a593Smuzhiyun			interrupt-parent = <&mbigen_sas0>;
615*4882a593Smuzhiyun			interrupts = <64 4>,<65 4>,<66 4>,<67 4>,<68 4>,
616*4882a593Smuzhiyun				     <69 4>,<70 4>,<71 4>,<72 4>,<73 4>,
617*4882a593Smuzhiyun				     <75 4>,<76 4>,<77 4>,<78 4>,<79 4>,
618*4882a593Smuzhiyun				     <80 4>,<81 4>,<82 4>,<83 4>,<84 4>,
619*4882a593Smuzhiyun				     <85 4>,<86 4>,<87 4>,<88 4>,<89 4>,
620*4882a593Smuzhiyun				     <90 4>,<91 4>,<92 4>,<93 4>,<94 4>,
621*4882a593Smuzhiyun				     <95 4>,<96 4>,<97 4>,<98 4>,<99 4>,
622*4882a593Smuzhiyun				     <100 4>,<101 4>,<102 4>,<103 4>,<104 4>,
623*4882a593Smuzhiyun				     <105 4>,<106 4>,<107 4>,<108 4>,<109 4>,
624*4882a593Smuzhiyun				     <110 4>,<111 4>,<112 4>,<113 4>,<114 4>,
625*4882a593Smuzhiyun				     <115 4>,<116 4>,<117 4>,<118 4>,<119 4>,
626*4882a593Smuzhiyun				     <120 4>,<121 4>,<122 4>,<123 4>,<124 4>,
627*4882a593Smuzhiyun				     <125 4>,<126 4>,<127 4>,<128 4>,<129 4>,
628*4882a593Smuzhiyun				     <130 4>,<131 4>,<132 4>,<133 4>,<134 4>,
629*4882a593Smuzhiyun				     <135 4>,<136 4>,<137 4>,<138 4>,<139 4>,
630*4882a593Smuzhiyun				     <140 4>,<141 4>,<142 4>,<143 4>,<144 4>,
631*4882a593Smuzhiyun				     <145 4>,<146 4>,<147 4>,<148 4>,<149 4>,
632*4882a593Smuzhiyun				     <150 4>,<151 4>,<152 4>,<153 4>,<154 4>,
633*4882a593Smuzhiyun				     <155 4>,<156 4>,<157 4>,<158 4>,<159 4>,
634*4882a593Smuzhiyun				     <160 4>,<601 1>,<602 1>,<603 1>,<604 1>,
635*4882a593Smuzhiyun				     <605 1>,<606 1>,<607 1>,<608 1>,<609 1>,
636*4882a593Smuzhiyun				     <610 1>,<611 1>,<612 1>,<613 1>,<614 1>,
637*4882a593Smuzhiyun				     <615 1>,<616 1>,<617 1>,<618 1>,<619 1>,
638*4882a593Smuzhiyun				     <620 1>,<621 1>,<622 1>,<623 1>,<624 1>,
639*4882a593Smuzhiyun				     <625 1>,<626 1>,<627 1>,<628 1>,<629 1>,
640*4882a593Smuzhiyun				     <630 1>,<631 1>,<632 1>;
641*4882a593Smuzhiyun			status = "disabled";
642*4882a593Smuzhiyun		};
643*4882a593Smuzhiyun
644*4882a593Smuzhiyun		sas1: sas@a2000000 {
645*4882a593Smuzhiyun			compatible = "hisilicon,hip06-sas-v2";
646*4882a593Smuzhiyun			reg = <0 0xa2000000 0 0x10000>;
647*4882a593Smuzhiyun			sas-addr = [50 01 88 20 16 00 00 00];
648*4882a593Smuzhiyun			hisilicon,sas-syscon = <&pcie_subctl>;
649*4882a593Smuzhiyun			hip06-sas-v2-quirk-amt;
650*4882a593Smuzhiyun			ctrl-reset-reg = <0xa18>;
651*4882a593Smuzhiyun			ctrl-reset-sts-reg = <0x5a0c>;
652*4882a593Smuzhiyun			ctrl-clock-ena-reg = <0x318>;
653*4882a593Smuzhiyun			clocks = <&refclk 0>;
654*4882a593Smuzhiyun			queue-count = <16>;
655*4882a593Smuzhiyun			phy-count = <8>;
656*4882a593Smuzhiyun			dma-coherent;
657*4882a593Smuzhiyun			interrupt-parent = <&mbigen_sas1>;
658*4882a593Smuzhiyun			interrupts = <64 4>,<65 4>,<66 4>,<67 4>,<68 4>,
659*4882a593Smuzhiyun				     <69 4>,<70 4>,<71 4>,<72 4>,<73 4>,
660*4882a593Smuzhiyun				     <74 4>,<75 4>,<76 4>,<77 4>,<78 4>,
661*4882a593Smuzhiyun				     <79 4>,<80 4>,<81 4>,<82 4>,<83 4>,
662*4882a593Smuzhiyun				     <84 4>,<85 4>,<86 4>,<87 4>,<88 4>,
663*4882a593Smuzhiyun				     <89 4>,<90 4>,<91 4>,<92 4>,<93 4>,
664*4882a593Smuzhiyun				     <94 4>,<95 4>,<96 4>,<97 4>,<98 4>,
665*4882a593Smuzhiyun				     <99 4>,<100 4>,<101 4>,<102 4>,<103 4>,
666*4882a593Smuzhiyun				     <104 4>,<105 4>,<106 4>,<107 4>,<108 4>,
667*4882a593Smuzhiyun				     <109 4>,<110 4>,<111 4>,<112 4>,<113 4>,
668*4882a593Smuzhiyun				     <114 4>,<115 4>,<116 4>,<117 4>,<118 4>,
669*4882a593Smuzhiyun				     <119 4>,<120 4>,<121 4>,<122 4>,<123 4>,
670*4882a593Smuzhiyun				     <124 4>,<125 4>,<126 4>,<127 4>,<128 4>,
671*4882a593Smuzhiyun				     <129 4>,<130 4>,<131 4>,<132 4>,<133 4>,
672*4882a593Smuzhiyun				     <134 4>,<135 4>,<136 4>,<137 4>,<138 4>,
673*4882a593Smuzhiyun				     <139 4>,<140 4>,<141 4>,<142 4>,<143 4>,
674*4882a593Smuzhiyun				     <144 4>,<145 4>,<146 4>,<147 4>,<148 4>,
675*4882a593Smuzhiyun				     <149 4>,<150 4>,<151 4>,<152 4>,<153 4>,
676*4882a593Smuzhiyun				     <154 4>,<155 4>,<156 4>,<157 4>,<158 4>,
677*4882a593Smuzhiyun				     <159 4>,<576 1>,<577 1>,<578 1>,<579 1>,
678*4882a593Smuzhiyun				     <580 1>,<581 1>,<582 1>,<583 1>,<584 1>,
679*4882a593Smuzhiyun				     <585 1>,<586 1>,<587 1>,<588 1>,<589 1>,
680*4882a593Smuzhiyun				     <590 1>,<591 1>,<592 1>,<593 1>,<594 1>,
681*4882a593Smuzhiyun				     <595 1>,<596 1>,<597 1>,<598 1>,<599 1>,
682*4882a593Smuzhiyun				     <600 1>,<601 1>,<602 1>,<603 1>,<604 1>,
683*4882a593Smuzhiyun				     <605 1>,<606 1>,<607 1>;
684*4882a593Smuzhiyun			status = "disabled";
685*4882a593Smuzhiyun		};
686*4882a593Smuzhiyun
687*4882a593Smuzhiyun		sas2: sas@a3000000 {
688*4882a593Smuzhiyun			compatible = "hisilicon,hip06-sas-v2";
689*4882a593Smuzhiyun			reg = <0 0xa3000000 0 0x10000>;
690*4882a593Smuzhiyun			sas-addr = [50 01 88 20 16 00 00 00];
691*4882a593Smuzhiyun			hisilicon,sas-syscon = <&pcie_subctl>;
692*4882a593Smuzhiyun			ctrl-reset-reg = <0xae0>;
693*4882a593Smuzhiyun			ctrl-reset-sts-reg = <0x5a70>;
694*4882a593Smuzhiyun			ctrl-clock-ena-reg = <0x3a8>;
695*4882a593Smuzhiyun			clocks = <&refclk 0>;
696*4882a593Smuzhiyun			queue-count = <16>;
697*4882a593Smuzhiyun			phy-count = <9>;
698*4882a593Smuzhiyun			dma-coherent;
699*4882a593Smuzhiyun			interrupt-parent = <&mbigen_sas2>;
700*4882a593Smuzhiyun			interrupts = <192 4>,<193 4>,<194 4>,<195 4>,<196 4>,
701*4882a593Smuzhiyun				     <197 4>,<198 4>,<199 4>,<200 4>,<201 4>,
702*4882a593Smuzhiyun				     <202 4>,<203 4>,<204 4>,<205 4>,<206 4>,
703*4882a593Smuzhiyun				     <207 4>,<208 4>,<209 4>,<210 4>,<211 4>,
704*4882a593Smuzhiyun				     <212 4>,<213 4>,<214 4>,<215 4>,<216 4>,
705*4882a593Smuzhiyun				     <217 4>,<218 4>,<219 4>,<220 4>,<221 4>,
706*4882a593Smuzhiyun				     <222 4>,<223 4>,<224 4>,<225 4>,<226 4>,
707*4882a593Smuzhiyun				     <227 4>,<228 4>,<229 4>,<230 4>,<231 4>,
708*4882a593Smuzhiyun				     <232 4>,<233 4>,<234 4>,<235 4>,<236 4>,
709*4882a593Smuzhiyun				     <237 4>,<238 4>,<239 4>,<240 4>,<241 4>,
710*4882a593Smuzhiyun				     <242 4>,<243 4>,<244 4>,<245 4>,<246 4>,
711*4882a593Smuzhiyun				     <247 4>,<248 4>,<249 4>,<250 4>,<251 4>,
712*4882a593Smuzhiyun				     <252 4>,<253 4>,<254 4>,<255 4>,<256 4>,
713*4882a593Smuzhiyun				     <257 4>,<258 4>,<259 4>,<260 4>,<261 4>,
714*4882a593Smuzhiyun				     <262 4>,<263 4>,<264 4>,<265 4>,<266 4>,
715*4882a593Smuzhiyun				     <267 4>,<268 4>,<269 4>,<270 4>,<271 4>,
716*4882a593Smuzhiyun				     <272 4>,<273 4>,<274 4>,<275 4>,<276 4>,
717*4882a593Smuzhiyun				     <277 4>,<278 4>,<279 4>,<280 4>,<281 4>,
718*4882a593Smuzhiyun				     <282 4>,<283 4>,<284 4>,<285 4>,<286 4>,
719*4882a593Smuzhiyun				     <287 4>,<608 1>,<609 1>,<610 1>,<611 1>,
720*4882a593Smuzhiyun				     <612 1>,<613 1>,<614 1>,<615 1>,<616 1>,
721*4882a593Smuzhiyun				     <617 1>,<618 1>,<619 1>,<620 1>,<621 1>,
722*4882a593Smuzhiyun				     <622 1>,<623 1>,<624 1>,<625 1>,<626 1>,
723*4882a593Smuzhiyun				     <627 1>,<628 1>,<629 1>,<630 1>,<631 1>,
724*4882a593Smuzhiyun				     <632 1>,<633 1>,<634 1>,<635 1>,<636 1>,
725*4882a593Smuzhiyun				     <637 1>,<638 1>,<639 1>;
726*4882a593Smuzhiyun			status = "disabled";
727*4882a593Smuzhiyun		};
728*4882a593Smuzhiyun
729*4882a593Smuzhiyun		pcie0: pcie@a0090000 {
730*4882a593Smuzhiyun			compatible = "hisilicon,hip06-pcie-ecam";
731*4882a593Smuzhiyun			reg = <0 0xb0000000 0 0x2000000>,
732*4882a593Smuzhiyun			      <0 0xa0090000 0 0x10000>;
733*4882a593Smuzhiyun			bus-range = <0  31>;
734*4882a593Smuzhiyun			msi-map = <0x0000 &its_dsa 0x0000 0x2000>;
735*4882a593Smuzhiyun			msi-map-mask = <0xffff>;
736*4882a593Smuzhiyun			#address-cells = <3>;
737*4882a593Smuzhiyun			#size-cells = <2>;
738*4882a593Smuzhiyun			device_type = "pci";
739*4882a593Smuzhiyun			dma-coherent;
740*4882a593Smuzhiyun			ranges = <0x02000000 0 0xb2000000 0x0 0xb2000000 0
741*4882a593Smuzhiyun				 0x5ff0000 0x01000000 0 0 0 0xb7ff0000
742*4882a593Smuzhiyun				 0 0x10000>;
743*4882a593Smuzhiyun			#interrupt-cells = <1>;
744*4882a593Smuzhiyun			interrupt-map-mask = <0xf800 0 0 7>;
745*4882a593Smuzhiyun			interrupt-map = <0x0 0 0 1 &mbigen_pcie0 650 4
746*4882a593Smuzhiyun					0x0 0 0 2 &mbigen_pcie0 650 4
747*4882a593Smuzhiyun					0x0 0 0 3 &mbigen_pcie0 650 4
748*4882a593Smuzhiyun					0x0 0 0 4 &mbigen_pcie0 650 4>;
749*4882a593Smuzhiyun			status = "disabled";
750*4882a593Smuzhiyun		};
751*4882a593Smuzhiyun
752*4882a593Smuzhiyun	};
753*4882a593Smuzhiyun
754*4882a593Smuzhiyun};
755