xref: /OK3568_Linux_fs/kernel/arch/arm/boot/dts/qcom-msm8974.dtsi (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun// SPDX-License-Identifier: GPL-2.0
2*4882a593Smuzhiyun/dts-v1/;
3*4882a593Smuzhiyun
4*4882a593Smuzhiyun#include <dt-bindings/interconnect/qcom,msm8974.h>
5*4882a593Smuzhiyun#include <dt-bindings/interrupt-controller/arm-gic.h>
6*4882a593Smuzhiyun#include <dt-bindings/clock/qcom,gcc-msm8974.h>
7*4882a593Smuzhiyun#include <dt-bindings/clock/qcom,mmcc-msm8974.h>
8*4882a593Smuzhiyun#include <dt-bindings/clock/qcom,rpmcc.h>
9*4882a593Smuzhiyun#include <dt-bindings/reset/qcom,gcc-msm8974.h>
10*4882a593Smuzhiyun#include <dt-bindings/gpio/gpio.h>
11*4882a593Smuzhiyun
12*4882a593Smuzhiyun/ {
13*4882a593Smuzhiyun	#address-cells = <1>;
14*4882a593Smuzhiyun	#size-cells = <1>;
15*4882a593Smuzhiyun	model = "Qualcomm MSM8974";
16*4882a593Smuzhiyun	compatible = "qcom,msm8974";
17*4882a593Smuzhiyun	interrupt-parent = <&intc>;
18*4882a593Smuzhiyun
19*4882a593Smuzhiyun	reserved-memory {
20*4882a593Smuzhiyun		#address-cells = <1>;
21*4882a593Smuzhiyun		#size-cells = <1>;
22*4882a593Smuzhiyun		ranges;
23*4882a593Smuzhiyun
24*4882a593Smuzhiyun		mpss_region: mpss@8000000 {
25*4882a593Smuzhiyun			reg = <0x08000000 0x5100000>;
26*4882a593Smuzhiyun			no-map;
27*4882a593Smuzhiyun		};
28*4882a593Smuzhiyun
29*4882a593Smuzhiyun		mba_region: mba@d100000 {
30*4882a593Smuzhiyun			reg = <0x0d100000 0x100000>;
31*4882a593Smuzhiyun			no-map;
32*4882a593Smuzhiyun		};
33*4882a593Smuzhiyun
34*4882a593Smuzhiyun		wcnss_region: wcnss@d200000 {
35*4882a593Smuzhiyun			reg = <0x0d200000 0xa00000>;
36*4882a593Smuzhiyun			no-map;
37*4882a593Smuzhiyun		};
38*4882a593Smuzhiyun
39*4882a593Smuzhiyun		adsp_region: adsp@dc00000 {
40*4882a593Smuzhiyun			reg = <0x0dc00000 0x1900000>;
41*4882a593Smuzhiyun			no-map;
42*4882a593Smuzhiyun		};
43*4882a593Smuzhiyun
44*4882a593Smuzhiyun		venus@f500000 {
45*4882a593Smuzhiyun			reg = <0x0f500000 0x500000>;
46*4882a593Smuzhiyun			no-map;
47*4882a593Smuzhiyun		};
48*4882a593Smuzhiyun
49*4882a593Smuzhiyun		smem_region: smem@fa00000 {
50*4882a593Smuzhiyun			reg = <0xfa00000 0x200000>;
51*4882a593Smuzhiyun			no-map;
52*4882a593Smuzhiyun		};
53*4882a593Smuzhiyun
54*4882a593Smuzhiyun		tz@fc00000 {
55*4882a593Smuzhiyun			reg = <0x0fc00000 0x160000>;
56*4882a593Smuzhiyun			no-map;
57*4882a593Smuzhiyun		};
58*4882a593Smuzhiyun
59*4882a593Smuzhiyun		rfsa@fd60000 {
60*4882a593Smuzhiyun			reg = <0x0fd60000 0x20000>;
61*4882a593Smuzhiyun			no-map;
62*4882a593Smuzhiyun		};
63*4882a593Smuzhiyun
64*4882a593Smuzhiyun		rmtfs@fd80000 {
65*4882a593Smuzhiyun			compatible = "qcom,rmtfs-mem";
66*4882a593Smuzhiyun			reg = <0x0fd80000 0x180000>;
67*4882a593Smuzhiyun			no-map;
68*4882a593Smuzhiyun
69*4882a593Smuzhiyun			qcom,client-id = <1>;
70*4882a593Smuzhiyun		};
71*4882a593Smuzhiyun	};
72*4882a593Smuzhiyun
73*4882a593Smuzhiyun	cpus {
74*4882a593Smuzhiyun		#address-cells = <1>;
75*4882a593Smuzhiyun		#size-cells = <0>;
76*4882a593Smuzhiyun		interrupts = <GIC_PPI 9 0xf04>;
77*4882a593Smuzhiyun
78*4882a593Smuzhiyun		CPU0: cpu@0 {
79*4882a593Smuzhiyun			compatible = "qcom,krait";
80*4882a593Smuzhiyun			enable-method = "qcom,kpss-acc-v2";
81*4882a593Smuzhiyun			device_type = "cpu";
82*4882a593Smuzhiyun			reg = <0>;
83*4882a593Smuzhiyun			next-level-cache = <&L2>;
84*4882a593Smuzhiyun			qcom,acc = <&acc0>;
85*4882a593Smuzhiyun			qcom,saw = <&saw0>;
86*4882a593Smuzhiyun			cpu-idle-states = <&CPU_SPC>;
87*4882a593Smuzhiyun		};
88*4882a593Smuzhiyun
89*4882a593Smuzhiyun		CPU1: cpu@1 {
90*4882a593Smuzhiyun			compatible = "qcom,krait";
91*4882a593Smuzhiyun			enable-method = "qcom,kpss-acc-v2";
92*4882a593Smuzhiyun			device_type = "cpu";
93*4882a593Smuzhiyun			reg = <1>;
94*4882a593Smuzhiyun			next-level-cache = <&L2>;
95*4882a593Smuzhiyun			qcom,acc = <&acc1>;
96*4882a593Smuzhiyun			qcom,saw = <&saw1>;
97*4882a593Smuzhiyun			cpu-idle-states = <&CPU_SPC>;
98*4882a593Smuzhiyun		};
99*4882a593Smuzhiyun
100*4882a593Smuzhiyun		CPU2: cpu@2 {
101*4882a593Smuzhiyun			compatible = "qcom,krait";
102*4882a593Smuzhiyun			enable-method = "qcom,kpss-acc-v2";
103*4882a593Smuzhiyun			device_type = "cpu";
104*4882a593Smuzhiyun			reg = <2>;
105*4882a593Smuzhiyun			next-level-cache = <&L2>;
106*4882a593Smuzhiyun			qcom,acc = <&acc2>;
107*4882a593Smuzhiyun			qcom,saw = <&saw2>;
108*4882a593Smuzhiyun			cpu-idle-states = <&CPU_SPC>;
109*4882a593Smuzhiyun		};
110*4882a593Smuzhiyun
111*4882a593Smuzhiyun		CPU3: cpu@3 {
112*4882a593Smuzhiyun			compatible = "qcom,krait";
113*4882a593Smuzhiyun			enable-method = "qcom,kpss-acc-v2";
114*4882a593Smuzhiyun			device_type = "cpu";
115*4882a593Smuzhiyun			reg = <3>;
116*4882a593Smuzhiyun			next-level-cache = <&L2>;
117*4882a593Smuzhiyun			qcom,acc = <&acc3>;
118*4882a593Smuzhiyun			qcom,saw = <&saw3>;
119*4882a593Smuzhiyun			cpu-idle-states = <&CPU_SPC>;
120*4882a593Smuzhiyun		};
121*4882a593Smuzhiyun
122*4882a593Smuzhiyun		L2: l2-cache {
123*4882a593Smuzhiyun			compatible = "cache";
124*4882a593Smuzhiyun			cache-level = <2>;
125*4882a593Smuzhiyun			qcom,saw = <&saw_l2>;
126*4882a593Smuzhiyun		};
127*4882a593Smuzhiyun
128*4882a593Smuzhiyun		idle-states {
129*4882a593Smuzhiyun			CPU_SPC: spc {
130*4882a593Smuzhiyun				compatible = "qcom,idle-state-spc",
131*4882a593Smuzhiyun						"arm,idle-state";
132*4882a593Smuzhiyun				entry-latency-us = <150>;
133*4882a593Smuzhiyun				exit-latency-us = <200>;
134*4882a593Smuzhiyun				min-residency-us = <2000>;
135*4882a593Smuzhiyun			};
136*4882a593Smuzhiyun		};
137*4882a593Smuzhiyun	};
138*4882a593Smuzhiyun
139*4882a593Smuzhiyun	memory {
140*4882a593Smuzhiyun		device_type = "memory";
141*4882a593Smuzhiyun		reg = <0x0 0x0>;
142*4882a593Smuzhiyun	};
143*4882a593Smuzhiyun
144*4882a593Smuzhiyun	thermal-zones {
145*4882a593Smuzhiyun		cpu-thermal0 {
146*4882a593Smuzhiyun			polling-delay-passive = <250>;
147*4882a593Smuzhiyun			polling-delay = <1000>;
148*4882a593Smuzhiyun
149*4882a593Smuzhiyun			thermal-sensors = <&tsens 5>;
150*4882a593Smuzhiyun
151*4882a593Smuzhiyun			trips {
152*4882a593Smuzhiyun				cpu_alert0: trip0 {
153*4882a593Smuzhiyun					temperature = <75000>;
154*4882a593Smuzhiyun					hysteresis = <2000>;
155*4882a593Smuzhiyun					type = "passive";
156*4882a593Smuzhiyun				};
157*4882a593Smuzhiyun				cpu_crit0: trip1 {
158*4882a593Smuzhiyun					temperature = <110000>;
159*4882a593Smuzhiyun					hysteresis = <2000>;
160*4882a593Smuzhiyun					type = "critical";
161*4882a593Smuzhiyun				};
162*4882a593Smuzhiyun			};
163*4882a593Smuzhiyun		};
164*4882a593Smuzhiyun
165*4882a593Smuzhiyun		cpu-thermal1 {
166*4882a593Smuzhiyun			polling-delay-passive = <250>;
167*4882a593Smuzhiyun			polling-delay = <1000>;
168*4882a593Smuzhiyun
169*4882a593Smuzhiyun			thermal-sensors = <&tsens 6>;
170*4882a593Smuzhiyun
171*4882a593Smuzhiyun			trips {
172*4882a593Smuzhiyun				cpu_alert1: trip0 {
173*4882a593Smuzhiyun					temperature = <75000>;
174*4882a593Smuzhiyun					hysteresis = <2000>;
175*4882a593Smuzhiyun					type = "passive";
176*4882a593Smuzhiyun				};
177*4882a593Smuzhiyun				cpu_crit1: trip1 {
178*4882a593Smuzhiyun					temperature = <110000>;
179*4882a593Smuzhiyun					hysteresis = <2000>;
180*4882a593Smuzhiyun					type = "critical";
181*4882a593Smuzhiyun				};
182*4882a593Smuzhiyun			};
183*4882a593Smuzhiyun		};
184*4882a593Smuzhiyun
185*4882a593Smuzhiyun		cpu-thermal2 {
186*4882a593Smuzhiyun			polling-delay-passive = <250>;
187*4882a593Smuzhiyun			polling-delay = <1000>;
188*4882a593Smuzhiyun
189*4882a593Smuzhiyun			thermal-sensors = <&tsens 7>;
190*4882a593Smuzhiyun
191*4882a593Smuzhiyun			trips {
192*4882a593Smuzhiyun				cpu_alert2: trip0 {
193*4882a593Smuzhiyun					temperature = <75000>;
194*4882a593Smuzhiyun					hysteresis = <2000>;
195*4882a593Smuzhiyun					type = "passive";
196*4882a593Smuzhiyun				};
197*4882a593Smuzhiyun				cpu_crit2: trip1 {
198*4882a593Smuzhiyun					temperature = <110000>;
199*4882a593Smuzhiyun					hysteresis = <2000>;
200*4882a593Smuzhiyun					type = "critical";
201*4882a593Smuzhiyun				};
202*4882a593Smuzhiyun			};
203*4882a593Smuzhiyun		};
204*4882a593Smuzhiyun
205*4882a593Smuzhiyun		cpu-thermal3 {
206*4882a593Smuzhiyun			polling-delay-passive = <250>;
207*4882a593Smuzhiyun			polling-delay = <1000>;
208*4882a593Smuzhiyun
209*4882a593Smuzhiyun			thermal-sensors = <&tsens 8>;
210*4882a593Smuzhiyun
211*4882a593Smuzhiyun			trips {
212*4882a593Smuzhiyun				cpu_alert3: trip0 {
213*4882a593Smuzhiyun					temperature = <75000>;
214*4882a593Smuzhiyun					hysteresis = <2000>;
215*4882a593Smuzhiyun					type = "passive";
216*4882a593Smuzhiyun				};
217*4882a593Smuzhiyun				cpu_crit3: trip1 {
218*4882a593Smuzhiyun					temperature = <110000>;
219*4882a593Smuzhiyun					hysteresis = <2000>;
220*4882a593Smuzhiyun					type = "critical";
221*4882a593Smuzhiyun				};
222*4882a593Smuzhiyun			};
223*4882a593Smuzhiyun		};
224*4882a593Smuzhiyun
225*4882a593Smuzhiyun		q6-dsp-thermal {
226*4882a593Smuzhiyun			polling-delay-passive = <250>;
227*4882a593Smuzhiyun			polling-delay = <1000>;
228*4882a593Smuzhiyun
229*4882a593Smuzhiyun			thermal-sensors = <&tsens 1>;
230*4882a593Smuzhiyun
231*4882a593Smuzhiyun			trips {
232*4882a593Smuzhiyun				q6_dsp_alert0: trip-point0 {
233*4882a593Smuzhiyun					temperature = <90000>;
234*4882a593Smuzhiyun					hysteresis = <2000>;
235*4882a593Smuzhiyun					type = "hot";
236*4882a593Smuzhiyun				};
237*4882a593Smuzhiyun			};
238*4882a593Smuzhiyun		};
239*4882a593Smuzhiyun
240*4882a593Smuzhiyun		modemtx-thermal {
241*4882a593Smuzhiyun			polling-delay-passive = <250>;
242*4882a593Smuzhiyun			polling-delay = <1000>;
243*4882a593Smuzhiyun
244*4882a593Smuzhiyun			thermal-sensors = <&tsens 2>;
245*4882a593Smuzhiyun
246*4882a593Smuzhiyun			trips {
247*4882a593Smuzhiyun				modemtx_alert0: trip-point0 {
248*4882a593Smuzhiyun					temperature = <90000>;
249*4882a593Smuzhiyun					hysteresis = <2000>;
250*4882a593Smuzhiyun					type = "hot";
251*4882a593Smuzhiyun				};
252*4882a593Smuzhiyun			};
253*4882a593Smuzhiyun		};
254*4882a593Smuzhiyun
255*4882a593Smuzhiyun		video-thermal {
256*4882a593Smuzhiyun			polling-delay-passive = <250>;
257*4882a593Smuzhiyun			polling-delay = <1000>;
258*4882a593Smuzhiyun
259*4882a593Smuzhiyun			thermal-sensors = <&tsens 3>;
260*4882a593Smuzhiyun
261*4882a593Smuzhiyun			trips {
262*4882a593Smuzhiyun				video_alert0: trip-point0 {
263*4882a593Smuzhiyun					temperature = <95000>;
264*4882a593Smuzhiyun					hysteresis = <2000>;
265*4882a593Smuzhiyun					type = "hot";
266*4882a593Smuzhiyun				};
267*4882a593Smuzhiyun			};
268*4882a593Smuzhiyun		};
269*4882a593Smuzhiyun
270*4882a593Smuzhiyun		wlan-thermal {
271*4882a593Smuzhiyun			polling-delay-passive = <250>;
272*4882a593Smuzhiyun			polling-delay = <1000>;
273*4882a593Smuzhiyun
274*4882a593Smuzhiyun			thermal-sensors = <&tsens 4>;
275*4882a593Smuzhiyun
276*4882a593Smuzhiyun			trips {
277*4882a593Smuzhiyun				wlan_alert0: trip-point0 {
278*4882a593Smuzhiyun					temperature = <105000>;
279*4882a593Smuzhiyun					hysteresis = <2000>;
280*4882a593Smuzhiyun					type = "hot";
281*4882a593Smuzhiyun				};
282*4882a593Smuzhiyun			};
283*4882a593Smuzhiyun		};
284*4882a593Smuzhiyun
285*4882a593Smuzhiyun		gpu-thermal-top {
286*4882a593Smuzhiyun			polling-delay-passive = <250>;
287*4882a593Smuzhiyun			polling-delay = <1000>;
288*4882a593Smuzhiyun
289*4882a593Smuzhiyun			thermal-sensors = <&tsens 9>;
290*4882a593Smuzhiyun
291*4882a593Smuzhiyun			trips {
292*4882a593Smuzhiyun				gpu1_alert0: trip-point0 {
293*4882a593Smuzhiyun					temperature = <90000>;
294*4882a593Smuzhiyun					hysteresis = <2000>;
295*4882a593Smuzhiyun					type = "hot";
296*4882a593Smuzhiyun				};
297*4882a593Smuzhiyun			};
298*4882a593Smuzhiyun		};
299*4882a593Smuzhiyun
300*4882a593Smuzhiyun		gpu-thermal-bottom {
301*4882a593Smuzhiyun			polling-delay-passive = <250>;
302*4882a593Smuzhiyun			polling-delay = <1000>;
303*4882a593Smuzhiyun
304*4882a593Smuzhiyun			thermal-sensors = <&tsens 10>;
305*4882a593Smuzhiyun
306*4882a593Smuzhiyun			trips {
307*4882a593Smuzhiyun				gpu2_alert0: trip-point0 {
308*4882a593Smuzhiyun					temperature = <90000>;
309*4882a593Smuzhiyun					hysteresis = <2000>;
310*4882a593Smuzhiyun					type = "hot";
311*4882a593Smuzhiyun				};
312*4882a593Smuzhiyun			};
313*4882a593Smuzhiyun		};
314*4882a593Smuzhiyun	};
315*4882a593Smuzhiyun
316*4882a593Smuzhiyun	cpu-pmu {
317*4882a593Smuzhiyun		compatible = "qcom,krait-pmu";
318*4882a593Smuzhiyun		interrupts = <GIC_PPI 7 0xf04>;
319*4882a593Smuzhiyun	};
320*4882a593Smuzhiyun
321*4882a593Smuzhiyun	clocks {
322*4882a593Smuzhiyun		xo_board: xo_board {
323*4882a593Smuzhiyun			compatible = "fixed-clock";
324*4882a593Smuzhiyun			#clock-cells = <0>;
325*4882a593Smuzhiyun			clock-frequency = <19200000>;
326*4882a593Smuzhiyun		};
327*4882a593Smuzhiyun
328*4882a593Smuzhiyun		sleep_clk: sleep_clk {
329*4882a593Smuzhiyun			compatible = "fixed-clock";
330*4882a593Smuzhiyun			#clock-cells = <0>;
331*4882a593Smuzhiyun			clock-frequency = <32768>;
332*4882a593Smuzhiyun		};
333*4882a593Smuzhiyun	};
334*4882a593Smuzhiyun
335*4882a593Smuzhiyun	timer {
336*4882a593Smuzhiyun		compatible = "arm,armv7-timer";
337*4882a593Smuzhiyun		interrupts = <GIC_PPI 2 0xf08>,
338*4882a593Smuzhiyun			     <GIC_PPI 3 0xf08>,
339*4882a593Smuzhiyun			     <GIC_PPI 4 0xf08>,
340*4882a593Smuzhiyun			     <GIC_PPI 1 0xf08>;
341*4882a593Smuzhiyun		clock-frequency = <19200000>;
342*4882a593Smuzhiyun	};
343*4882a593Smuzhiyun
344*4882a593Smuzhiyun	adsp-pil {
345*4882a593Smuzhiyun		compatible = "qcom,msm8974-adsp-pil";
346*4882a593Smuzhiyun
347*4882a593Smuzhiyun		interrupts-extended = <&intc GIC_SPI 162 IRQ_TYPE_EDGE_RISING>,
348*4882a593Smuzhiyun				      <&adsp_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
349*4882a593Smuzhiyun				      <&adsp_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
350*4882a593Smuzhiyun				      <&adsp_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
351*4882a593Smuzhiyun				      <&adsp_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
352*4882a593Smuzhiyun		interrupt-names = "wdog", "fatal", "ready", "handover", "stop-ack";
353*4882a593Smuzhiyun
354*4882a593Smuzhiyun		cx-supply = <&pm8841_s2>;
355*4882a593Smuzhiyun
356*4882a593Smuzhiyun		clocks = <&xo_board>;
357*4882a593Smuzhiyun		clock-names = "xo";
358*4882a593Smuzhiyun
359*4882a593Smuzhiyun		memory-region = <&adsp_region>;
360*4882a593Smuzhiyun
361*4882a593Smuzhiyun		qcom,smem-states = <&adsp_smp2p_out 0>;
362*4882a593Smuzhiyun		qcom,smem-state-names = "stop";
363*4882a593Smuzhiyun
364*4882a593Smuzhiyun		smd-edge {
365*4882a593Smuzhiyun			interrupts = <GIC_SPI 156 IRQ_TYPE_EDGE_RISING>;
366*4882a593Smuzhiyun
367*4882a593Smuzhiyun			qcom,ipc = <&apcs 8 8>;
368*4882a593Smuzhiyun			qcom,smd-edge = <1>;
369*4882a593Smuzhiyun
370*4882a593Smuzhiyun			label = "lpass";
371*4882a593Smuzhiyun		};
372*4882a593Smuzhiyun	};
373*4882a593Smuzhiyun
374*4882a593Smuzhiyun	smem {
375*4882a593Smuzhiyun		compatible = "qcom,smem";
376*4882a593Smuzhiyun
377*4882a593Smuzhiyun		memory-region = <&smem_region>;
378*4882a593Smuzhiyun		qcom,rpm-msg-ram = <&rpm_msg_ram>;
379*4882a593Smuzhiyun
380*4882a593Smuzhiyun		hwlocks = <&tcsr_mutex 3>;
381*4882a593Smuzhiyun	};
382*4882a593Smuzhiyun
383*4882a593Smuzhiyun	smp2p-adsp {
384*4882a593Smuzhiyun		compatible = "qcom,smp2p";
385*4882a593Smuzhiyun		qcom,smem = <443>, <429>;
386*4882a593Smuzhiyun
387*4882a593Smuzhiyun		interrupt-parent = <&intc>;
388*4882a593Smuzhiyun		interrupts = <GIC_SPI 158 IRQ_TYPE_EDGE_RISING>;
389*4882a593Smuzhiyun
390*4882a593Smuzhiyun		qcom,ipc = <&apcs 8 10>;
391*4882a593Smuzhiyun
392*4882a593Smuzhiyun		qcom,local-pid = <0>;
393*4882a593Smuzhiyun		qcom,remote-pid = <2>;
394*4882a593Smuzhiyun
395*4882a593Smuzhiyun		adsp_smp2p_out: master-kernel {
396*4882a593Smuzhiyun			qcom,entry-name = "master-kernel";
397*4882a593Smuzhiyun			#qcom,smem-state-cells = <1>;
398*4882a593Smuzhiyun		};
399*4882a593Smuzhiyun
400*4882a593Smuzhiyun		adsp_smp2p_in: slave-kernel {
401*4882a593Smuzhiyun			qcom,entry-name = "slave-kernel";
402*4882a593Smuzhiyun
403*4882a593Smuzhiyun			interrupt-controller;
404*4882a593Smuzhiyun			#interrupt-cells = <2>;
405*4882a593Smuzhiyun		};
406*4882a593Smuzhiyun	};
407*4882a593Smuzhiyun
408*4882a593Smuzhiyun	smp2p-modem {
409*4882a593Smuzhiyun		compatible = "qcom,smp2p";
410*4882a593Smuzhiyun		qcom,smem = <435>, <428>;
411*4882a593Smuzhiyun
412*4882a593Smuzhiyun		interrupt-parent = <&intc>;
413*4882a593Smuzhiyun		interrupts = <GIC_SPI 27 IRQ_TYPE_EDGE_RISING>;
414*4882a593Smuzhiyun
415*4882a593Smuzhiyun		qcom,ipc = <&apcs 8 14>;
416*4882a593Smuzhiyun
417*4882a593Smuzhiyun		qcom,local-pid = <0>;
418*4882a593Smuzhiyun		qcom,remote-pid = <1>;
419*4882a593Smuzhiyun
420*4882a593Smuzhiyun		modem_smp2p_out: master-kernel {
421*4882a593Smuzhiyun			qcom,entry-name = "master-kernel";
422*4882a593Smuzhiyun			#qcom,smem-state-cells = <1>;
423*4882a593Smuzhiyun		};
424*4882a593Smuzhiyun
425*4882a593Smuzhiyun		modem_smp2p_in: slave-kernel {
426*4882a593Smuzhiyun			qcom,entry-name = "slave-kernel";
427*4882a593Smuzhiyun
428*4882a593Smuzhiyun			interrupt-controller;
429*4882a593Smuzhiyun			#interrupt-cells = <2>;
430*4882a593Smuzhiyun		};
431*4882a593Smuzhiyun	};
432*4882a593Smuzhiyun
433*4882a593Smuzhiyun	smp2p-wcnss {
434*4882a593Smuzhiyun		compatible = "qcom,smp2p";
435*4882a593Smuzhiyun		qcom,smem = <451>, <431>;
436*4882a593Smuzhiyun
437*4882a593Smuzhiyun		interrupt-parent = <&intc>;
438*4882a593Smuzhiyun		interrupts = <GIC_SPI 143 IRQ_TYPE_EDGE_RISING>;
439*4882a593Smuzhiyun
440*4882a593Smuzhiyun		qcom,ipc = <&apcs 8 18>;
441*4882a593Smuzhiyun
442*4882a593Smuzhiyun		qcom,local-pid = <0>;
443*4882a593Smuzhiyun		qcom,remote-pid = <4>;
444*4882a593Smuzhiyun
445*4882a593Smuzhiyun		wcnss_smp2p_out: master-kernel {
446*4882a593Smuzhiyun			qcom,entry-name = "master-kernel";
447*4882a593Smuzhiyun
448*4882a593Smuzhiyun			#qcom,smem-state-cells = <1>;
449*4882a593Smuzhiyun		};
450*4882a593Smuzhiyun
451*4882a593Smuzhiyun		wcnss_smp2p_in: slave-kernel {
452*4882a593Smuzhiyun			qcom,entry-name = "slave-kernel";
453*4882a593Smuzhiyun
454*4882a593Smuzhiyun			interrupt-controller;
455*4882a593Smuzhiyun			#interrupt-cells = <2>;
456*4882a593Smuzhiyun		};
457*4882a593Smuzhiyun	};
458*4882a593Smuzhiyun
459*4882a593Smuzhiyun	smsm {
460*4882a593Smuzhiyun		compatible = "qcom,smsm";
461*4882a593Smuzhiyun
462*4882a593Smuzhiyun		#address-cells = <1>;
463*4882a593Smuzhiyun		#size-cells = <0>;
464*4882a593Smuzhiyun
465*4882a593Smuzhiyun		qcom,ipc-1 = <&apcs 8 13>;
466*4882a593Smuzhiyun		qcom,ipc-2 = <&apcs 8 9>;
467*4882a593Smuzhiyun		qcom,ipc-3 = <&apcs 8 19>;
468*4882a593Smuzhiyun
469*4882a593Smuzhiyun		apps_smsm: apps@0 {
470*4882a593Smuzhiyun			reg = <0>;
471*4882a593Smuzhiyun
472*4882a593Smuzhiyun			#qcom,smem-state-cells = <1>;
473*4882a593Smuzhiyun		};
474*4882a593Smuzhiyun
475*4882a593Smuzhiyun		modem_smsm: modem@1 {
476*4882a593Smuzhiyun			reg = <1>;
477*4882a593Smuzhiyun			interrupts = <GIC_SPI 26 IRQ_TYPE_EDGE_RISING>;
478*4882a593Smuzhiyun
479*4882a593Smuzhiyun			interrupt-controller;
480*4882a593Smuzhiyun			#interrupt-cells = <2>;
481*4882a593Smuzhiyun		};
482*4882a593Smuzhiyun
483*4882a593Smuzhiyun		adsp_smsm: adsp@2 {
484*4882a593Smuzhiyun			reg = <2>;
485*4882a593Smuzhiyun			interrupts = <GIC_SPI 157 IRQ_TYPE_EDGE_RISING>;
486*4882a593Smuzhiyun
487*4882a593Smuzhiyun			interrupt-controller;
488*4882a593Smuzhiyun			#interrupt-cells = <2>;
489*4882a593Smuzhiyun		};
490*4882a593Smuzhiyun
491*4882a593Smuzhiyun		wcnss_smsm: wcnss@7 {
492*4882a593Smuzhiyun			reg = <7>;
493*4882a593Smuzhiyun			interrupts = <GIC_SPI 144 IRQ_TYPE_EDGE_RISING>;
494*4882a593Smuzhiyun
495*4882a593Smuzhiyun			interrupt-controller;
496*4882a593Smuzhiyun			#interrupt-cells = <2>;
497*4882a593Smuzhiyun		};
498*4882a593Smuzhiyun	};
499*4882a593Smuzhiyun
500*4882a593Smuzhiyun	firmware {
501*4882a593Smuzhiyun		scm {
502*4882a593Smuzhiyun			compatible = "qcom,scm";
503*4882a593Smuzhiyun			clocks = <&gcc GCC_CE1_CLK>, <&gcc GCC_CE1_AXI_CLK>, <&gcc GCC_CE1_AHB_CLK>;
504*4882a593Smuzhiyun			clock-names = "core", "bus", "iface";
505*4882a593Smuzhiyun		};
506*4882a593Smuzhiyun	};
507*4882a593Smuzhiyun
508*4882a593Smuzhiyun	soc: soc {
509*4882a593Smuzhiyun		#address-cells = <1>;
510*4882a593Smuzhiyun		#size-cells = <1>;
511*4882a593Smuzhiyun		ranges;
512*4882a593Smuzhiyun		compatible = "simple-bus";
513*4882a593Smuzhiyun
514*4882a593Smuzhiyun		intc: interrupt-controller@f9000000 {
515*4882a593Smuzhiyun			compatible = "qcom,msm-qgic2";
516*4882a593Smuzhiyun			interrupt-controller;
517*4882a593Smuzhiyun			#interrupt-cells = <3>;
518*4882a593Smuzhiyun			reg = <0xf9000000 0x1000>,
519*4882a593Smuzhiyun			      <0xf9002000 0x1000>;
520*4882a593Smuzhiyun		};
521*4882a593Smuzhiyun
522*4882a593Smuzhiyun		apcs: syscon@f9011000 {
523*4882a593Smuzhiyun			compatible = "syscon";
524*4882a593Smuzhiyun			reg = <0xf9011000 0x1000>;
525*4882a593Smuzhiyun		};
526*4882a593Smuzhiyun
527*4882a593Smuzhiyun		qfprom: qfprom@fc4bc000 {
528*4882a593Smuzhiyun			#address-cells = <1>;
529*4882a593Smuzhiyun			#size-cells = <1>;
530*4882a593Smuzhiyun			compatible = "qcom,qfprom";
531*4882a593Smuzhiyun			reg = <0xfc4bc000 0x1000>;
532*4882a593Smuzhiyun			tsens_calib: calib@d0 {
533*4882a593Smuzhiyun				reg = <0xd0 0x18>;
534*4882a593Smuzhiyun			};
535*4882a593Smuzhiyun			tsens_backup: backup@440 {
536*4882a593Smuzhiyun				reg = <0x440 0x10>;
537*4882a593Smuzhiyun			};
538*4882a593Smuzhiyun		};
539*4882a593Smuzhiyun
540*4882a593Smuzhiyun		tsens: thermal-sensor@fc4a9000 {
541*4882a593Smuzhiyun			compatible = "qcom,msm8974-tsens";
542*4882a593Smuzhiyun			reg = <0xfc4a9000 0x1000>, /* TM */
543*4882a593Smuzhiyun			      <0xfc4a8000 0x1000>; /* SROT */
544*4882a593Smuzhiyun			nvmem-cells = <&tsens_calib>, <&tsens_backup>;
545*4882a593Smuzhiyun			nvmem-cell-names = "calib", "calib_backup";
546*4882a593Smuzhiyun			#qcom,sensors = <11>;
547*4882a593Smuzhiyun			interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>;
548*4882a593Smuzhiyun			interrupt-names = "uplow";
549*4882a593Smuzhiyun			#thermal-sensor-cells = <1>;
550*4882a593Smuzhiyun		};
551*4882a593Smuzhiyun
552*4882a593Smuzhiyun		timer@f9020000 {
553*4882a593Smuzhiyun			#address-cells = <1>;
554*4882a593Smuzhiyun			#size-cells = <1>;
555*4882a593Smuzhiyun			ranges;
556*4882a593Smuzhiyun			compatible = "arm,armv7-timer-mem";
557*4882a593Smuzhiyun			reg = <0xf9020000 0x1000>;
558*4882a593Smuzhiyun			clock-frequency = <19200000>;
559*4882a593Smuzhiyun
560*4882a593Smuzhiyun			frame@f9021000 {
561*4882a593Smuzhiyun				frame-number = <0>;
562*4882a593Smuzhiyun				interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>,
563*4882a593Smuzhiyun					     <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
564*4882a593Smuzhiyun				reg = <0xf9021000 0x1000>,
565*4882a593Smuzhiyun				      <0xf9022000 0x1000>;
566*4882a593Smuzhiyun			};
567*4882a593Smuzhiyun
568*4882a593Smuzhiyun			frame@f9023000 {
569*4882a593Smuzhiyun				frame-number = <1>;
570*4882a593Smuzhiyun				interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
571*4882a593Smuzhiyun				reg = <0xf9023000 0x1000>;
572*4882a593Smuzhiyun				status = "disabled";
573*4882a593Smuzhiyun			};
574*4882a593Smuzhiyun
575*4882a593Smuzhiyun			frame@f9024000 {
576*4882a593Smuzhiyun				frame-number = <2>;
577*4882a593Smuzhiyun				interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
578*4882a593Smuzhiyun				reg = <0xf9024000 0x1000>;
579*4882a593Smuzhiyun				status = "disabled";
580*4882a593Smuzhiyun			};
581*4882a593Smuzhiyun
582*4882a593Smuzhiyun			frame@f9025000 {
583*4882a593Smuzhiyun				frame-number = <3>;
584*4882a593Smuzhiyun				interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
585*4882a593Smuzhiyun				reg = <0xf9025000 0x1000>;
586*4882a593Smuzhiyun				status = "disabled";
587*4882a593Smuzhiyun			};
588*4882a593Smuzhiyun
589*4882a593Smuzhiyun			frame@f9026000 {
590*4882a593Smuzhiyun				frame-number = <4>;
591*4882a593Smuzhiyun				interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
592*4882a593Smuzhiyun				reg = <0xf9026000 0x1000>;
593*4882a593Smuzhiyun				status = "disabled";
594*4882a593Smuzhiyun			};
595*4882a593Smuzhiyun
596*4882a593Smuzhiyun			frame@f9027000 {
597*4882a593Smuzhiyun				frame-number = <5>;
598*4882a593Smuzhiyun				interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
599*4882a593Smuzhiyun				reg = <0xf9027000 0x1000>;
600*4882a593Smuzhiyun				status = "disabled";
601*4882a593Smuzhiyun			};
602*4882a593Smuzhiyun
603*4882a593Smuzhiyun			frame@f9028000 {
604*4882a593Smuzhiyun				frame-number = <6>;
605*4882a593Smuzhiyun				interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
606*4882a593Smuzhiyun				reg = <0xf9028000 0x1000>;
607*4882a593Smuzhiyun				status = "disabled";
608*4882a593Smuzhiyun			};
609*4882a593Smuzhiyun		};
610*4882a593Smuzhiyun
611*4882a593Smuzhiyun		saw0: power-controller@f9089000 {
612*4882a593Smuzhiyun			compatible = "qcom,msm8974-saw2-v2.1-cpu", "qcom,saw2";
613*4882a593Smuzhiyun			reg = <0xf9089000 0x1000>, <0xf9009000 0x1000>;
614*4882a593Smuzhiyun		};
615*4882a593Smuzhiyun
616*4882a593Smuzhiyun		saw1: power-controller@f9099000 {
617*4882a593Smuzhiyun			compatible = "qcom,msm8974-saw2-v2.1-cpu", "qcom,saw2";
618*4882a593Smuzhiyun			reg = <0xf9099000 0x1000>, <0xf9009000 0x1000>;
619*4882a593Smuzhiyun		};
620*4882a593Smuzhiyun
621*4882a593Smuzhiyun		saw2: power-controller@f90a9000 {
622*4882a593Smuzhiyun			compatible = "qcom,msm8974-saw2-v2.1-cpu", "qcom,saw2";
623*4882a593Smuzhiyun			reg = <0xf90a9000 0x1000>, <0xf9009000 0x1000>;
624*4882a593Smuzhiyun		};
625*4882a593Smuzhiyun
626*4882a593Smuzhiyun		saw3: power-controller@f90b9000 {
627*4882a593Smuzhiyun			compatible = "qcom,msm8974-saw2-v2.1-cpu", "qcom,saw2";
628*4882a593Smuzhiyun			reg = <0xf90b9000 0x1000>, <0xf9009000 0x1000>;
629*4882a593Smuzhiyun		};
630*4882a593Smuzhiyun
631*4882a593Smuzhiyun		saw_l2: power-controller@f9012000 {
632*4882a593Smuzhiyun			compatible = "qcom,saw2";
633*4882a593Smuzhiyun			reg = <0xf9012000 0x1000>;
634*4882a593Smuzhiyun			regulator;
635*4882a593Smuzhiyun		};
636*4882a593Smuzhiyun
637*4882a593Smuzhiyun		acc0: clock-controller@f9088000 {
638*4882a593Smuzhiyun			compatible = "qcom,kpss-acc-v2";
639*4882a593Smuzhiyun			reg = <0xf9088000 0x1000>, <0xf9008000 0x1000>;
640*4882a593Smuzhiyun		};
641*4882a593Smuzhiyun
642*4882a593Smuzhiyun		acc1: clock-controller@f9098000 {
643*4882a593Smuzhiyun			compatible = "qcom,kpss-acc-v2";
644*4882a593Smuzhiyun			reg = <0xf9098000 0x1000>, <0xf9008000 0x1000>;
645*4882a593Smuzhiyun		};
646*4882a593Smuzhiyun
647*4882a593Smuzhiyun		acc2: clock-controller@f90a8000 {
648*4882a593Smuzhiyun			compatible = "qcom,kpss-acc-v2";
649*4882a593Smuzhiyun			reg = <0xf90a8000 0x1000>, <0xf9008000 0x1000>;
650*4882a593Smuzhiyun		};
651*4882a593Smuzhiyun
652*4882a593Smuzhiyun		acc3: clock-controller@f90b8000 {
653*4882a593Smuzhiyun			compatible = "qcom,kpss-acc-v2";
654*4882a593Smuzhiyun			reg = <0xf90b8000 0x1000>, <0xf9008000 0x1000>;
655*4882a593Smuzhiyun		};
656*4882a593Smuzhiyun
657*4882a593Smuzhiyun		restart@fc4ab000 {
658*4882a593Smuzhiyun			compatible = "qcom,pshold";
659*4882a593Smuzhiyun			reg = <0xfc4ab000 0x4>;
660*4882a593Smuzhiyun		};
661*4882a593Smuzhiyun
662*4882a593Smuzhiyun		gcc: clock-controller@fc400000 {
663*4882a593Smuzhiyun			compatible = "qcom,gcc-msm8974";
664*4882a593Smuzhiyun			#clock-cells = <1>;
665*4882a593Smuzhiyun			#reset-cells = <1>;
666*4882a593Smuzhiyun			#power-domain-cells = <1>;
667*4882a593Smuzhiyun			reg = <0xfc400000 0x4000>;
668*4882a593Smuzhiyun		};
669*4882a593Smuzhiyun
670*4882a593Smuzhiyun		tcsr: syscon@fd4a0000 {
671*4882a593Smuzhiyun			compatible = "syscon";
672*4882a593Smuzhiyun			reg = <0xfd4a0000 0x10000>;
673*4882a593Smuzhiyun		};
674*4882a593Smuzhiyun
675*4882a593Smuzhiyun		tcsr_mutex_block: syscon@fd484000 {
676*4882a593Smuzhiyun			compatible = "syscon";
677*4882a593Smuzhiyun			reg = <0xfd484000 0x2000>;
678*4882a593Smuzhiyun		};
679*4882a593Smuzhiyun
680*4882a593Smuzhiyun		mmcc: clock-controller@fd8c0000 {
681*4882a593Smuzhiyun			compatible = "qcom,mmcc-msm8974";
682*4882a593Smuzhiyun			#clock-cells = <1>;
683*4882a593Smuzhiyun			#reset-cells = <1>;
684*4882a593Smuzhiyun			#power-domain-cells = <1>;
685*4882a593Smuzhiyun			reg = <0xfd8c0000 0x6000>;
686*4882a593Smuzhiyun		};
687*4882a593Smuzhiyun
688*4882a593Smuzhiyun		tcsr_mutex: tcsr-mutex {
689*4882a593Smuzhiyun			compatible = "qcom,tcsr-mutex";
690*4882a593Smuzhiyun			syscon = <&tcsr_mutex_block 0 0x80>;
691*4882a593Smuzhiyun
692*4882a593Smuzhiyun			#hwlock-cells = <1>;
693*4882a593Smuzhiyun		};
694*4882a593Smuzhiyun
695*4882a593Smuzhiyun		rpm_msg_ram: memory@fc428000 {
696*4882a593Smuzhiyun			compatible = "qcom,rpm-msg-ram";
697*4882a593Smuzhiyun			reg = <0xfc428000 0x4000>;
698*4882a593Smuzhiyun		};
699*4882a593Smuzhiyun
700*4882a593Smuzhiyun		blsp1_uart1: serial@f991d000 {
701*4882a593Smuzhiyun			compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm";
702*4882a593Smuzhiyun			reg = <0xf991d000 0x1000>;
703*4882a593Smuzhiyun			interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
704*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP1_UART1_APPS_CLK>, <&gcc GCC_BLSP1_AHB_CLK>;
705*4882a593Smuzhiyun			clock-names = "core", "iface";
706*4882a593Smuzhiyun			status = "disabled";
707*4882a593Smuzhiyun		};
708*4882a593Smuzhiyun
709*4882a593Smuzhiyun		blsp1_uart2: serial@f991e000 {
710*4882a593Smuzhiyun			compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm";
711*4882a593Smuzhiyun			reg = <0xf991e000 0x1000>;
712*4882a593Smuzhiyun			interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
713*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP1_UART2_APPS_CLK>, <&gcc GCC_BLSP1_AHB_CLK>;
714*4882a593Smuzhiyun			clock-names = "core", "iface";
715*4882a593Smuzhiyun			status = "disabled";
716*4882a593Smuzhiyun		};
717*4882a593Smuzhiyun
718*4882a593Smuzhiyun		blsp2_uart10: serial@f9960000 {
719*4882a593Smuzhiyun			compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm";
720*4882a593Smuzhiyun			reg = <0xf9960000 0x1000>;
721*4882a593Smuzhiyun			interrupts = <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>;
722*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP2_UART4_APPS_CLK>, <&gcc GCC_BLSP2_AHB_CLK>;
723*4882a593Smuzhiyun			clock-names = "core", "iface";
724*4882a593Smuzhiyun			status = "disabled";
725*4882a593Smuzhiyun		};
726*4882a593Smuzhiyun
727*4882a593Smuzhiyun		sdhci@f9824900 {
728*4882a593Smuzhiyun			compatible = "qcom,msm8974-sdhci", "qcom,sdhci-msm-v4";
729*4882a593Smuzhiyun			reg = <0xf9824900 0x11c>, <0xf9824000 0x800>;
730*4882a593Smuzhiyun			reg-names = "hc_mem", "core_mem";
731*4882a593Smuzhiyun			interrupts = <GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>,
732*4882a593Smuzhiyun				     <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>;
733*4882a593Smuzhiyun			interrupt-names = "hc_irq", "pwr_irq";
734*4882a593Smuzhiyun			clocks = <&gcc GCC_SDCC1_APPS_CLK>,
735*4882a593Smuzhiyun				 <&gcc GCC_SDCC1_AHB_CLK>,
736*4882a593Smuzhiyun				 <&xo_board>;
737*4882a593Smuzhiyun			clock-names = "core", "iface", "xo";
738*4882a593Smuzhiyun			status = "disabled";
739*4882a593Smuzhiyun		};
740*4882a593Smuzhiyun
741*4882a593Smuzhiyun		sdhci@f9864900 {
742*4882a593Smuzhiyun			compatible = "qcom,msm8974-sdhci", "qcom,sdhci-msm-v4";
743*4882a593Smuzhiyun			reg = <0xf9864900 0x11c>, <0xf9864000 0x800>;
744*4882a593Smuzhiyun			reg-names = "hc_mem", "core_mem";
745*4882a593Smuzhiyun			interrupts = <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
746*4882a593Smuzhiyun				     <GIC_SPI 224 IRQ_TYPE_LEVEL_HIGH>;
747*4882a593Smuzhiyun			interrupt-names = "hc_irq", "pwr_irq";
748*4882a593Smuzhiyun			clocks = <&gcc GCC_SDCC3_APPS_CLK>,
749*4882a593Smuzhiyun				 <&gcc GCC_SDCC3_AHB_CLK>,
750*4882a593Smuzhiyun				 <&xo_board>;
751*4882a593Smuzhiyun			clock-names = "core", "iface", "xo";
752*4882a593Smuzhiyun			status = "disabled";
753*4882a593Smuzhiyun		};
754*4882a593Smuzhiyun
755*4882a593Smuzhiyun		sdhci@f98a4900 {
756*4882a593Smuzhiyun			compatible = "qcom,msm8974-sdhci", "qcom,sdhci-msm-v4";
757*4882a593Smuzhiyun			reg = <0xf98a4900 0x11c>, <0xf98a4000 0x800>;
758*4882a593Smuzhiyun			reg-names = "hc_mem", "core_mem";
759*4882a593Smuzhiyun			interrupts = <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>,
760*4882a593Smuzhiyun				     <GIC_SPI 221 IRQ_TYPE_LEVEL_HIGH>;
761*4882a593Smuzhiyun			interrupt-names = "hc_irq", "pwr_irq";
762*4882a593Smuzhiyun			clocks = <&gcc GCC_SDCC2_APPS_CLK>,
763*4882a593Smuzhiyun				 <&gcc GCC_SDCC2_AHB_CLK>,
764*4882a593Smuzhiyun				 <&xo_board>;
765*4882a593Smuzhiyun			clock-names = "core", "iface", "xo";
766*4882a593Smuzhiyun			status = "disabled";
767*4882a593Smuzhiyun		};
768*4882a593Smuzhiyun
769*4882a593Smuzhiyun		otg: usb@f9a55000 {
770*4882a593Smuzhiyun			compatible = "qcom,ci-hdrc";
771*4882a593Smuzhiyun			reg = <0xf9a55000 0x200>,
772*4882a593Smuzhiyun			      <0xf9a55200 0x200>;
773*4882a593Smuzhiyun			interrupts = <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>;
774*4882a593Smuzhiyun			clocks = <&gcc GCC_USB_HS_AHB_CLK>,
775*4882a593Smuzhiyun				 <&gcc GCC_USB_HS_SYSTEM_CLK>;
776*4882a593Smuzhiyun			clock-names = "iface", "core";
777*4882a593Smuzhiyun			assigned-clocks = <&gcc GCC_USB_HS_SYSTEM_CLK>;
778*4882a593Smuzhiyun			assigned-clock-rates = <75000000>;
779*4882a593Smuzhiyun			resets = <&gcc GCC_USB_HS_BCR>;
780*4882a593Smuzhiyun			reset-names = "core";
781*4882a593Smuzhiyun			phy_type = "ulpi";
782*4882a593Smuzhiyun			dr_mode = "otg";
783*4882a593Smuzhiyun			ahb-burst-config = <0>;
784*4882a593Smuzhiyun			phy-names = "usb-phy";
785*4882a593Smuzhiyun			status = "disabled";
786*4882a593Smuzhiyun			#reset-cells = <1>;
787*4882a593Smuzhiyun
788*4882a593Smuzhiyun			ulpi {
789*4882a593Smuzhiyun				usb_hs1_phy: phy@a {
790*4882a593Smuzhiyun					compatible = "qcom,usb-hs-phy-msm8974",
791*4882a593Smuzhiyun						     "qcom,usb-hs-phy";
792*4882a593Smuzhiyun					#phy-cells = <0>;
793*4882a593Smuzhiyun					clocks = <&xo_board>, <&gcc GCC_USB2A_PHY_SLEEP_CLK>;
794*4882a593Smuzhiyun					clock-names = "ref", "sleep";
795*4882a593Smuzhiyun					resets = <&gcc GCC_USB2A_PHY_BCR>, <&otg 0>;
796*4882a593Smuzhiyun					reset-names = "phy", "por";
797*4882a593Smuzhiyun					status = "disabled";
798*4882a593Smuzhiyun				};
799*4882a593Smuzhiyun
800*4882a593Smuzhiyun				usb_hs2_phy: phy@b {
801*4882a593Smuzhiyun					compatible = "qcom,usb-hs-phy-msm8974",
802*4882a593Smuzhiyun						     "qcom,usb-hs-phy";
803*4882a593Smuzhiyun					#phy-cells = <0>;
804*4882a593Smuzhiyun					clocks = <&xo_board>, <&gcc GCC_USB2B_PHY_SLEEP_CLK>;
805*4882a593Smuzhiyun					clock-names = "ref", "sleep";
806*4882a593Smuzhiyun					resets = <&gcc GCC_USB2B_PHY_BCR>, <&otg 1>;
807*4882a593Smuzhiyun					reset-names = "phy", "por";
808*4882a593Smuzhiyun					status = "disabled";
809*4882a593Smuzhiyun				};
810*4882a593Smuzhiyun			};
811*4882a593Smuzhiyun		};
812*4882a593Smuzhiyun
813*4882a593Smuzhiyun		rng@f9bff000 {
814*4882a593Smuzhiyun			compatible = "qcom,prng";
815*4882a593Smuzhiyun			reg = <0xf9bff000 0x200>;
816*4882a593Smuzhiyun			clocks = <&gcc GCC_PRNG_AHB_CLK>;
817*4882a593Smuzhiyun			clock-names = "core";
818*4882a593Smuzhiyun		};
819*4882a593Smuzhiyun
820*4882a593Smuzhiyun		remoteproc@fc880000 {
821*4882a593Smuzhiyun			compatible = "qcom,msm8974-mss-pil";
822*4882a593Smuzhiyun			reg = <0xfc880000 0x100>, <0xfc820000 0x020>;
823*4882a593Smuzhiyun			reg-names = "qdsp6", "rmb";
824*4882a593Smuzhiyun
825*4882a593Smuzhiyun			interrupts-extended = <&intc GIC_SPI 24 IRQ_TYPE_EDGE_RISING>,
826*4882a593Smuzhiyun					      <&modem_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
827*4882a593Smuzhiyun					      <&modem_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
828*4882a593Smuzhiyun					      <&modem_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
829*4882a593Smuzhiyun					      <&modem_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
830*4882a593Smuzhiyun			interrupt-names = "wdog", "fatal", "ready", "handover", "stop-ack";
831*4882a593Smuzhiyun
832*4882a593Smuzhiyun			clocks = <&gcc GCC_MSS_Q6_BIMC_AXI_CLK>,
833*4882a593Smuzhiyun				 <&gcc GCC_MSS_CFG_AHB_CLK>,
834*4882a593Smuzhiyun				 <&gcc GCC_BOOT_ROM_AHB_CLK>,
835*4882a593Smuzhiyun				 <&xo_board>;
836*4882a593Smuzhiyun			clock-names = "iface", "bus", "mem", "xo";
837*4882a593Smuzhiyun
838*4882a593Smuzhiyun			resets = <&gcc GCC_MSS_RESTART>;
839*4882a593Smuzhiyun			reset-names = "mss_restart";
840*4882a593Smuzhiyun
841*4882a593Smuzhiyun			cx-supply = <&pm8841_s2>;
842*4882a593Smuzhiyun			mss-supply = <&pm8841_s3>;
843*4882a593Smuzhiyun			mx-supply = <&pm8841_s1>;
844*4882a593Smuzhiyun			pll-supply = <&pm8941_l12>;
845*4882a593Smuzhiyun
846*4882a593Smuzhiyun			qcom,halt-regs = <&tcsr_mutex_block 0x1180 0x1200 0x1280>;
847*4882a593Smuzhiyun
848*4882a593Smuzhiyun			qcom,smem-states = <&modem_smp2p_out 0>;
849*4882a593Smuzhiyun			qcom,smem-state-names = "stop";
850*4882a593Smuzhiyun
851*4882a593Smuzhiyun			mba {
852*4882a593Smuzhiyun				memory-region = <&mba_region>;
853*4882a593Smuzhiyun			};
854*4882a593Smuzhiyun
855*4882a593Smuzhiyun			mpss {
856*4882a593Smuzhiyun				memory-region = <&mpss_region>;
857*4882a593Smuzhiyun			};
858*4882a593Smuzhiyun
859*4882a593Smuzhiyun			smd-edge {
860*4882a593Smuzhiyun				interrupts = <GIC_SPI 25 IRQ_TYPE_EDGE_RISING>;
861*4882a593Smuzhiyun
862*4882a593Smuzhiyun				qcom,ipc = <&apcs 8 12>;
863*4882a593Smuzhiyun				qcom,smd-edge = <0>;
864*4882a593Smuzhiyun
865*4882a593Smuzhiyun				label = "modem";
866*4882a593Smuzhiyun			};
867*4882a593Smuzhiyun		};
868*4882a593Smuzhiyun
869*4882a593Smuzhiyun		pronto: remoteproc@fb21b000 {
870*4882a593Smuzhiyun			compatible = "qcom,pronto-v2-pil", "qcom,pronto";
871*4882a593Smuzhiyun			reg = <0xfb204000 0x2000>, <0xfb202000 0x1000>, <0xfb21b000 0x3000>;
872*4882a593Smuzhiyun			reg-names = "ccu", "dxe", "pmu";
873*4882a593Smuzhiyun
874*4882a593Smuzhiyun			memory-region = <&wcnss_region>;
875*4882a593Smuzhiyun
876*4882a593Smuzhiyun			interrupts-extended = <&intc GIC_SPI 149 IRQ_TYPE_EDGE_RISING>,
877*4882a593Smuzhiyun					      <&wcnss_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
878*4882a593Smuzhiyun					      <&wcnss_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
879*4882a593Smuzhiyun					      <&wcnss_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
880*4882a593Smuzhiyun					      <&wcnss_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
881*4882a593Smuzhiyun			interrupt-names = "wdog", "fatal", "ready", "handover", "stop-ack";
882*4882a593Smuzhiyun
883*4882a593Smuzhiyun			vddpx-supply = <&pm8941_s3>;
884*4882a593Smuzhiyun
885*4882a593Smuzhiyun			qcom,smem-states = <&wcnss_smp2p_out 0>;
886*4882a593Smuzhiyun			qcom,smem-state-names = "stop";
887*4882a593Smuzhiyun
888*4882a593Smuzhiyun			status = "disabled";
889*4882a593Smuzhiyun
890*4882a593Smuzhiyun			iris {
891*4882a593Smuzhiyun				compatible = "qcom,wcn3680";
892*4882a593Smuzhiyun
893*4882a593Smuzhiyun				clocks = <&rpmcc RPM_SMD_CXO_A2>;
894*4882a593Smuzhiyun				clock-names = "xo";
895*4882a593Smuzhiyun
896*4882a593Smuzhiyun				vddxo-supply = <&pm8941_l6>;
897*4882a593Smuzhiyun				vddrfa-supply = <&pm8941_l11>;
898*4882a593Smuzhiyun				vddpa-supply = <&pm8941_l19>;
899*4882a593Smuzhiyun				vdddig-supply = <&pm8941_s3>;
900*4882a593Smuzhiyun			};
901*4882a593Smuzhiyun
902*4882a593Smuzhiyun			smd-edge {
903*4882a593Smuzhiyun				interrupts = <GIC_SPI 142 IRQ_TYPE_EDGE_RISING>;
904*4882a593Smuzhiyun
905*4882a593Smuzhiyun				qcom,ipc = <&apcs 8 17>;
906*4882a593Smuzhiyun				qcom,smd-edge = <6>;
907*4882a593Smuzhiyun
908*4882a593Smuzhiyun				wcnss {
909*4882a593Smuzhiyun					compatible = "qcom,wcnss";
910*4882a593Smuzhiyun					qcom,smd-channels = "WCNSS_CTRL";
911*4882a593Smuzhiyun					status = "disabled";
912*4882a593Smuzhiyun
913*4882a593Smuzhiyun					qcom,mmio = <&pronto>;
914*4882a593Smuzhiyun
915*4882a593Smuzhiyun					bt {
916*4882a593Smuzhiyun						compatible = "qcom,wcnss-bt";
917*4882a593Smuzhiyun					};
918*4882a593Smuzhiyun
919*4882a593Smuzhiyun					wifi {
920*4882a593Smuzhiyun						compatible = "qcom,wcnss-wlan";
921*4882a593Smuzhiyun
922*4882a593Smuzhiyun						interrupts = <GIC_SPI 145 IRQ_TYPE_EDGE_RISING>,
923*4882a593Smuzhiyun							     <GIC_SPI 146 IRQ_TYPE_EDGE_RISING>;
924*4882a593Smuzhiyun						interrupt-names = "tx", "rx";
925*4882a593Smuzhiyun
926*4882a593Smuzhiyun						qcom,smem-states = <&apps_smsm 10>, <&apps_smsm 9>;
927*4882a593Smuzhiyun						qcom,smem-state-names = "tx-enable", "tx-rings-empty";
928*4882a593Smuzhiyun					};
929*4882a593Smuzhiyun				};
930*4882a593Smuzhiyun			};
931*4882a593Smuzhiyun		};
932*4882a593Smuzhiyun
933*4882a593Smuzhiyun		msmgpio: pinctrl@fd510000 {
934*4882a593Smuzhiyun			compatible = "qcom,msm8974-pinctrl";
935*4882a593Smuzhiyun			reg = <0xfd510000 0x4000>;
936*4882a593Smuzhiyun			gpio-controller;
937*4882a593Smuzhiyun			gpio-ranges = <&msmgpio 0 0 146>;
938*4882a593Smuzhiyun			#gpio-cells = <2>;
939*4882a593Smuzhiyun			interrupt-controller;
940*4882a593Smuzhiyun			#interrupt-cells = <2>;
941*4882a593Smuzhiyun			interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>;
942*4882a593Smuzhiyun		};
943*4882a593Smuzhiyun
944*4882a593Smuzhiyun		i2c@f9923000 {
945*4882a593Smuzhiyun			status = "disabled";
946*4882a593Smuzhiyun			compatible = "qcom,i2c-qup-v2.1.1";
947*4882a593Smuzhiyun			reg = <0xf9923000 0x1000>;
948*4882a593Smuzhiyun			interrupts = <0 95 IRQ_TYPE_LEVEL_HIGH>;
949*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP1_QUP1_I2C_APPS_CLK>, <&gcc GCC_BLSP1_AHB_CLK>;
950*4882a593Smuzhiyun			clock-names = "core", "iface";
951*4882a593Smuzhiyun			#address-cells = <1>;
952*4882a593Smuzhiyun			#size-cells = <0>;
953*4882a593Smuzhiyun		};
954*4882a593Smuzhiyun
955*4882a593Smuzhiyun		i2c@f9924000 {
956*4882a593Smuzhiyun			status = "disabled";
957*4882a593Smuzhiyun			compatible = "qcom,i2c-qup-v2.1.1";
958*4882a593Smuzhiyun			reg = <0xf9924000 0x1000>;
959*4882a593Smuzhiyun			interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
960*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP1_QUP2_I2C_APPS_CLK>, <&gcc GCC_BLSP1_AHB_CLK>;
961*4882a593Smuzhiyun			clock-names = "core", "iface";
962*4882a593Smuzhiyun			#address-cells = <1>;
963*4882a593Smuzhiyun			#size-cells = <0>;
964*4882a593Smuzhiyun		};
965*4882a593Smuzhiyun
966*4882a593Smuzhiyun		blsp_i2c3: i2c@f9925000 {
967*4882a593Smuzhiyun			status = "disabled";
968*4882a593Smuzhiyun			compatible = "qcom,i2c-qup-v2.1.1";
969*4882a593Smuzhiyun			reg = <0xf9925000 0x1000>;
970*4882a593Smuzhiyun			interrupts = <0 97 IRQ_TYPE_LEVEL_HIGH>;
971*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP1_QUP3_I2C_APPS_CLK>, <&gcc GCC_BLSP1_AHB_CLK>;
972*4882a593Smuzhiyun			clock-names = "core", "iface";
973*4882a593Smuzhiyun			#address-cells = <1>;
974*4882a593Smuzhiyun			#size-cells = <0>;
975*4882a593Smuzhiyun		};
976*4882a593Smuzhiyun
977*4882a593Smuzhiyun		blsp_i2c6: i2c@f9928000 {
978*4882a593Smuzhiyun			status = "disabled";
979*4882a593Smuzhiyun			compatible = "qcom,i2c-qup-v2.1.1";
980*4882a593Smuzhiyun			reg = <0xf9928000 0x1000>;
981*4882a593Smuzhiyun			interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
982*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP1_QUP6_I2C_APPS_CLK>, <&gcc GCC_BLSP1_AHB_CLK>;
983*4882a593Smuzhiyun			clock-names = "core", "iface";
984*4882a593Smuzhiyun			#address-cells = <1>;
985*4882a593Smuzhiyun			#size-cells = <0>;
986*4882a593Smuzhiyun		};
987*4882a593Smuzhiyun
988*4882a593Smuzhiyun		blsp_i2c8: i2c@f9964000 {
989*4882a593Smuzhiyun			status = "disabled";
990*4882a593Smuzhiyun			compatible = "qcom,i2c-qup-v2.1.1";
991*4882a593Smuzhiyun			reg = <0xf9964000 0x1000>;
992*4882a593Smuzhiyun			interrupts = <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
993*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP2_QUP2_I2C_APPS_CLK>, <&gcc GCC_BLSP2_AHB_CLK>;
994*4882a593Smuzhiyun			clock-names = "core", "iface";
995*4882a593Smuzhiyun			#address-cells = <1>;
996*4882a593Smuzhiyun			#size-cells = <0>;
997*4882a593Smuzhiyun		};
998*4882a593Smuzhiyun
999*4882a593Smuzhiyun		blsp_i2c11: i2c@f9967000 {
1000*4882a593Smuzhiyun			status = "disabled";
1001*4882a593Smuzhiyun			compatible = "qcom,i2c-qup-v2.1.1";
1002*4882a593Smuzhiyun			reg = <0xf9967000 0x1000>;
1003*4882a593Smuzhiyun			interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
1004*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP2_QUP5_I2C_APPS_CLK>, <&gcc GCC_BLSP2_AHB_CLK>;
1005*4882a593Smuzhiyun			clock-names = "core", "iface";
1006*4882a593Smuzhiyun			#address-cells = <1>;
1007*4882a593Smuzhiyun			#size-cells = <0>;
1008*4882a593Smuzhiyun			dmas = <&blsp2_dma 20>, <&blsp2_dma 21>;
1009*4882a593Smuzhiyun			dma-names = "tx", "rx";
1010*4882a593Smuzhiyun		};
1011*4882a593Smuzhiyun
1012*4882a593Smuzhiyun		blsp_i2c12: i2c@f9968000 {
1013*4882a593Smuzhiyun			status = "disabled";
1014*4882a593Smuzhiyun			compatible = "qcom,i2c-qup-v2.1.1";
1015*4882a593Smuzhiyun			reg = <0xf9968000 0x1000>;
1016*4882a593Smuzhiyun			interrupts = <0 106 IRQ_TYPE_LEVEL_HIGH>;
1017*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP2_QUP6_I2C_APPS_CLK>, <&gcc GCC_BLSP2_AHB_CLK>;
1018*4882a593Smuzhiyun			clock-names = "core", "iface";
1019*4882a593Smuzhiyun			#address-cells = <1>;
1020*4882a593Smuzhiyun			#size-cells = <0>;
1021*4882a593Smuzhiyun		};
1022*4882a593Smuzhiyun
1023*4882a593Smuzhiyun		spmi_bus: spmi@fc4cf000 {
1024*4882a593Smuzhiyun			compatible = "qcom,spmi-pmic-arb";
1025*4882a593Smuzhiyun			reg-names = "core", "intr", "cnfg";
1026*4882a593Smuzhiyun			reg = <0xfc4cf000 0x1000>,
1027*4882a593Smuzhiyun			      <0xfc4cb000 0x1000>,
1028*4882a593Smuzhiyun			      <0xfc4ca000 0x1000>;
1029*4882a593Smuzhiyun			interrupt-names = "periph_irq";
1030*4882a593Smuzhiyun			interrupts = <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>;
1031*4882a593Smuzhiyun			qcom,ee = <0>;
1032*4882a593Smuzhiyun			qcom,channel = <0>;
1033*4882a593Smuzhiyun			#address-cells = <2>;
1034*4882a593Smuzhiyun			#size-cells = <0>;
1035*4882a593Smuzhiyun			interrupt-controller;
1036*4882a593Smuzhiyun			#interrupt-cells = <4>;
1037*4882a593Smuzhiyun		};
1038*4882a593Smuzhiyun
1039*4882a593Smuzhiyun		blsp2_dma: dma-controller@f9944000 {
1040*4882a593Smuzhiyun			compatible = "qcom,bam-v1.4.0";
1041*4882a593Smuzhiyun			reg = <0xf9944000 0x19000>;
1042*4882a593Smuzhiyun			interrupts = <GIC_SPI 239 IRQ_TYPE_LEVEL_HIGH>;
1043*4882a593Smuzhiyun			clocks = <&gcc GCC_BLSP2_AHB_CLK>;
1044*4882a593Smuzhiyun			clock-names = "bam_clk";
1045*4882a593Smuzhiyun			#dma-cells = <1>;
1046*4882a593Smuzhiyun			qcom,ee = <0>;
1047*4882a593Smuzhiyun		};
1048*4882a593Smuzhiyun
1049*4882a593Smuzhiyun		etr@fc322000 {
1050*4882a593Smuzhiyun			compatible = "arm,coresight-tmc", "arm,primecell";
1051*4882a593Smuzhiyun			reg = <0xfc322000 0x1000>;
1052*4882a593Smuzhiyun
1053*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1054*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1055*4882a593Smuzhiyun
1056*4882a593Smuzhiyun			in-ports {
1057*4882a593Smuzhiyun				port {
1058*4882a593Smuzhiyun					etr_in: endpoint {
1059*4882a593Smuzhiyun						remote-endpoint = <&replicator_out0>;
1060*4882a593Smuzhiyun					};
1061*4882a593Smuzhiyun				};
1062*4882a593Smuzhiyun			};
1063*4882a593Smuzhiyun		};
1064*4882a593Smuzhiyun
1065*4882a593Smuzhiyun		tpiu@fc318000 {
1066*4882a593Smuzhiyun			compatible = "arm,coresight-tpiu", "arm,primecell";
1067*4882a593Smuzhiyun			reg = <0xfc318000 0x1000>;
1068*4882a593Smuzhiyun
1069*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1070*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1071*4882a593Smuzhiyun
1072*4882a593Smuzhiyun			in-ports {
1073*4882a593Smuzhiyun				port {
1074*4882a593Smuzhiyun					tpiu_in: endpoint {
1075*4882a593Smuzhiyun						remote-endpoint = <&replicator_out1>;
1076*4882a593Smuzhiyun					};
1077*4882a593Smuzhiyun				 };
1078*4882a593Smuzhiyun			};
1079*4882a593Smuzhiyun		};
1080*4882a593Smuzhiyun
1081*4882a593Smuzhiyun		replicator@fc31c000 {
1082*4882a593Smuzhiyun			compatible = "arm,coresight-dynamic-replicator", "arm,primecell";
1083*4882a593Smuzhiyun			reg = <0xfc31c000 0x1000>;
1084*4882a593Smuzhiyun
1085*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1086*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1087*4882a593Smuzhiyun
1088*4882a593Smuzhiyun			out-ports {
1089*4882a593Smuzhiyun				#address-cells = <1>;
1090*4882a593Smuzhiyun				#size-cells = <0>;
1091*4882a593Smuzhiyun
1092*4882a593Smuzhiyun				port@0 {
1093*4882a593Smuzhiyun					reg = <0>;
1094*4882a593Smuzhiyun					replicator_out0: endpoint {
1095*4882a593Smuzhiyun						remote-endpoint = <&etr_in>;
1096*4882a593Smuzhiyun					};
1097*4882a593Smuzhiyun				};
1098*4882a593Smuzhiyun				port@1 {
1099*4882a593Smuzhiyun					reg = <1>;
1100*4882a593Smuzhiyun					replicator_out1: endpoint {
1101*4882a593Smuzhiyun						remote-endpoint = <&tpiu_in>;
1102*4882a593Smuzhiyun					};
1103*4882a593Smuzhiyun				};
1104*4882a593Smuzhiyun			};
1105*4882a593Smuzhiyun
1106*4882a593Smuzhiyun			in-ports {
1107*4882a593Smuzhiyun				port {
1108*4882a593Smuzhiyun					replicator_in: endpoint {
1109*4882a593Smuzhiyun						remote-endpoint = <&etf_out>;
1110*4882a593Smuzhiyun					};
1111*4882a593Smuzhiyun				};
1112*4882a593Smuzhiyun			};
1113*4882a593Smuzhiyun		};
1114*4882a593Smuzhiyun
1115*4882a593Smuzhiyun		etf@fc307000 {
1116*4882a593Smuzhiyun			compatible = "arm,coresight-tmc", "arm,primecell";
1117*4882a593Smuzhiyun			reg = <0xfc307000 0x1000>;
1118*4882a593Smuzhiyun
1119*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1120*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1121*4882a593Smuzhiyun
1122*4882a593Smuzhiyun			out-ports {
1123*4882a593Smuzhiyun				port {
1124*4882a593Smuzhiyun					etf_out: endpoint {
1125*4882a593Smuzhiyun						remote-endpoint = <&replicator_in>;
1126*4882a593Smuzhiyun					};
1127*4882a593Smuzhiyun				};
1128*4882a593Smuzhiyun			};
1129*4882a593Smuzhiyun
1130*4882a593Smuzhiyun			in-ports {
1131*4882a593Smuzhiyun				port {
1132*4882a593Smuzhiyun					etf_in: endpoint {
1133*4882a593Smuzhiyun						remote-endpoint = <&merger_out>;
1134*4882a593Smuzhiyun					};
1135*4882a593Smuzhiyun				};
1136*4882a593Smuzhiyun			};
1137*4882a593Smuzhiyun		};
1138*4882a593Smuzhiyun
1139*4882a593Smuzhiyun		funnel@fc31b000 {
1140*4882a593Smuzhiyun			compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1141*4882a593Smuzhiyun			reg = <0xfc31b000 0x1000>;
1142*4882a593Smuzhiyun
1143*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1144*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1145*4882a593Smuzhiyun
1146*4882a593Smuzhiyun			in-ports {
1147*4882a593Smuzhiyun				#address-cells = <1>;
1148*4882a593Smuzhiyun				#size-cells = <0>;
1149*4882a593Smuzhiyun
1150*4882a593Smuzhiyun				/*
1151*4882a593Smuzhiyun				 * Not described input ports:
1152*4882a593Smuzhiyun				 * 0 - connected trought funnel to Audio, Modem and
1153*4882a593Smuzhiyun				 *     Resource and Power Manager CPU's
1154*4882a593Smuzhiyun				 * 2...7 - not-connected
1155*4882a593Smuzhiyun				 */
1156*4882a593Smuzhiyun				port@1 {
1157*4882a593Smuzhiyun					reg = <1>;
1158*4882a593Smuzhiyun					merger_in1: endpoint {
1159*4882a593Smuzhiyun						remote-endpoint = <&funnel1_out>;
1160*4882a593Smuzhiyun					};
1161*4882a593Smuzhiyun				};
1162*4882a593Smuzhiyun			};
1163*4882a593Smuzhiyun
1164*4882a593Smuzhiyun			out-ports {
1165*4882a593Smuzhiyun				port {
1166*4882a593Smuzhiyun					merger_out: endpoint {
1167*4882a593Smuzhiyun						remote-endpoint = <&etf_in>;
1168*4882a593Smuzhiyun					};
1169*4882a593Smuzhiyun				};
1170*4882a593Smuzhiyun			};
1171*4882a593Smuzhiyun		};
1172*4882a593Smuzhiyun
1173*4882a593Smuzhiyun		funnel@fc31a000 {
1174*4882a593Smuzhiyun			compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1175*4882a593Smuzhiyun			reg = <0xfc31a000 0x1000>;
1176*4882a593Smuzhiyun
1177*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1178*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1179*4882a593Smuzhiyun
1180*4882a593Smuzhiyun			in-ports {
1181*4882a593Smuzhiyun				#address-cells = <1>;
1182*4882a593Smuzhiyun				#size-cells = <0>;
1183*4882a593Smuzhiyun
1184*4882a593Smuzhiyun				/*
1185*4882a593Smuzhiyun				 * Not described input ports:
1186*4882a593Smuzhiyun				 * 0 - not-connected
1187*4882a593Smuzhiyun				 * 1 - connected trought funnel to Multimedia CPU
1188*4882a593Smuzhiyun				 * 2 - connected to Wireless CPU
1189*4882a593Smuzhiyun				 * 3 - not-connected
1190*4882a593Smuzhiyun				 * 4 - not-connected
1191*4882a593Smuzhiyun				 * 6 - not-connected
1192*4882a593Smuzhiyun				 * 7 - connected to STM
1193*4882a593Smuzhiyun				 */
1194*4882a593Smuzhiyun				port@5 {
1195*4882a593Smuzhiyun					reg = <5>;
1196*4882a593Smuzhiyun					funnel1_in5: endpoint {
1197*4882a593Smuzhiyun						remote-endpoint = <&kpss_out>;
1198*4882a593Smuzhiyun					};
1199*4882a593Smuzhiyun				};
1200*4882a593Smuzhiyun			};
1201*4882a593Smuzhiyun
1202*4882a593Smuzhiyun			out-ports {
1203*4882a593Smuzhiyun				port {
1204*4882a593Smuzhiyun					funnel1_out: endpoint {
1205*4882a593Smuzhiyun						remote-endpoint = <&merger_in1>;
1206*4882a593Smuzhiyun					};
1207*4882a593Smuzhiyun				};
1208*4882a593Smuzhiyun			};
1209*4882a593Smuzhiyun		};
1210*4882a593Smuzhiyun
1211*4882a593Smuzhiyun		funnel@fc345000 { /* KPSS funnel only 4 inputs are used */
1212*4882a593Smuzhiyun			compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1213*4882a593Smuzhiyun			reg = <0xfc345000 0x1000>;
1214*4882a593Smuzhiyun
1215*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1216*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1217*4882a593Smuzhiyun
1218*4882a593Smuzhiyun			in-ports {
1219*4882a593Smuzhiyun				#address-cells = <1>;
1220*4882a593Smuzhiyun				#size-cells = <0>;
1221*4882a593Smuzhiyun
1222*4882a593Smuzhiyun				port@0 {
1223*4882a593Smuzhiyun					reg = <0>;
1224*4882a593Smuzhiyun					kpss_in0: endpoint {
1225*4882a593Smuzhiyun						remote-endpoint = <&etm0_out>;
1226*4882a593Smuzhiyun					};
1227*4882a593Smuzhiyun				};
1228*4882a593Smuzhiyun				port@1 {
1229*4882a593Smuzhiyun					reg = <1>;
1230*4882a593Smuzhiyun					kpss_in1: endpoint {
1231*4882a593Smuzhiyun						remote-endpoint = <&etm1_out>;
1232*4882a593Smuzhiyun					};
1233*4882a593Smuzhiyun				};
1234*4882a593Smuzhiyun				port@2 {
1235*4882a593Smuzhiyun					reg = <2>;
1236*4882a593Smuzhiyun					kpss_in2: endpoint {
1237*4882a593Smuzhiyun						remote-endpoint = <&etm2_out>;
1238*4882a593Smuzhiyun					};
1239*4882a593Smuzhiyun				};
1240*4882a593Smuzhiyun				port@3 {
1241*4882a593Smuzhiyun					reg = <3>;
1242*4882a593Smuzhiyun					kpss_in3: endpoint {
1243*4882a593Smuzhiyun						remote-endpoint = <&etm3_out>;
1244*4882a593Smuzhiyun					};
1245*4882a593Smuzhiyun				};
1246*4882a593Smuzhiyun			};
1247*4882a593Smuzhiyun
1248*4882a593Smuzhiyun			out-ports {
1249*4882a593Smuzhiyun				port {
1250*4882a593Smuzhiyun					kpss_out: endpoint {
1251*4882a593Smuzhiyun						remote-endpoint = <&funnel1_in5>;
1252*4882a593Smuzhiyun					};
1253*4882a593Smuzhiyun				};
1254*4882a593Smuzhiyun			};
1255*4882a593Smuzhiyun		};
1256*4882a593Smuzhiyun
1257*4882a593Smuzhiyun		etm@fc33c000 {
1258*4882a593Smuzhiyun			compatible = "arm,coresight-etm4x", "arm,primecell";
1259*4882a593Smuzhiyun			reg = <0xfc33c000 0x1000>;
1260*4882a593Smuzhiyun
1261*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1262*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1263*4882a593Smuzhiyun
1264*4882a593Smuzhiyun			cpu = <&CPU0>;
1265*4882a593Smuzhiyun
1266*4882a593Smuzhiyun			out-ports {
1267*4882a593Smuzhiyun				port {
1268*4882a593Smuzhiyun					etm0_out: endpoint {
1269*4882a593Smuzhiyun						remote-endpoint = <&kpss_in0>;
1270*4882a593Smuzhiyun					};
1271*4882a593Smuzhiyun				};
1272*4882a593Smuzhiyun			};
1273*4882a593Smuzhiyun		};
1274*4882a593Smuzhiyun
1275*4882a593Smuzhiyun		etm@fc33d000 {
1276*4882a593Smuzhiyun			compatible = "arm,coresight-etm4x", "arm,primecell";
1277*4882a593Smuzhiyun			reg = <0xfc33d000 0x1000>;
1278*4882a593Smuzhiyun
1279*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1280*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1281*4882a593Smuzhiyun
1282*4882a593Smuzhiyun			cpu = <&CPU1>;
1283*4882a593Smuzhiyun
1284*4882a593Smuzhiyun			out-ports {
1285*4882a593Smuzhiyun				port {
1286*4882a593Smuzhiyun					etm1_out: endpoint {
1287*4882a593Smuzhiyun						remote-endpoint = <&kpss_in1>;
1288*4882a593Smuzhiyun					};
1289*4882a593Smuzhiyun				};
1290*4882a593Smuzhiyun			};
1291*4882a593Smuzhiyun		};
1292*4882a593Smuzhiyun
1293*4882a593Smuzhiyun		etm@fc33e000 {
1294*4882a593Smuzhiyun			compatible = "arm,coresight-etm4x", "arm,primecell";
1295*4882a593Smuzhiyun			reg = <0xfc33e000 0x1000>;
1296*4882a593Smuzhiyun
1297*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1298*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1299*4882a593Smuzhiyun
1300*4882a593Smuzhiyun			cpu = <&CPU2>;
1301*4882a593Smuzhiyun
1302*4882a593Smuzhiyun			out-ports {
1303*4882a593Smuzhiyun				port {
1304*4882a593Smuzhiyun					etm2_out: endpoint {
1305*4882a593Smuzhiyun						remote-endpoint = <&kpss_in2>;
1306*4882a593Smuzhiyun					};
1307*4882a593Smuzhiyun				};
1308*4882a593Smuzhiyun			};
1309*4882a593Smuzhiyun		};
1310*4882a593Smuzhiyun
1311*4882a593Smuzhiyun		etm@fc33f000 {
1312*4882a593Smuzhiyun			compatible = "arm,coresight-etm4x", "arm,primecell";
1313*4882a593Smuzhiyun			reg = <0xfc33f000 0x1000>;
1314*4882a593Smuzhiyun
1315*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1316*4882a593Smuzhiyun			clock-names = "apb_pclk", "atclk";
1317*4882a593Smuzhiyun
1318*4882a593Smuzhiyun			cpu = <&CPU3>;
1319*4882a593Smuzhiyun
1320*4882a593Smuzhiyun			out-ports {
1321*4882a593Smuzhiyun				port {
1322*4882a593Smuzhiyun					etm3_out: endpoint {
1323*4882a593Smuzhiyun						remote-endpoint = <&kpss_in3>;
1324*4882a593Smuzhiyun					};
1325*4882a593Smuzhiyun				};
1326*4882a593Smuzhiyun			};
1327*4882a593Smuzhiyun		};
1328*4882a593Smuzhiyun
1329*4882a593Smuzhiyun		ocmem@fdd00000 {
1330*4882a593Smuzhiyun			compatible = "qcom,msm8974-ocmem";
1331*4882a593Smuzhiyun			reg = <0xfdd00000 0x2000>,
1332*4882a593Smuzhiyun			      <0xfec00000 0x180000>;
1333*4882a593Smuzhiyun			reg-names = "ctrl",
1334*4882a593Smuzhiyun			            "mem";
1335*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_OCMEMGX_CLK>,
1336*4882a593Smuzhiyun			         <&mmcc OCMEMCX_OCMEMNOC_CLK>;
1337*4882a593Smuzhiyun			clock-names = "core",
1338*4882a593Smuzhiyun			              "iface";
1339*4882a593Smuzhiyun
1340*4882a593Smuzhiyun			#address-cells = <1>;
1341*4882a593Smuzhiyun			#size-cells = <1>;
1342*4882a593Smuzhiyun
1343*4882a593Smuzhiyun			gmu_sram: gmu-sram@0 {
1344*4882a593Smuzhiyun				reg = <0x0 0x100000>;
1345*4882a593Smuzhiyun			};
1346*4882a593Smuzhiyun		};
1347*4882a593Smuzhiyun
1348*4882a593Smuzhiyun		bimc: interconnect@fc380000 {
1349*4882a593Smuzhiyun			reg = <0xfc380000 0x6a000>;
1350*4882a593Smuzhiyun			compatible = "qcom,msm8974-bimc";
1351*4882a593Smuzhiyun			#interconnect-cells = <1>;
1352*4882a593Smuzhiyun			clock-names = "bus", "bus_a";
1353*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_BIMC_CLK>,
1354*4882a593Smuzhiyun			         <&rpmcc RPM_SMD_BIMC_A_CLK>;
1355*4882a593Smuzhiyun		};
1356*4882a593Smuzhiyun
1357*4882a593Smuzhiyun		snoc: interconnect@fc460000 {
1358*4882a593Smuzhiyun			reg = <0xfc460000 0x4000>;
1359*4882a593Smuzhiyun			compatible = "qcom,msm8974-snoc";
1360*4882a593Smuzhiyun			#interconnect-cells = <1>;
1361*4882a593Smuzhiyun			clock-names = "bus", "bus_a";
1362*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_SNOC_CLK>,
1363*4882a593Smuzhiyun			         <&rpmcc RPM_SMD_SNOC_A_CLK>;
1364*4882a593Smuzhiyun		};
1365*4882a593Smuzhiyun
1366*4882a593Smuzhiyun		pnoc: interconnect@fc468000 {
1367*4882a593Smuzhiyun			reg = <0xfc468000 0x4000>;
1368*4882a593Smuzhiyun			compatible = "qcom,msm8974-pnoc";
1369*4882a593Smuzhiyun			#interconnect-cells = <1>;
1370*4882a593Smuzhiyun			clock-names = "bus", "bus_a";
1371*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_PNOC_CLK>,
1372*4882a593Smuzhiyun			         <&rpmcc RPM_SMD_PNOC_A_CLK>;
1373*4882a593Smuzhiyun		};
1374*4882a593Smuzhiyun
1375*4882a593Smuzhiyun		ocmemnoc: interconnect@fc470000 {
1376*4882a593Smuzhiyun			reg = <0xfc470000 0x4000>;
1377*4882a593Smuzhiyun			compatible = "qcom,msm8974-ocmemnoc";
1378*4882a593Smuzhiyun			#interconnect-cells = <1>;
1379*4882a593Smuzhiyun			clock-names = "bus", "bus_a";
1380*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_OCMEMGX_CLK>,
1381*4882a593Smuzhiyun			         <&rpmcc RPM_SMD_OCMEMGX_A_CLK>;
1382*4882a593Smuzhiyun		};
1383*4882a593Smuzhiyun
1384*4882a593Smuzhiyun		mmssnoc: interconnect@fc478000 {
1385*4882a593Smuzhiyun			reg = <0xfc478000 0x4000>;
1386*4882a593Smuzhiyun			compatible = "qcom,msm8974-mmssnoc";
1387*4882a593Smuzhiyun			#interconnect-cells = <1>;
1388*4882a593Smuzhiyun			clock-names = "bus", "bus_a";
1389*4882a593Smuzhiyun			clocks = <&mmcc MMSS_S0_AXI_CLK>,
1390*4882a593Smuzhiyun			         <&mmcc MMSS_S0_AXI_CLK>;
1391*4882a593Smuzhiyun		};
1392*4882a593Smuzhiyun
1393*4882a593Smuzhiyun		cnoc: interconnect@fc480000 {
1394*4882a593Smuzhiyun			reg = <0xfc480000 0x4000>;
1395*4882a593Smuzhiyun			compatible = "qcom,msm8974-cnoc";
1396*4882a593Smuzhiyun			#interconnect-cells = <1>;
1397*4882a593Smuzhiyun			clock-names = "bus", "bus_a";
1398*4882a593Smuzhiyun			clocks = <&rpmcc RPM_SMD_CNOC_CLK>,
1399*4882a593Smuzhiyun			         <&rpmcc RPM_SMD_CNOC_A_CLK>;
1400*4882a593Smuzhiyun		};
1401*4882a593Smuzhiyun
1402*4882a593Smuzhiyun		mdss: mdss@fd900000 {
1403*4882a593Smuzhiyun			status = "disabled";
1404*4882a593Smuzhiyun
1405*4882a593Smuzhiyun			compatible = "qcom,mdss";
1406*4882a593Smuzhiyun			reg = <0xfd900000 0x100>,
1407*4882a593Smuzhiyun			      <0xfd924000 0x1000>;
1408*4882a593Smuzhiyun			reg-names = "mdss_phys",
1409*4882a593Smuzhiyun			            "vbif_phys";
1410*4882a593Smuzhiyun
1411*4882a593Smuzhiyun			power-domains = <&mmcc MDSS_GDSC>;
1412*4882a593Smuzhiyun
1413*4882a593Smuzhiyun			clocks = <&mmcc MDSS_AHB_CLK>,
1414*4882a593Smuzhiyun			         <&mmcc MDSS_AXI_CLK>,
1415*4882a593Smuzhiyun			         <&mmcc MDSS_VSYNC_CLK>;
1416*4882a593Smuzhiyun			clock-names = "iface",
1417*4882a593Smuzhiyun			              "bus",
1418*4882a593Smuzhiyun			              "vsync";
1419*4882a593Smuzhiyun
1420*4882a593Smuzhiyun			interrupts = <GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH>;
1421*4882a593Smuzhiyun
1422*4882a593Smuzhiyun			interrupt-controller;
1423*4882a593Smuzhiyun			#interrupt-cells = <1>;
1424*4882a593Smuzhiyun
1425*4882a593Smuzhiyun			#address-cells = <1>;
1426*4882a593Smuzhiyun			#size-cells = <1>;
1427*4882a593Smuzhiyun			ranges;
1428*4882a593Smuzhiyun
1429*4882a593Smuzhiyun			mdp: mdp@fd900000 {
1430*4882a593Smuzhiyun				status = "disabled";
1431*4882a593Smuzhiyun
1432*4882a593Smuzhiyun				compatible = "qcom,mdp5";
1433*4882a593Smuzhiyun				reg = <0xfd900100 0x22000>;
1434*4882a593Smuzhiyun				reg-names = "mdp_phys";
1435*4882a593Smuzhiyun
1436*4882a593Smuzhiyun				interrupt-parent = <&mdss>;
1437*4882a593Smuzhiyun				interrupts = <0 0>;
1438*4882a593Smuzhiyun
1439*4882a593Smuzhiyun				clocks = <&mmcc MDSS_AHB_CLK>,
1440*4882a593Smuzhiyun					 <&mmcc MDSS_AXI_CLK>,
1441*4882a593Smuzhiyun					 <&mmcc MDSS_MDP_CLK>,
1442*4882a593Smuzhiyun					 <&mmcc MDSS_VSYNC_CLK>;
1443*4882a593Smuzhiyun				clock-names = "iface",
1444*4882a593Smuzhiyun				              "bus",
1445*4882a593Smuzhiyun				              "core",
1446*4882a593Smuzhiyun				              "vsync";
1447*4882a593Smuzhiyun
1448*4882a593Smuzhiyun				interconnects = <&mmssnoc MNOC_MAS_MDP_PORT0 &bimc BIMC_SLV_EBI_CH0>;
1449*4882a593Smuzhiyun				interconnect-names = "mdp0-mem";
1450*4882a593Smuzhiyun
1451*4882a593Smuzhiyun				ports {
1452*4882a593Smuzhiyun					#address-cells = <1>;
1453*4882a593Smuzhiyun					#size-cells = <0>;
1454*4882a593Smuzhiyun
1455*4882a593Smuzhiyun					port@0 {
1456*4882a593Smuzhiyun						reg = <0>;
1457*4882a593Smuzhiyun						mdp5_intf1_out: endpoint {
1458*4882a593Smuzhiyun							remote-endpoint = <&dsi0_in>;
1459*4882a593Smuzhiyun						};
1460*4882a593Smuzhiyun					};
1461*4882a593Smuzhiyun				};
1462*4882a593Smuzhiyun			};
1463*4882a593Smuzhiyun
1464*4882a593Smuzhiyun			dsi0: dsi@fd922800 {
1465*4882a593Smuzhiyun				status = "disabled";
1466*4882a593Smuzhiyun
1467*4882a593Smuzhiyun				compatible = "qcom,mdss-dsi-ctrl";
1468*4882a593Smuzhiyun				reg = <0xfd922800 0x1f8>;
1469*4882a593Smuzhiyun				reg-names = "dsi_ctrl";
1470*4882a593Smuzhiyun
1471*4882a593Smuzhiyun				interrupt-parent = <&mdss>;
1472*4882a593Smuzhiyun				interrupts = <4 IRQ_TYPE_LEVEL_HIGH>;
1473*4882a593Smuzhiyun
1474*4882a593Smuzhiyun				assigned-clocks = <&mmcc BYTE0_CLK_SRC>,
1475*4882a593Smuzhiyun				                  <&mmcc PCLK0_CLK_SRC>;
1476*4882a593Smuzhiyun				assigned-clock-parents = <&dsi_phy0 0>,
1477*4882a593Smuzhiyun				                         <&dsi_phy0 1>;
1478*4882a593Smuzhiyun
1479*4882a593Smuzhiyun				clocks = <&mmcc MDSS_MDP_CLK>,
1480*4882a593Smuzhiyun				         <&mmcc MDSS_AHB_CLK>,
1481*4882a593Smuzhiyun				         <&mmcc MDSS_AXI_CLK>,
1482*4882a593Smuzhiyun				         <&mmcc MDSS_BYTE0_CLK>,
1483*4882a593Smuzhiyun				         <&mmcc MDSS_PCLK0_CLK>,
1484*4882a593Smuzhiyun				         <&mmcc MDSS_ESC0_CLK>,
1485*4882a593Smuzhiyun				         <&mmcc MMSS_MISC_AHB_CLK>;
1486*4882a593Smuzhiyun				clock-names = "mdp_core",
1487*4882a593Smuzhiyun				              "iface",
1488*4882a593Smuzhiyun				              "bus",
1489*4882a593Smuzhiyun				              "byte",
1490*4882a593Smuzhiyun				              "pixel",
1491*4882a593Smuzhiyun				              "core",
1492*4882a593Smuzhiyun				              "core_mmss";
1493*4882a593Smuzhiyun
1494*4882a593Smuzhiyun				phys = <&dsi_phy0>;
1495*4882a593Smuzhiyun				phy-names = "dsi-phy";
1496*4882a593Smuzhiyun
1497*4882a593Smuzhiyun				ports {
1498*4882a593Smuzhiyun					#address-cells = <1>;
1499*4882a593Smuzhiyun					#size-cells = <0>;
1500*4882a593Smuzhiyun
1501*4882a593Smuzhiyun					port@0 {
1502*4882a593Smuzhiyun						reg = <0>;
1503*4882a593Smuzhiyun						dsi0_in: endpoint {
1504*4882a593Smuzhiyun							remote-endpoint = <&mdp5_intf1_out>;
1505*4882a593Smuzhiyun						};
1506*4882a593Smuzhiyun					};
1507*4882a593Smuzhiyun
1508*4882a593Smuzhiyun					port@1 {
1509*4882a593Smuzhiyun						reg = <1>;
1510*4882a593Smuzhiyun						dsi0_out: endpoint {
1511*4882a593Smuzhiyun						};
1512*4882a593Smuzhiyun					};
1513*4882a593Smuzhiyun				};
1514*4882a593Smuzhiyun			};
1515*4882a593Smuzhiyun
1516*4882a593Smuzhiyun			dsi_phy0: dsi-phy@fd922a00 {
1517*4882a593Smuzhiyun				status = "disabled";
1518*4882a593Smuzhiyun
1519*4882a593Smuzhiyun				compatible = "qcom,dsi-phy-28nm-hpm";
1520*4882a593Smuzhiyun				reg = <0xfd922a00 0xd4>,
1521*4882a593Smuzhiyun				      <0xfd922b00 0x280>,
1522*4882a593Smuzhiyun				      <0xfd922d80 0x30>;
1523*4882a593Smuzhiyun				reg-names = "dsi_pll",
1524*4882a593Smuzhiyun				            "dsi_phy",
1525*4882a593Smuzhiyun				            "dsi_phy_regulator";
1526*4882a593Smuzhiyun
1527*4882a593Smuzhiyun				#clock-cells = <1>;
1528*4882a593Smuzhiyun				#phy-cells = <0>;
1529*4882a593Smuzhiyun				qcom,dsi-phy-index = <0>;
1530*4882a593Smuzhiyun
1531*4882a593Smuzhiyun				clocks = <&mmcc MDSS_AHB_CLK>, <&xo_board>;
1532*4882a593Smuzhiyun				clock-names = "iface", "ref";
1533*4882a593Smuzhiyun			};
1534*4882a593Smuzhiyun		};
1535*4882a593Smuzhiyun
1536*4882a593Smuzhiyun		imem@fe805000 {
1537*4882a593Smuzhiyun			status = "disabled";
1538*4882a593Smuzhiyun			compatible = "syscon", "simple-mfd";
1539*4882a593Smuzhiyun			reg = <0xfe805000 0x1000>;
1540*4882a593Smuzhiyun
1541*4882a593Smuzhiyun			reboot-mode {
1542*4882a593Smuzhiyun				compatible = "syscon-reboot-mode";
1543*4882a593Smuzhiyun				offset = <0x65c>;
1544*4882a593Smuzhiyun			};
1545*4882a593Smuzhiyun		};
1546*4882a593Smuzhiyun	};
1547*4882a593Smuzhiyun
1548*4882a593Smuzhiyun	smd {
1549*4882a593Smuzhiyun		compatible = "qcom,smd";
1550*4882a593Smuzhiyun
1551*4882a593Smuzhiyun		rpm {
1552*4882a593Smuzhiyun			interrupts = <GIC_SPI 168 IRQ_TYPE_EDGE_RISING>;
1553*4882a593Smuzhiyun			qcom,ipc = <&apcs 8 0>;
1554*4882a593Smuzhiyun			qcom,smd-edge = <15>;
1555*4882a593Smuzhiyun
1556*4882a593Smuzhiyun			rpm_requests {
1557*4882a593Smuzhiyun				compatible = "qcom,rpm-msm8974";
1558*4882a593Smuzhiyun				qcom,smd-channels = "rpm_requests";
1559*4882a593Smuzhiyun
1560*4882a593Smuzhiyun				rpmcc: clock-controller {
1561*4882a593Smuzhiyun					compatible = "qcom,rpmcc-msm8974", "qcom,rpmcc";
1562*4882a593Smuzhiyun					#clock-cells = <1>;
1563*4882a593Smuzhiyun				};
1564*4882a593Smuzhiyun
1565*4882a593Smuzhiyun				pm8841-regulators {
1566*4882a593Smuzhiyun					compatible = "qcom,rpm-pm8841-regulators";
1567*4882a593Smuzhiyun
1568*4882a593Smuzhiyun					pm8841_s1: s1 {};
1569*4882a593Smuzhiyun					pm8841_s2: s2 {};
1570*4882a593Smuzhiyun					pm8841_s3: s3 {};
1571*4882a593Smuzhiyun					pm8841_s4: s4 {};
1572*4882a593Smuzhiyun					pm8841_s5: s5 {};
1573*4882a593Smuzhiyun					pm8841_s6: s6 {};
1574*4882a593Smuzhiyun					pm8841_s7: s7 {};
1575*4882a593Smuzhiyun					pm8841_s8: s8 {};
1576*4882a593Smuzhiyun				};
1577*4882a593Smuzhiyun
1578*4882a593Smuzhiyun				pm8941-regulators {
1579*4882a593Smuzhiyun					compatible = "qcom,rpm-pm8941-regulators";
1580*4882a593Smuzhiyun
1581*4882a593Smuzhiyun					pm8941_s1: s1 {};
1582*4882a593Smuzhiyun					pm8941_s2: s2 {};
1583*4882a593Smuzhiyun					pm8941_s3: s3 {};
1584*4882a593Smuzhiyun
1585*4882a593Smuzhiyun					pm8941_l1: l1 {};
1586*4882a593Smuzhiyun					pm8941_l2: l2 {};
1587*4882a593Smuzhiyun					pm8941_l3: l3 {};
1588*4882a593Smuzhiyun					pm8941_l4: l4 {};
1589*4882a593Smuzhiyun					pm8941_l5: l5 {};
1590*4882a593Smuzhiyun					pm8941_l6: l6 {};
1591*4882a593Smuzhiyun					pm8941_l7: l7 {};
1592*4882a593Smuzhiyun					pm8941_l8: l8 {};
1593*4882a593Smuzhiyun					pm8941_l9: l9 {};
1594*4882a593Smuzhiyun					pm8941_l10: l10 {};
1595*4882a593Smuzhiyun					pm8941_l11: l11 {};
1596*4882a593Smuzhiyun					pm8941_l12: l12 {};
1597*4882a593Smuzhiyun					pm8941_l13: l13 {};
1598*4882a593Smuzhiyun					pm8941_l14: l14 {};
1599*4882a593Smuzhiyun					pm8941_l15: l15 {};
1600*4882a593Smuzhiyun					pm8941_l16: l16 {};
1601*4882a593Smuzhiyun					pm8941_l17: l17 {};
1602*4882a593Smuzhiyun					pm8941_l18: l18 {};
1603*4882a593Smuzhiyun					pm8941_l19: l19 {};
1604*4882a593Smuzhiyun					pm8941_l20: l20 {};
1605*4882a593Smuzhiyun					pm8941_l21: l21 {};
1606*4882a593Smuzhiyun					pm8941_l22: l22 {};
1607*4882a593Smuzhiyun					pm8941_l23: l23 {};
1608*4882a593Smuzhiyun					pm8941_l24: l24 {};
1609*4882a593Smuzhiyun
1610*4882a593Smuzhiyun					pm8941_lvs1: lvs1 {};
1611*4882a593Smuzhiyun					pm8941_lvs2: lvs2 {};
1612*4882a593Smuzhiyun					pm8941_lvs3: lvs3 {};
1613*4882a593Smuzhiyun				};
1614*4882a593Smuzhiyun			};
1615*4882a593Smuzhiyun		};
1616*4882a593Smuzhiyun	};
1617*4882a593Smuzhiyun
1618*4882a593Smuzhiyun	vreg_boost: vreg-boost {
1619*4882a593Smuzhiyun		compatible = "regulator-fixed";
1620*4882a593Smuzhiyun
1621*4882a593Smuzhiyun		regulator-name = "vreg-boost";
1622*4882a593Smuzhiyun		regulator-min-microvolt = <3150000>;
1623*4882a593Smuzhiyun		regulator-max-microvolt = <3150000>;
1624*4882a593Smuzhiyun
1625*4882a593Smuzhiyun		regulator-always-on;
1626*4882a593Smuzhiyun		regulator-boot-on;
1627*4882a593Smuzhiyun
1628*4882a593Smuzhiyun		gpio = <&pm8941_gpios 21 GPIO_ACTIVE_HIGH>;
1629*4882a593Smuzhiyun		enable-active-high;
1630*4882a593Smuzhiyun
1631*4882a593Smuzhiyun		pinctrl-names = "default";
1632*4882a593Smuzhiyun		pinctrl-0 = <&boost_bypass_n_pin>;
1633*4882a593Smuzhiyun	};
1634*4882a593Smuzhiyun	vreg_vph_pwr: vreg-vph-pwr {
1635*4882a593Smuzhiyun		compatible = "regulator-fixed";
1636*4882a593Smuzhiyun		regulator-name = "vph-pwr";
1637*4882a593Smuzhiyun
1638*4882a593Smuzhiyun		regulator-min-microvolt = <3600000>;
1639*4882a593Smuzhiyun		regulator-max-microvolt = <3600000>;
1640*4882a593Smuzhiyun
1641*4882a593Smuzhiyun		regulator-always-on;
1642*4882a593Smuzhiyun	};
1643*4882a593Smuzhiyun};
1644