xref: /linux/arch/arm64/boot/dts/qcom/sm6115.dtsi (revision 115e74a29b530d121891238e9551c4bcdf7b04b5)
1// SPDX-License-Identifier: (GPL-2.0+ OR BSD-3-Clause)
2/*
3 * Copyright (c) 2021, Iskren Chernev <iskren.chernev@gmail.com>
4 */
5
6#include <dt-bindings/clock/qcom,dsi-phy-28nm.h>
7#include <dt-bindings/clock/qcom,gcc-sm6115.h>
8#include <dt-bindings/clock/qcom,sm6115-dispcc.h>
9#include <dt-bindings/clock/qcom,sm6115-gpucc.h>
10#include <dt-bindings/clock/qcom,rpmcc.h>
11#include <dt-bindings/dma/qcom-gpi.h>
12#include <dt-bindings/firmware/qcom,scm.h>
13#include <dt-bindings/gpio/gpio.h>
14#include <dt-bindings/interconnect/qcom,rpm-icc.h>
15#include <dt-bindings/interconnect/qcom,sm6115.h>
16#include <dt-bindings/interrupt-controller/arm-gic.h>
17#include <dt-bindings/power/qcom-rpmpd.h>
18#include <dt-bindings/soc/qcom,apr.h>
19#include <dt-bindings/sound/qcom,q6asm.h>
20#include <dt-bindings/sound/qcom,q6dsp-lpass-ports.h>
21#include <dt-bindings/thermal/thermal.h>
22
23/ {
24	interrupt-parent = <&intc>;
25
26	#address-cells = <2>;
27	#size-cells = <2>;
28
29	chosen { };
30
31	clocks {
32		xo_board: xo-board {
33			compatible = "fixed-clock";
34			#clock-cells = <0>;
35		};
36
37		sleep_clk: sleep-clk {
38			compatible = "fixed-clock";
39			#clock-cells = <0>;
40		};
41	};
42
43	cpus {
44		#address-cells = <2>;
45		#size-cells = <0>;
46
47		cpu0: cpu@0 {
48			device_type = "cpu";
49			compatible = "qcom,kryo260";
50			reg = <0x0 0x0>;
51			clocks = <&cpufreq_hw 0>;
52			capacity-dmips-mhz = <1024>;
53			dynamic-power-coefficient = <100>;
54			enable-method = "psci";
55			next-level-cache = <&l2_0>;
56			qcom,freq-domain = <&cpufreq_hw 0>;
57			power-domains = <&cpu_pd0>;
58			power-domain-names = "psci";
59			l2_0: l2-cache {
60				compatible = "cache";
61				cache-level = <2>;
62				cache-unified;
63			};
64		};
65
66		cpu1: cpu@1 {
67			device_type = "cpu";
68			compatible = "qcom,kryo260";
69			reg = <0x0 0x1>;
70			clocks = <&cpufreq_hw 0>;
71			capacity-dmips-mhz = <1024>;
72			dynamic-power-coefficient = <100>;
73			enable-method = "psci";
74			next-level-cache = <&l2_0>;
75			qcom,freq-domain = <&cpufreq_hw 0>;
76			power-domains = <&cpu_pd1>;
77			power-domain-names = "psci";
78		};
79
80		cpu2: cpu@2 {
81			device_type = "cpu";
82			compatible = "qcom,kryo260";
83			reg = <0x0 0x2>;
84			clocks = <&cpufreq_hw 0>;
85			capacity-dmips-mhz = <1024>;
86			dynamic-power-coefficient = <100>;
87			enable-method = "psci";
88			next-level-cache = <&l2_0>;
89			qcom,freq-domain = <&cpufreq_hw 0>;
90			power-domains = <&cpu_pd2>;
91			power-domain-names = "psci";
92		};
93
94		cpu3: cpu@3 {
95			device_type = "cpu";
96			compatible = "qcom,kryo260";
97			reg = <0x0 0x3>;
98			clocks = <&cpufreq_hw 0>;
99			capacity-dmips-mhz = <1024>;
100			dynamic-power-coefficient = <100>;
101			enable-method = "psci";
102			next-level-cache = <&l2_0>;
103			qcom,freq-domain = <&cpufreq_hw 0>;
104			power-domains = <&cpu_pd3>;
105			power-domain-names = "psci";
106		};
107
108		cpu4: cpu@100 {
109			device_type = "cpu";
110			compatible = "qcom,kryo260";
111			reg = <0x0 0x100>;
112			clocks = <&cpufreq_hw 1>;
113			enable-method = "psci";
114			capacity-dmips-mhz = <1638>;
115			dynamic-power-coefficient = <282>;
116			next-level-cache = <&l2_1>;
117			qcom,freq-domain = <&cpufreq_hw 1>;
118			power-domains = <&cpu_pd4>;
119			power-domain-names = "psci";
120			l2_1: l2-cache {
121				compatible = "cache";
122				cache-level = <2>;
123				cache-unified;
124			};
125		};
126
127		cpu5: cpu@101 {
128			device_type = "cpu";
129			compatible = "qcom,kryo260";
130			reg = <0x0 0x101>;
131			clocks = <&cpufreq_hw 1>;
132			capacity-dmips-mhz = <1638>;
133			dynamic-power-coefficient = <282>;
134			enable-method = "psci";
135			next-level-cache = <&l2_1>;
136			qcom,freq-domain = <&cpufreq_hw 1>;
137			power-domains = <&cpu_pd5>;
138			power-domain-names = "psci";
139		};
140
141		cpu6: cpu@102 {
142			device_type = "cpu";
143			compatible = "qcom,kryo260";
144			reg = <0x0 0x102>;
145			clocks = <&cpufreq_hw 1>;
146			capacity-dmips-mhz = <1638>;
147			dynamic-power-coefficient = <282>;
148			enable-method = "psci";
149			next-level-cache = <&l2_1>;
150			qcom,freq-domain = <&cpufreq_hw 1>;
151			power-domains = <&cpu_pd6>;
152			power-domain-names = "psci";
153		};
154
155		cpu7: cpu@103 {
156			device_type = "cpu";
157			compatible = "qcom,kryo260";
158			reg = <0x0 0x103>;
159			clocks = <&cpufreq_hw 1>;
160			capacity-dmips-mhz = <1638>;
161			dynamic-power-coefficient = <282>;
162			enable-method = "psci";
163			next-level-cache = <&l2_1>;
164			qcom,freq-domain = <&cpufreq_hw 1>;
165			power-domains = <&cpu_pd7>;
166			power-domain-names = "psci";
167		};
168
169		cpu-map {
170			cluster0 {
171				core0 {
172					cpu = <&cpu0>;
173				};
174
175				core1 {
176					cpu = <&cpu1>;
177				};
178
179				core2 {
180					cpu = <&cpu2>;
181				};
182
183				core3 {
184					cpu = <&cpu3>;
185				};
186			};
187
188			cluster1 {
189				core0 {
190					cpu = <&cpu4>;
191				};
192
193				core1 {
194					cpu = <&cpu5>;
195				};
196
197				core2 {
198					cpu = <&cpu6>;
199				};
200
201				core3 {
202					cpu = <&cpu7>;
203				};
204			};
205		};
206
207		idle-states {
208			entry-method = "psci";
209
210			little_cpu_sleep_0: cpu-sleep-0-0 {
211				compatible = "arm,idle-state";
212				idle-state-name = "silver-rail-power-collapse";
213				arm,psci-suspend-param = <0x40000003>;
214				entry-latency-us = <290>;
215				exit-latency-us = <376>;
216				min-residency-us = <1182>;
217				local-timer-stop;
218			};
219
220			big_cpu_sleep_0: cpu-sleep-1-0 {
221				compatible = "arm,idle-state";
222				idle-state-name = "gold-rail-power-collapse";
223				arm,psci-suspend-param = <0x40000003>;
224				entry-latency-us = <297>;
225				exit-latency-us = <324>;
226				min-residency-us = <1110>;
227				local-timer-stop;
228			};
229		};
230
231		domain-idle-states {
232			cluster_0_sleep_0: cluster-sleep-0-0 {
233				/* GDHS */
234				compatible = "domain-idle-state";
235				arm,psci-suspend-param = <0x40000022>;
236				entry-latency-us = <360>;
237				exit-latency-us = <421>;
238				min-residency-us = <782>;
239			};
240
241			cluster_0_sleep_1: cluster-sleep-0-1 {
242				/* Power Collapse */
243				compatible = "domain-idle-state";
244				arm,psci-suspend-param = <0x41000044>;
245				entry-latency-us = <800>;
246				exit-latency-us = <2118>;
247				min-residency-us = <7376>;
248			};
249
250			cluster_1_sleep_0: cluster-sleep-1-0 {
251				/* GDHS */
252				compatible = "domain-idle-state";
253				arm,psci-suspend-param = <0x40000042>;
254				entry-latency-us = <314>;
255				exit-latency-us = <345>;
256				min-residency-us = <660>;
257			};
258
259			cluster_1_sleep_1: cluster-sleep-1-1 {
260				/* Power Collapse */
261				compatible = "domain-idle-state";
262				arm,psci-suspend-param = <0x41000044>;
263				entry-latency-us = <640>;
264				exit-latency-us = <1654>;
265				min-residency-us = <8094>;
266			};
267		};
268	};
269
270	firmware {
271		scm: scm {
272			compatible = "qcom,scm-sm6115", "qcom,scm";
273			#reset-cells = <1>;
274			interconnects = <&system_noc MASTER_CRYPTO_CORE0 RPM_ALWAYS_TAG
275					 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
276		};
277	};
278
279	memory@80000000 {
280		device_type = "memory";
281		/* We expect the bootloader to fill in the size */
282		reg = <0 0x80000000 0 0>;
283	};
284
285	qup_opp_table: opp-table-qup {
286		compatible = "operating-points-v2";
287
288		opp-75000000 {
289			opp-hz = /bits/ 64 <75000000>;
290			required-opps = <&rpmpd_opp_low_svs>;
291		};
292
293		opp-100000000 {
294			opp-hz = /bits/ 64 <100000000>;
295			required-opps = <&rpmpd_opp_svs>;
296		};
297
298		opp-128000000 {
299			opp-hz = /bits/ 64 <128000000>;
300			required-opps = <&rpmpd_opp_nom>;
301		};
302	};
303
304	pmu {
305		compatible = "arm,armv8-pmuv3";
306		interrupts = <GIC_PPI 6 IRQ_TYPE_LEVEL_HIGH>;
307	};
308
309	psci {
310		compatible = "arm,psci-1.0";
311		method = "smc";
312
313		cpu_pd0: power-domain-cpu0 {
314			#power-domain-cells = <0>;
315			power-domains = <&cluster_0_pd>;
316			domain-idle-states = <&little_cpu_sleep_0>;
317		};
318
319		cpu_pd1: power-domain-cpu1 {
320			#power-domain-cells = <0>;
321			power-domains = <&cluster_0_pd>;
322			domain-idle-states = <&little_cpu_sleep_0>;
323		};
324
325		cpu_pd2: power-domain-cpu2 {
326			#power-domain-cells = <0>;
327			power-domains = <&cluster_0_pd>;
328			domain-idle-states = <&little_cpu_sleep_0>;
329		};
330
331		cpu_pd3: power-domain-cpu3 {
332			#power-domain-cells = <0>;
333			power-domains = <&cluster_0_pd>;
334			domain-idle-states = <&little_cpu_sleep_0>;
335		};
336
337		cpu_pd4: power-domain-cpu4 {
338			#power-domain-cells = <0>;
339			power-domains = <&cluster_1_pd>;
340			domain-idle-states = <&big_cpu_sleep_0>;
341		};
342
343		cpu_pd5: power-domain-cpu5 {
344			#power-domain-cells = <0>;
345			power-domains = <&cluster_1_pd>;
346			domain-idle-states = <&big_cpu_sleep_0>;
347		};
348
349		cpu_pd6: power-domain-cpu6 {
350			#power-domain-cells = <0>;
351			power-domains = <&cluster_1_pd>;
352			domain-idle-states = <&big_cpu_sleep_0>;
353		};
354
355		cpu_pd7: power-domain-cpu7 {
356			#power-domain-cells = <0>;
357			power-domains = <&cluster_1_pd>;
358			domain-idle-states = <&big_cpu_sleep_0>;
359		};
360
361		cluster_0_pd: power-domain-cpu-cluster0 {
362			#power-domain-cells = <0>;
363			domain-idle-states = <&cluster_0_sleep_0>, <&cluster_0_sleep_1>;
364		};
365
366		cluster_1_pd: power-domain-cpu-cluster1 {
367			#power-domain-cells = <0>;
368			domain-idle-states = <&cluster_1_sleep_0>, <&cluster_1_sleep_1>;
369		};
370	};
371
372	rpm: remoteproc {
373		compatible = "qcom,sm6115-rpm-proc", "qcom,rpm-proc";
374
375		glink-edge {
376			compatible = "qcom,glink-rpm";
377
378			interrupts = <GIC_SPI 194 IRQ_TYPE_EDGE_RISING>;
379			qcom,rpm-msg-ram = <&rpm_msg_ram>;
380			mboxes = <&apcs_glb 0>;
381
382			rpm_requests: rpm-requests {
383				compatible = "qcom,rpm-sm6115", "qcom,glink-smd-rpm";
384				qcom,glink-channels = "rpm_requests";
385
386				rpmcc: clock-controller {
387					compatible = "qcom,rpmcc-sm6115", "qcom,rpmcc";
388					clocks = <&xo_board>;
389					clock-names = "xo";
390					#clock-cells = <1>;
391				};
392
393				rpmpd: power-controller {
394					compatible = "qcom,sm6115-rpmpd";
395					#power-domain-cells = <1>;
396					operating-points-v2 = <&rpmpd_opp_table>;
397
398					rpmpd_opp_table: opp-table {
399						compatible = "operating-points-v2";
400
401						rpmpd_opp_min_svs: opp1 {
402							opp-level = <RPM_SMD_LEVEL_MIN_SVS>;
403						};
404
405						rpmpd_opp_low_svs: opp2 {
406							opp-level = <RPM_SMD_LEVEL_LOW_SVS>;
407						};
408
409						rpmpd_opp_svs: opp3 {
410							opp-level = <RPM_SMD_LEVEL_SVS>;
411						};
412
413						rpmpd_opp_svs_plus: opp4 {
414							opp-level = <RPM_SMD_LEVEL_SVS_PLUS>;
415						};
416
417						rpmpd_opp_nom: opp5 {
418							opp-level = <RPM_SMD_LEVEL_NOM>;
419						};
420
421						rpmpd_opp_nom_plus: opp6 {
422							opp-level = <RPM_SMD_LEVEL_NOM_PLUS>;
423						};
424
425						rpmpd_opp_turbo: opp7 {
426							opp-level = <RPM_SMD_LEVEL_TURBO>;
427						};
428
429						rpmpd_opp_turbo_plus: opp8 {
430							opp-level = <RPM_SMD_LEVEL_TURBO_NO_CPR>;
431						};
432					};
433				};
434			};
435		};
436	};
437
438	reserved_memory: reserved-memory {
439		#address-cells = <2>;
440		#size-cells = <2>;
441		ranges;
442
443		hyp_mem: memory@45700000 {
444			reg = <0x0 0x45700000 0x0 0x600000>;
445			no-map;
446		};
447
448		xbl_aop_mem: memory@45e00000 {
449			reg = <0x0 0x45e00000 0x0 0x140000>;
450			no-map;
451		};
452
453		sec_apps_mem: memory@45fff000 {
454			reg = <0x0 0x45fff000 0x0 0x1000>;
455			no-map;
456		};
457
458		smem_mem: memory@46000000 {
459			compatible = "qcom,smem";
460			reg = <0x0 0x46000000 0x0 0x200000>;
461			no-map;
462
463			hwlocks = <&tcsr_mutex 3>;
464			qcom,rpm-msg-ram = <&rpm_msg_ram>;
465		};
466
467		cdsp_sec_mem: memory@46200000 {
468			reg = <0x0 0x46200000 0x0 0x1e00000>;
469			no-map;
470		};
471
472		pil_modem_mem: memory@4ab00000 {
473			reg = <0x0 0x4ab00000 0x0 0x6900000>;
474			no-map;
475		};
476
477		pil_video_mem: memory@51400000 {
478			reg = <0x0 0x51400000 0x0 0x500000>;
479			no-map;
480		};
481
482		wlan_msa_mem: memory@51900000 {
483			reg = <0x0 0x51900000 0x0 0x100000>;
484			no-map;
485		};
486
487		pil_cdsp_mem: memory@51a00000 {
488			reg = <0x0 0x51a00000 0x0 0x1e00000>;
489			no-map;
490		};
491
492		pil_adsp_mem: memory@53800000 {
493			reg = <0x0 0x53800000 0x0 0x2800000>;
494			no-map;
495		};
496
497		pil_ipa_fw_mem: memory@56100000 {
498			reg = <0x0 0x56100000 0x0 0x10000>;
499			no-map;
500		};
501
502		pil_ipa_gsi_mem: memory@56110000 {
503			reg = <0x0 0x56110000 0x0 0x5000>;
504			no-map;
505		};
506
507		pil_gpu_mem: memory@56115000 {
508			reg = <0x0 0x56115000 0x0 0x2000>;
509			no-map;
510		};
511
512		cont_splash_memory: memory@5c000000 {
513			reg = <0x0 0x5c000000 0x0 0x00f00000>;
514			no-map;
515		};
516
517		dfps_data_memory: memory@5cf00000 {
518			reg = <0x0 0x5cf00000 0x0 0x0100000>;
519			no-map;
520		};
521
522		removed_mem: memory@60000000 {
523			reg = <0x0 0x60000000 0x0 0x3900000>;
524			no-map;
525		};
526
527		rmtfs_mem: memory@89b01000 {
528			compatible = "qcom,rmtfs-mem";
529			reg = <0x0 0x89b01000 0x0 0x200000>;
530			no-map;
531
532			qcom,client-id = <1>;
533			qcom,vmid = <QCOM_SCM_VMID_MSS_MSA QCOM_SCM_VMID_NAV>;
534		};
535	};
536
537	smp2p-adsp {
538		compatible = "qcom,smp2p";
539		qcom,smem = <443>, <429>;
540
541		interrupts = <GIC_SPI 279 IRQ_TYPE_EDGE_RISING>;
542
543		mboxes = <&apcs_glb 10>;
544
545		qcom,local-pid = <0>;
546		qcom,remote-pid = <2>;
547
548		adsp_smp2p_out: master-kernel {
549			qcom,entry-name = "master-kernel";
550			#qcom,smem-state-cells = <1>;
551		};
552
553		adsp_smp2p_in: slave-kernel {
554			qcom,entry-name = "slave-kernel";
555
556			interrupt-controller;
557			#interrupt-cells = <2>;
558		};
559	};
560
561	smp2p-cdsp {
562		compatible = "qcom,smp2p";
563		qcom,smem = <94>, <432>;
564
565		interrupts = <GIC_SPI 263 IRQ_TYPE_EDGE_RISING>;
566
567		mboxes = <&apcs_glb 30>;
568
569		qcom,local-pid = <0>;
570		qcom,remote-pid = <5>;
571
572		cdsp_smp2p_out: master-kernel {
573			qcom,entry-name = "master-kernel";
574			#qcom,smem-state-cells = <1>;
575		};
576
577		cdsp_smp2p_in: slave-kernel {
578			qcom,entry-name = "slave-kernel";
579
580			interrupt-controller;
581			#interrupt-cells = <2>;
582		};
583	};
584
585	smp2p-mpss {
586		compatible = "qcom,smp2p";
587		qcom,smem = <435>, <428>;
588
589		interrupts = <GIC_SPI 70 IRQ_TYPE_EDGE_RISING>;
590
591		mboxes = <&apcs_glb 14>;
592
593		qcom,local-pid = <0>;
594		qcom,remote-pid = <1>;
595
596		modem_smp2p_out: master-kernel {
597			qcom,entry-name = "master-kernel";
598			#qcom,smem-state-cells = <1>;
599		};
600
601		modem_smp2p_in: slave-kernel {
602			qcom,entry-name = "slave-kernel";
603
604			interrupt-controller;
605			#interrupt-cells = <2>;
606		};
607	};
608
609	soc: soc@0 {
610		compatible = "simple-bus";
611		#address-cells = <2>;
612		#size-cells = <2>;
613		ranges = <0 0 0 0 0x10 0>;
614		dma-ranges = <0 0 0 0 0x10 0>;
615
616		tcsr_mutex: hwlock@340000 {
617			compatible = "qcom,tcsr-mutex";
618			reg = <0x0 0x00340000 0x0 0x20000>;
619			#hwlock-cells = <1>;
620		};
621
622		tcsr_regs: syscon@3c0000 {
623			compatible = "qcom,sm6115-tcsr", "syscon";
624			reg = <0x0 0x003c0000 0x0 0x40000>;
625		};
626
627		tlmm: pinctrl@500000 {
628			compatible = "qcom,sm6115-tlmm";
629			reg = <0x0 0x00500000 0x0 0x400000>,
630			      <0x0 0x00900000 0x0 0x400000>,
631			      <0x0 0x00d00000 0x0 0x400000>;
632			reg-names = "west", "south", "east";
633			interrupts = <GIC_SPI 227 IRQ_TYPE_LEVEL_HIGH>;
634			gpio-controller;
635			gpio-ranges = <&tlmm 0 0 114>; /* GPIOs + ufs_reset */
636			#gpio-cells = <2>;
637			interrupt-controller;
638			#interrupt-cells = <2>;
639
640			qup_i2c0_default: qup-i2c0-default-state {
641				pins = "gpio0", "gpio1";
642				function = "qup0";
643				drive-strength = <2>;
644				bias-pull-up;
645			};
646
647			qup_i2c1_default: qup-i2c1-default-state {
648				pins = "gpio4", "gpio5";
649				function = "qup1";
650				drive-strength = <2>;
651				bias-pull-up;
652			};
653
654			qup_i2c2_default: qup-i2c2-default-state {
655				pins = "gpio6", "gpio7";
656				function = "qup2";
657				drive-strength = <2>;
658				bias-pull-up;
659			};
660
661			qup_i2c3_default: qup-i2c3-default-state {
662				pins = "gpio8", "gpio9";
663				function = "qup3";
664				drive-strength = <2>;
665				bias-pull-up;
666			};
667
668			qup_i2c4_default: qup-i2c4-default-state {
669				pins = "gpio12", "gpio13";
670				function = "qup4";
671				drive-strength = <2>;
672				bias-pull-up;
673			};
674
675			qup_i2c5_default: qup-i2c5-default-state {
676				pins = "gpio14", "gpio15";
677				function = "qup5";
678				drive-strength = <2>;
679				bias-pull-up;
680			};
681
682			qup_spi0_default: qup-spi0-default-state {
683				pins = "gpio0", "gpio1","gpio2", "gpio3";
684				function = "qup0";
685				drive-strength = <2>;
686				bias-pull-up;
687			};
688
689			qup_spi1_default: qup-spi1-default-state {
690				pins = "gpio4", "gpio5", "gpio69", "gpio70";
691				function = "qup1";
692				drive-strength = <2>;
693				bias-pull-up;
694			};
695
696			qup_spi2_default: qup-spi2-default-state {
697				pins = "gpio6", "gpio7", "gpio71", "gpio80";
698				function = "qup2";
699				drive-strength = <2>;
700				bias-pull-up;
701			};
702
703			qup_spi3_default: qup-spi3-default-state {
704				pins = "gpio8", "gpio9", "gpio10", "gpio11";
705				function = "qup3";
706				drive-strength = <2>;
707				bias-pull-up;
708			};
709
710			qup_spi4_default: qup-spi4-default-state {
711				pins = "gpio12", "gpio13", "gpio96", "gpio97";
712				function = "qup4";
713				drive-strength = <2>;
714				bias-pull-up;
715			};
716
717			qup_spi5_default: qup-spi5-default-state {
718				pins = "gpio14", "gpio15", "gpio16", "gpio17";
719				function = "qup5";
720				drive-strength = <2>;
721				bias-pull-up;
722			};
723
724			qup_uart4_default: qup-uart4-default-state {
725				pins = "gpio12", "gpio13";
726				function = "qup4";
727				drive-strength = <2>;
728				bias-disable;
729			};
730
731			sdc1_state_on: sdc1-on-state {
732				clk-pins {
733					pins = "sdc1_clk";
734					bias-disable;
735					drive-strength = <16>;
736				};
737
738				cmd-pins {
739					pins = "sdc1_cmd";
740					bias-pull-up;
741					drive-strength = <10>;
742				};
743
744				data-pins {
745					pins = "sdc1_data";
746					bias-pull-up;
747					drive-strength = <10>;
748				};
749
750				rclk-pins {
751					pins = "sdc1_rclk";
752					bias-pull-down;
753				};
754			};
755
756			sdc1_state_off: sdc1-off-state {
757				clk-pins {
758					pins = "sdc1_clk";
759					bias-disable;
760					drive-strength = <2>;
761				};
762
763				cmd-pins {
764					pins = "sdc1_cmd";
765					bias-pull-up;
766					drive-strength = <2>;
767				};
768
769				data-pins {
770					pins = "sdc1_data";
771					bias-pull-up;
772					drive-strength = <2>;
773				};
774
775				rclk-pins {
776					pins = "sdc1_rclk";
777					bias-pull-down;
778				};
779			};
780
781			sdc2_state_on: sdc2-on-state {
782				clk-pins {
783					pins = "sdc2_clk";
784					bias-disable;
785					drive-strength = <16>;
786				};
787
788				cmd-pins {
789					pins = "sdc2_cmd";
790					bias-pull-up;
791					drive-strength = <10>;
792				};
793
794				data-pins {
795					pins = "sdc2_data";
796					bias-pull-up;
797					drive-strength = <10>;
798				};
799			};
800
801			sdc2_state_off: sdc2-off-state {
802				clk-pins {
803					pins = "sdc2_clk";
804					bias-disable;
805					drive-strength = <2>;
806				};
807
808				cmd-pins {
809					pins = "sdc2_cmd";
810					bias-pull-up;
811					drive-strength = <2>;
812				};
813
814				data-pins {
815					pins = "sdc2_data";
816					bias-pull-up;
817					drive-strength = <2>;
818				};
819			};
820		};
821
822		lpass_tlmm: pinctrl@a7c0000 {
823			compatible = "qcom,sm6115-lpass-lpi-pinctrl";
824			reg = <0x0 0x0a7c0000 0x0 0x20000>,
825			      <0x0 0x0a950000 0x0 0x10000>;
826
827			clocks = <&q6afecc LPASS_HW_DCODEC_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>;
828			clock-names = "audio";
829
830			gpio-controller;
831			#gpio-cells = <2>;
832			gpio-ranges = <&lpass_tlmm 0 0 19>;
833
834		};
835
836		gcc: clock-controller@1400000 {
837			compatible = "qcom,gcc-sm6115";
838			reg = <0x0 0x01400000 0x0 0x1f0000>;
839			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>, <&sleep_clk>;
840			clock-names = "bi_tcxo", "sleep_clk";
841			#clock-cells = <1>;
842			#reset-cells = <1>;
843			#power-domain-cells = <1>;
844		};
845
846		usb_hsphy: phy@1613000 {
847			compatible = "qcom,sm6115-qusb2-phy";
848			reg = <0x0 0x01613000 0x0 0x180>;
849			#phy-cells = <0>;
850
851			clocks = <&gcc GCC_AHB2PHY_USB_CLK>, <&rpmcc RPM_SMD_XO_CLK_SRC>;
852			clock-names = "cfg_ahb", "ref";
853
854			resets = <&gcc GCC_QUSB2PHY_PRIM_BCR>;
855			nvmem-cells = <&qusb2_hstx_trim>;
856
857			status = "disabled";
858		};
859
860		cryptobam: dma-controller@1b04000 {
861			compatible = "qcom,bam-v1.7.4", "qcom,bam-v1.7.0";
862			reg = <0x0 0x01b04000 0x0 0x24000>;
863			interrupts = <GIC_SPI 247 IRQ_TYPE_LEVEL_HIGH>;
864			clocks = <&rpmcc RPM_SMD_CE1_CLK>;
865			clock-names = "bam_clk";
866			#dma-cells = <1>;
867			qcom,ee = <0>;
868			qcom,controlled-remotely;
869			iommus = <&apps_smmu 0x92 0>,
870				 <&apps_smmu 0x94 0x11>,
871				 <&apps_smmu 0x96 0x11>,
872				 <&apps_smmu 0x98 0x1>,
873				 <&apps_smmu 0x9F 0>;
874		};
875
876		crypto: crypto@1b3a000 {
877			compatible = "qcom,sm6115-qce", "qcom,ipq4019-qce", "qcom,qce";
878			reg = <0x0 0x01b3a000 0x0 0x6000>;
879			clocks = <&rpmcc RPM_SMD_CE1_CLK>;
880			clock-names = "core";
881
882			dmas = <&cryptobam 6>, <&cryptobam 7>;
883			dma-names = "rx", "tx";
884			iommus = <&apps_smmu 0x92 0>,
885				 <&apps_smmu 0x94 0x11>,
886				 <&apps_smmu 0x96 0x11>,
887				 <&apps_smmu 0x98 0x1>,
888				 <&apps_smmu 0x9F 0>;
889		};
890
891		usb_qmpphy: phy@1615000 {
892			compatible = "qcom,sm6115-qmp-usb3-phy";
893			reg = <0x0 0x01615000 0x0 0x1000>;
894
895			clocks = <&gcc GCC_AHB2PHY_USB_CLK>,
896				 <&gcc GCC_USB3_PRIM_CLKREF_CLK>,
897				 <&gcc GCC_USB3_PRIM_PHY_COM_AUX_CLK>,
898				 <&gcc GCC_USB3_PRIM_PHY_PIPE_CLK>;
899			clock-names = "cfg_ahb",
900				      "ref",
901				      "com_aux",
902				      "pipe";
903
904			resets = <&gcc GCC_USB3_PHY_PRIM_SP0_BCR>,
905				 <&gcc GCC_USB3PHY_PHY_PRIM_SP0_BCR>;
906			reset-names = "phy", "phy_phy";
907
908			#clock-cells = <0>;
909			clock-output-names = "usb3_phy_pipe_clk_src";
910
911			#phy-cells = <0>;
912			orientation-switch;
913
914			qcom,tcsr-reg = <&tcsr_regs 0xb244>;
915
916			status = "disabled";
917
918			ports {
919				#address-cells = <1>;
920				#size-cells = <0>;
921
922				port@0 {
923					reg = <0>;
924
925					usb_qmpphy_out: endpoint {
926					};
927				};
928
929				port@1 {
930					reg = <1>;
931
932					usb_qmpphy_usb_ss_in: endpoint {
933						remote-endpoint = <&usb_dwc3_ss>;
934					};
935				};
936			};
937		};
938
939		system_noc: interconnect@1880000 {
940			compatible = "qcom,sm6115-snoc";
941			reg = <0x0 0x01880000 0x0 0x5f080>;
942			clocks = <&gcc GCC_SYS_NOC_CPUSS_AHB_CLK>,
943				 <&gcc GCC_SYS_NOC_UFS_PHY_AXI_CLK>,
944				 <&gcc GCC_SYS_NOC_USB3_PRIM_AXI_CLK>,
945				 <&rpmcc RPM_SMD_IPA_CLK>;
946			clock-names = "cpu_axi",
947				      "ufs_axi",
948				      "usb_axi",
949				      "ipa";
950			#interconnect-cells = <2>;
951
952			clk_virt: interconnect-clk {
953				compatible = "qcom,sm6115-clk-virt";
954				#interconnect-cells = <2>;
955			};
956
957			mmrt_virt: interconnect-mmrt {
958				compatible = "qcom,sm6115-mmrt-virt";
959				#interconnect-cells = <2>;
960			};
961
962			mmnrt_virt: interconnect-mmnrt {
963				compatible = "qcom,sm6115-mmnrt-virt";
964				#interconnect-cells = <2>;
965			};
966		};
967
968		config_noc: interconnect@1900000 {
969			compatible = "qcom,sm6115-cnoc";
970			reg = <0x0 0x01900000 0x0 0x6200>;
971			clocks = <&gcc GCC_CFG_NOC_USB3_PRIM_AXI_CLK>;
972			clock-names = "usb_axi";
973			#interconnect-cells = <2>;
974		};
975
976		qfprom@1b40000 {
977			compatible = "qcom,sm6115-qfprom", "qcom,qfprom";
978			reg = <0x0 0x01b40000 0x0 0x7000>;
979			#address-cells = <1>;
980			#size-cells = <1>;
981
982			qusb2_hstx_trim: hstx-trim@25b {
983				reg = <0x25b 0x1>;
984				bits = <1 4>;
985			};
986
987			gpu_speed_bin: gpu-speed-bin@6006 {
988				reg = <0x6006 0x2>;
989				bits = <5 8>;
990			};
991		};
992
993		rng: rng@1b53000 {
994			compatible = "qcom,prng-ee";
995			reg = <0x0 0x01b53000 0x0 0x1000>;
996			clocks = <&gcc GCC_PRNG_AHB_CLK>;
997			clock-names = "core";
998		};
999
1000		pmu@1b8e300 {
1001			compatible = "qcom,sm6115-cpu-bwmon", "qcom,sdm845-bwmon";
1002			reg = <0x0 0x01b8e300 0x0 0x600>;
1003			interrupts = <GIC_SPI 421 IRQ_TYPE_LEVEL_HIGH>;
1004
1005			operating-points-v2 = <&cpu_bwmon_opp_table>;
1006			interconnects = <&bimc MASTER_AMPSS_M0 RPM_ACTIVE_TAG
1007					 &bimc SLAVE_EBI_CH0 RPM_ACTIVE_TAG>;
1008
1009			cpu_bwmon_opp_table: opp-table {
1010				compatible = "operating-points-v2";
1011
1012				opp-0 {
1013					opp-peak-kBps = <(200 * 4 * 1000)>;
1014				};
1015
1016				opp-1 {
1017					opp-peak-kBps = <(300 * 4 * 1000)>;
1018				};
1019
1020				opp-2 {
1021					opp-peak-kBps = <(451 * 4 * 1000)>;
1022				};
1023
1024				opp-3 {
1025					opp-peak-kBps = <(547 * 4 * 1000)>;
1026				};
1027
1028				opp-4 {
1029					opp-peak-kBps = <(681 * 4 * 1000)>;
1030				};
1031
1032				opp-5 {
1033					opp-peak-kBps = <(768 * 4 * 1000)>;
1034				};
1035
1036				opp-6 {
1037					opp-peak-kBps = <(1017 * 4 * 1000)>;
1038				};
1039
1040				opp-7 {
1041					opp-peak-kBps = <(1353 * 4 * 1000)>;
1042				};
1043
1044				opp-8 {
1045					opp-peak-kBps = <(1555 * 4 * 1000)>;
1046				};
1047
1048				opp-9 {
1049					opp-peak-kBps = <(1804 * 4 * 1000)>;
1050				};
1051			};
1052		};
1053
1054		spmi_bus: spmi@1c40000 {
1055			compatible = "qcom,spmi-pmic-arb";
1056			reg = <0x0 0x01c40000 0x0 0x1100>,
1057			      <0x0 0x01e00000 0x0 0x2000000>,
1058			      <0x0 0x03e00000 0x0 0x100000>,
1059			      <0x0 0x03f00000 0x0 0xa0000>,
1060			      <0x0 0x01c0a000 0x0 0x26000>;
1061			reg-names = "core", "chnls", "obsrvr", "intr", "cnfg";
1062			interrupt-names = "periph_irq";
1063			interrupts = <GIC_SPI 183 IRQ_TYPE_LEVEL_HIGH>;
1064			qcom,ee = <0>;
1065			qcom,channel = <0>;
1066			#address-cells = <2>;
1067			#size-cells = <0>;
1068			interrupt-controller;
1069			#interrupt-cells = <4>;
1070		};
1071
1072		tsens0: thermal-sensor@4411000 {
1073			compatible = "qcom,sm6115-tsens", "qcom,tsens-v2";
1074			reg = <0x0 0x04411000 0x0 0x1ff>, /* TM */
1075			      <0x0 0x04410000 0x0 0x8>; /* SROT */
1076			#qcom,sensors = <16>;
1077			interrupts = <GIC_SPI 275 IRQ_TYPE_LEVEL_HIGH>,
1078				     <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>;
1079			interrupt-names = "uplow", "critical";
1080			#thermal-sensor-cells = <1>;
1081		};
1082
1083		bimc: interconnect@4480000 {
1084			compatible = "qcom,sm6115-bimc";
1085			reg = <0x0 0x04480000 0x0 0x80000>;
1086			#interconnect-cells = <2>;
1087		};
1088
1089		rpm_msg_ram: sram@45f0000 {
1090			compatible = "qcom,rpm-msg-ram";
1091			reg = <0x0 0x045f0000 0x0 0x7000>;
1092		};
1093
1094		sram@4690000 {
1095			compatible = "qcom,rpm-stats";
1096			reg = <0x0 0x04690000 0x0 0x10000>;
1097		};
1098
1099		sdhc_1: mmc@4744000 {
1100			compatible = "qcom,sm6115-sdhci", "qcom,sdhci-msm-v5";
1101			reg = <0x0 0x04744000 0x0 0x1000>,
1102			      <0x0 0x04745000 0x0 0x1000>,
1103			      <0x0 0x04748000 0x0 0x8000>;
1104			reg-names = "hc", "cqhci", "ice";
1105
1106			interrupts = <GIC_SPI 348 IRQ_TYPE_LEVEL_HIGH>,
1107				     <GIC_SPI 352 IRQ_TYPE_LEVEL_HIGH>;
1108			interrupt-names = "hc_irq", "pwr_irq";
1109
1110			clocks = <&gcc GCC_SDCC1_AHB_CLK>,
1111				 <&gcc GCC_SDCC1_APPS_CLK>,
1112				 <&rpmcc RPM_SMD_XO_CLK_SRC>,
1113				 <&gcc GCC_SDCC1_ICE_CORE_CLK>;
1114			clock-names = "iface", "core", "xo", "ice";
1115
1116			resets = <&gcc GCC_SDCC1_BCR>;
1117
1118			power-domains = <&rpmpd SM6115_VDDCX>;
1119			operating-points-v2 = <&sdhc1_opp_table>;
1120			iommus = <&apps_smmu 0x00c0 0x0>;
1121			interconnects = <&system_noc MASTER_SDCC_1 RPM_ALWAYS_TAG
1122					 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>,
1123					<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1124					 &config_noc SLAVE_SDCC_1 RPM_ALWAYS_TAG>;
1125			interconnect-names = "sdhc-ddr",
1126					     "cpu-sdhc";
1127
1128			bus-width = <8>;
1129			status = "disabled";
1130
1131			sdhc1_opp_table: opp-table {
1132				compatible = "operating-points-v2";
1133
1134				opp-100000000 {
1135					opp-hz = /bits/ 64 <100000000>;
1136					required-opps = <&rpmpd_opp_low_svs>;
1137					opp-peak-kBps = <250000 133320>;
1138					opp-avg-kBps = <102400 65000>;
1139				};
1140
1141				opp-192000000 {
1142					opp-hz = /bits/ 64 <192000000>;
1143					required-opps = <&rpmpd_opp_low_svs>;
1144					opp-peak-kBps = <800000 300000>;
1145					opp-avg-kBps = <204800 200000>;
1146				};
1147
1148				opp-384000000 {
1149					opp-hz = /bits/ 64 <384000000>;
1150					required-opps = <&rpmpd_opp_svs_plus>;
1151					opp-peak-kBps = <800000 300000>;
1152					opp-avg-kBps = <204800 200000>;
1153				};
1154			};
1155		};
1156
1157		sdhc_2: mmc@4784000 {
1158			compatible = "qcom,sm6115-sdhci", "qcom,sdhci-msm-v5";
1159			reg = <0x0 0x04784000 0x0 0x1000>;
1160			reg-names = "hc";
1161
1162			interrupts = <GIC_SPI 350 IRQ_TYPE_LEVEL_HIGH>,
1163				     <GIC_SPI 353 IRQ_TYPE_LEVEL_HIGH>;
1164			interrupt-names = "hc_irq", "pwr_irq";
1165
1166			clocks = <&gcc GCC_SDCC2_AHB_CLK>,
1167				 <&gcc GCC_SDCC2_APPS_CLK>,
1168				 <&rpmcc RPM_SMD_XO_CLK_SRC>;
1169			clock-names = "iface", "core", "xo";
1170
1171			power-domains = <&rpmpd SM6115_VDDCX>;
1172			operating-points-v2 = <&sdhc2_opp_table>;
1173			iommus = <&apps_smmu 0x00a0 0x0>;
1174			resets = <&gcc GCC_SDCC2_BCR>;
1175			interconnects = <&system_noc MASTER_SDCC_2 RPM_ALWAYS_TAG
1176					 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>,
1177					<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1178					 &config_noc SLAVE_SDCC_2 RPM_ALWAYS_TAG>;
1179			interconnect-names = "sdhc-ddr",
1180					     "cpu-sdhc";
1181
1182			bus-width = <4>;
1183			qcom,dll-config = <0x0007642c>;
1184			qcom,ddr-config = <0x80040868>;
1185			status = "disabled";
1186
1187			sdhc2_opp_table: opp-table {
1188				compatible = "operating-points-v2";
1189
1190				opp-100000000 {
1191					opp-hz = /bits/ 64 <100000000>;
1192					required-opps = <&rpmpd_opp_low_svs>;
1193					opp-peak-kBps = <250000 133320>;
1194					opp-avg-kBps = <261438 150000>;
1195				};
1196
1197				opp-202000000 {
1198					opp-hz = /bits/ 64 <202000000>;
1199					required-opps = <&rpmpd_opp_nom>;
1200					opp-peak-kBps = <800000 300000>;
1201					opp-avg-kBps = <261438 300000>;
1202				};
1203			};
1204		};
1205
1206		ufs_mem_hc: ufshc@4804000 {
1207			compatible = "qcom,sm6115-ufshc", "qcom,ufshc", "jedec,ufs-2.0";
1208			reg = <0x0 0x04804000 0x0 0x3000>, <0x0 0x04810000 0x0 0x8000>;
1209			reg-names = "std", "ice";
1210			interrupts = <GIC_SPI 356 IRQ_TYPE_LEVEL_HIGH>;
1211			phys = <&ufs_mem_phy>;
1212			phy-names = "ufsphy";
1213			lanes-per-direction = <1>;
1214			#reset-cells = <1>;
1215			resets = <&gcc GCC_UFS_PHY_BCR>;
1216			reset-names = "rst";
1217
1218			power-domains = <&gcc GCC_UFS_PHY_GDSC>;
1219			iommus = <&apps_smmu 0x100 0>;
1220
1221			clocks = <&gcc GCC_UFS_PHY_AXI_CLK>,
1222				 <&gcc GCC_SYS_NOC_UFS_PHY_AXI_CLK>,
1223				 <&gcc GCC_UFS_PHY_AHB_CLK>,
1224				 <&gcc GCC_UFS_PHY_UNIPRO_CORE_CLK>,
1225				 <&rpmcc RPM_SMD_XO_CLK_SRC>,
1226				 <&gcc GCC_UFS_PHY_TX_SYMBOL_0_CLK>,
1227				 <&gcc GCC_UFS_PHY_RX_SYMBOL_0_CLK>,
1228				 <&gcc GCC_UFS_PHY_ICE_CORE_CLK>;
1229			clock-names = "core_clk",
1230				      "bus_aggr_clk",
1231				      "iface_clk",
1232				      "core_clk_unipro",
1233				      "ref_clk",
1234				      "tx_lane0_sync_clk",
1235				      "rx_lane0_sync_clk",
1236				      "ice_core_clk";
1237
1238			freq-table-hz = <50000000 200000000>,
1239					<0 0>,
1240					<0 0>,
1241					<37500000 150000000>,
1242					<0 0>,
1243					<0 0>,
1244					<0 0>,
1245					<75000000 300000000>;
1246
1247			status = "disabled";
1248		};
1249
1250		ufs_mem_phy: phy@4807000 {
1251			compatible = "qcom,sm6115-qmp-ufs-phy";
1252			reg = <0x0 0x04807000 0x0 0x1000>;
1253
1254			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>,
1255				 <&gcc GCC_UFS_PHY_PHY_AUX_CLK>,
1256				 <&gcc GCC_UFS_CLKREF_CLK>;
1257			clock-names = "ref",
1258				      "ref_aux",
1259				      "qref";
1260
1261			power-domains = <&gcc GCC_UFS_PHY_GDSC>;
1262
1263			resets = <&ufs_mem_hc 0>;
1264			reset-names = "ufsphy";
1265
1266			#phy-cells = <0>;
1267
1268			status = "disabled";
1269		};
1270
1271		gpi_dma0: dma-controller@4a00000 {
1272			compatible = "qcom,sm6115-gpi-dma", "qcom,sm6350-gpi-dma";
1273			reg = <0x0 0x04a00000 0x0 0x60000>;
1274			interrupts = <GIC_SPI 335 IRQ_TYPE_LEVEL_HIGH>,
1275				     <GIC_SPI 336 IRQ_TYPE_LEVEL_HIGH>,
1276				     <GIC_SPI 337 IRQ_TYPE_LEVEL_HIGH>,
1277				     <GIC_SPI 338 IRQ_TYPE_LEVEL_HIGH>,
1278				     <GIC_SPI 339 IRQ_TYPE_LEVEL_HIGH>,
1279				     <GIC_SPI 340 IRQ_TYPE_LEVEL_HIGH>,
1280				     <GIC_SPI 341 IRQ_TYPE_LEVEL_HIGH>,
1281				     <GIC_SPI 342 IRQ_TYPE_LEVEL_HIGH>,
1282				     <GIC_SPI 343 IRQ_TYPE_LEVEL_HIGH>,
1283				     <GIC_SPI 344 IRQ_TYPE_LEVEL_HIGH>;
1284			dma-channels = <10>;
1285			dma-channel-mask = <0xf>;
1286			iommus = <&apps_smmu 0xf6 0x0>;
1287			#dma-cells = <3>;
1288			status = "disabled";
1289		};
1290
1291		qupv3_id_0: geniqup@4ac0000 {
1292			compatible = "qcom,geni-se-qup";
1293			reg = <0x0 0x04ac0000 0x0 0x2000>;
1294			clock-names = "m-ahb", "s-ahb";
1295			clocks = <&gcc GCC_QUPV3_WRAP_0_M_AHB_CLK>,
1296				 <&gcc GCC_QUPV3_WRAP_0_S_AHB_CLK>;
1297			#address-cells = <2>;
1298			#size-cells = <2>;
1299			iommus = <&apps_smmu 0xe3 0x0>;
1300			ranges;
1301			status = "disabled";
1302
1303			i2c0: i2c@4a80000 {
1304				compatible = "qcom,geni-i2c";
1305				reg = <0x0 0x04a80000 0x0 0x4000>;
1306				clock-names = "se";
1307				clocks = <&gcc GCC_QUPV3_WRAP0_S0_CLK>;
1308				pinctrl-names = "default";
1309				pinctrl-0 = <&qup_i2c0_default>;
1310				interrupts = <GIC_SPI 327 IRQ_TYPE_LEVEL_HIGH>;
1311				dmas = <&gpi_dma0 0 0 QCOM_GPI_I2C>,
1312				       <&gpi_dma0 1 0 QCOM_GPI_I2C>;
1313				dma-names = "tx", "rx";
1314				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1315						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1316						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1317						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1318						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1319						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1320				interconnect-names = "qup-core",
1321						     "qup-config",
1322						     "qup-memory";
1323				#address-cells = <1>;
1324				#size-cells = <0>;
1325				status = "disabled";
1326			};
1327
1328			spi0: spi@4a80000 {
1329				compatible = "qcom,geni-spi";
1330				reg = <0x0 0x04a80000 0x0 0x4000>;
1331				clock-names = "se";
1332				clocks = <&gcc GCC_QUPV3_WRAP0_S0_CLK>;
1333				pinctrl-names = "default";
1334				pinctrl-0 = <&qup_spi0_default>;
1335				interrupts = <GIC_SPI 327 IRQ_TYPE_LEVEL_HIGH>;
1336				dmas = <&gpi_dma0 0 0 QCOM_GPI_SPI>,
1337				       <&gpi_dma0 1 0 QCOM_GPI_SPI>;
1338				dma-names = "tx", "rx";
1339				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1340						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1341						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1342						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1343						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1344						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1345				interconnect-names = "qup-core",
1346						     "qup-config",
1347						     "qup-memory";
1348				#address-cells = <1>;
1349				#size-cells = <0>;
1350				status = "disabled";
1351			};
1352
1353			i2c1: i2c@4a84000 {
1354				compatible = "qcom,geni-i2c";
1355				reg = <0x0 0x04a84000 0x0 0x4000>;
1356				clock-names = "se";
1357				clocks = <&gcc GCC_QUPV3_WRAP0_S1_CLK>;
1358				pinctrl-names = "default";
1359				pinctrl-0 = <&qup_i2c1_default>;
1360				interrupts = <GIC_SPI 328 IRQ_TYPE_LEVEL_HIGH>;
1361				dmas = <&gpi_dma0 0 1 QCOM_GPI_I2C>,
1362				       <&gpi_dma0 1 1 QCOM_GPI_I2C>;
1363				dma-names = "tx", "rx";
1364				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1365						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1366						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1367						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1368						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1369						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1370				interconnect-names = "qup-core",
1371						     "qup-config",
1372						     "qup-memory";
1373				#address-cells = <1>;
1374				#size-cells = <0>;
1375				status = "disabled";
1376			};
1377
1378			spi1: spi@4a84000 {
1379				compatible = "qcom,geni-spi";
1380				reg = <0x0 0x04a84000 0x0 0x4000>;
1381				clock-names = "se";
1382				clocks = <&gcc GCC_QUPV3_WRAP0_S1_CLK>;
1383				pinctrl-names = "default";
1384				pinctrl-0 = <&qup_spi1_default>;
1385				interrupts = <GIC_SPI 328 IRQ_TYPE_LEVEL_HIGH>;
1386				dmas = <&gpi_dma0 0 1 QCOM_GPI_SPI>,
1387				       <&gpi_dma0 1 1 QCOM_GPI_SPI>;
1388				dma-names = "tx", "rx";
1389				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1390						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1391						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1392						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1393						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1394						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1395				interconnect-names = "qup-core",
1396						     "qup-config",
1397						     "qup-memory";
1398				#address-cells = <1>;
1399				#size-cells = <0>;
1400				status = "disabled";
1401			};
1402
1403			i2c2: i2c@4a88000 {
1404				compatible = "qcom,geni-i2c";
1405				reg = <0x0 0x04a88000 0x0 0x4000>;
1406				clock-names = "se";
1407				clocks = <&gcc GCC_QUPV3_WRAP0_S2_CLK>;
1408				pinctrl-names = "default";
1409				pinctrl-0 = <&qup_i2c2_default>;
1410				interrupts = <GIC_SPI 329 IRQ_TYPE_LEVEL_HIGH>;
1411				dmas = <&gpi_dma0 0 2 QCOM_GPI_I2C>,
1412				       <&gpi_dma0 1 2 QCOM_GPI_I2C>;
1413				dma-names = "tx", "rx";
1414				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1415						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1416						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1417						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1418						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1419						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1420				interconnect-names = "qup-core",
1421						     "qup-config",
1422						     "qup-memory";
1423				#address-cells = <1>;
1424				#size-cells = <0>;
1425				status = "disabled";
1426			};
1427
1428			spi2: spi@4a88000 {
1429				compatible = "qcom,geni-spi";
1430				reg = <0x0 0x04a88000 0x0 0x4000>;
1431				clock-names = "se";
1432				clocks = <&gcc GCC_QUPV3_WRAP0_S2_CLK>;
1433				pinctrl-names = "default";
1434				pinctrl-0 = <&qup_spi2_default>;
1435				interrupts = <GIC_SPI 329 IRQ_TYPE_LEVEL_HIGH>;
1436				dmas = <&gpi_dma0 0 2 QCOM_GPI_SPI>,
1437				       <&gpi_dma0 1 2 QCOM_GPI_SPI>;
1438				dma-names = "tx", "rx";
1439				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1440						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1441						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1442						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1443						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1444						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1445				interconnect-names = "qup-core",
1446						     "qup-config",
1447						     "qup-memory";
1448				#address-cells = <1>;
1449				#size-cells = <0>;
1450				status = "disabled";
1451			};
1452
1453			i2c3: i2c@4a8c000 {
1454				compatible = "qcom,geni-i2c";
1455				reg = <0x0 0x04a8c000 0x0 0x4000>;
1456				clock-names = "se";
1457				clocks = <&gcc GCC_QUPV3_WRAP0_S3_CLK>;
1458				pinctrl-names = "default";
1459				pinctrl-0 = <&qup_i2c3_default>;
1460				interrupts = <GIC_SPI 330 IRQ_TYPE_LEVEL_HIGH>;
1461				dmas = <&gpi_dma0 0 3 QCOM_GPI_I2C>,
1462				       <&gpi_dma0 1 3 QCOM_GPI_I2C>;
1463				dma-names = "tx", "rx";
1464				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1465						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1466						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1467						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1468						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1469						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1470				interconnect-names = "qup-core",
1471						     "qup-config",
1472						     "qup-memory";
1473				#address-cells = <1>;
1474				#size-cells = <0>;
1475				status = "disabled";
1476			};
1477
1478			spi3: spi@4a8c000 {
1479				compatible = "qcom,geni-spi";
1480				reg = <0x0 0x04a8c000 0x0 0x4000>;
1481				clock-names = "se";
1482				clocks = <&gcc GCC_QUPV3_WRAP0_S3_CLK>;
1483				pinctrl-names = "default";
1484				pinctrl-0 = <&qup_spi3_default>;
1485				interrupts = <GIC_SPI 330 IRQ_TYPE_LEVEL_HIGH>;
1486				dmas = <&gpi_dma0 0 3 QCOM_GPI_SPI>,
1487				       <&gpi_dma0 1 3 QCOM_GPI_SPI>;
1488				dma-names = "tx", "rx";
1489				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1490						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1491						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1492						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1493						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1494						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1495				interconnect-names = "qup-core",
1496						     "qup-config",
1497						     "qup-memory";
1498				#address-cells = <1>;
1499				#size-cells = <0>;
1500				status = "disabled";
1501			};
1502
1503			uart3: serial@4a8c000 {
1504				compatible = "qcom,geni-uart";
1505				reg = <0x0 0x04a8c000 0x0 0x4000>;
1506				interrupts-extended = <&intc GIC_SPI 330 IRQ_TYPE_LEVEL_HIGH>;
1507				clocks = <&gcc GCC_QUPV3_WRAP0_S3_CLK>;
1508				clock-names = "se";
1509				power-domains = <&rpmpd SM6115_VDDCX>;
1510				operating-points-v2 = <&qup_opp_table>;
1511				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1512						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1513						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1514						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>;
1515				interconnect-names = "qup-core",
1516						     "qup-config";
1517				status = "disabled";
1518			};
1519
1520			i2c4: i2c@4a90000 {
1521				compatible = "qcom,geni-i2c";
1522				reg = <0x0 0x04a90000 0x0 0x4000>;
1523				clock-names = "se";
1524				clocks = <&gcc GCC_QUPV3_WRAP0_S4_CLK>;
1525				pinctrl-names = "default";
1526				pinctrl-0 = <&qup_i2c4_default>;
1527				interrupts = <GIC_SPI 331 IRQ_TYPE_LEVEL_HIGH>;
1528				dmas = <&gpi_dma0 0 4 QCOM_GPI_I2C>,
1529				       <&gpi_dma0 1 4 QCOM_GPI_I2C>;
1530				dma-names = "tx", "rx";
1531				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1532						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1533						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1534						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1535						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1536						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1537				interconnect-names = "qup-core",
1538						     "qup-config",
1539						     "qup-memory";
1540				#address-cells = <1>;
1541				#size-cells = <0>;
1542				status = "disabled";
1543			};
1544
1545			spi4: spi@4a90000 {
1546				compatible = "qcom,geni-spi";
1547				reg = <0x0 0x04a90000 0x0 0x4000>;
1548				clock-names = "se";
1549				clocks = <&gcc GCC_QUPV3_WRAP0_S4_CLK>;
1550				pinctrl-names = "default";
1551				pinctrl-0 = <&qup_spi4_default>;
1552				interrupts = <GIC_SPI 331 IRQ_TYPE_LEVEL_HIGH>;
1553				dmas = <&gpi_dma0 0 4 QCOM_GPI_SPI>,
1554				       <&gpi_dma0 1 4 QCOM_GPI_SPI>;
1555				dma-names = "tx", "rx";
1556				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1557						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1558						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1559						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1560						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1561						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1562				interconnect-names = "qup-core",
1563						     "qup-config",
1564						     "qup-memory";
1565				#address-cells = <1>;
1566				#size-cells = <0>;
1567				status = "disabled";
1568			};
1569
1570			uart4: serial@4a90000 {
1571				compatible = "qcom,geni-debug-uart";
1572				reg = <0x0 0x04a90000 0x0 0x4000>;
1573				clock-names = "se";
1574				clocks = <&gcc GCC_QUPV3_WRAP0_S4_CLK>;
1575				pinctrl-names = "default";
1576				pinctrl-0 = <&qup_uart4_default>;
1577				interrupts = <GIC_SPI 331 IRQ_TYPE_LEVEL_HIGH>;
1578				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1579						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1580						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1581						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>;
1582				interconnect-names = "qup-core",
1583						     "qup-config";
1584				status = "disabled";
1585			};
1586
1587			i2c5: i2c@4a94000 {
1588				compatible = "qcom,geni-i2c";
1589				reg = <0x0 0x04a94000 0x0 0x4000>;
1590				clock-names = "se";
1591				clocks = <&gcc GCC_QUPV3_WRAP0_S5_CLK>;
1592				pinctrl-names = "default";
1593				pinctrl-0 = <&qup_i2c5_default>;
1594				interrupts = <GIC_SPI 332 IRQ_TYPE_LEVEL_HIGH>;
1595				dmas = <&gpi_dma0 0 5 QCOM_GPI_I2C>,
1596				       <&gpi_dma0 1 5 QCOM_GPI_I2C>;
1597				dma-names = "tx", "rx";
1598				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1599						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1600						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1601						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1602						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1603						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1604				interconnect-names = "qup-core",
1605						     "qup-config",
1606						     "qup-memory";
1607				#address-cells = <1>;
1608				#size-cells = <0>;
1609				status = "disabled";
1610			};
1611
1612			spi5: spi@4a94000 {
1613				compatible = "qcom,geni-spi";
1614				reg = <0x0 0x04a94000 0x0 0x4000>;
1615				clock-names = "se";
1616				clocks = <&gcc GCC_QUPV3_WRAP0_S5_CLK>;
1617				pinctrl-names = "default";
1618				pinctrl-0 = <&qup_spi5_default>;
1619				interrupts = <GIC_SPI 332 IRQ_TYPE_LEVEL_HIGH>;
1620				dmas = <&gpi_dma0 0 5 QCOM_GPI_SPI>,
1621				       <&gpi_dma0 1 5 QCOM_GPI_SPI>;
1622				dma-names = "tx", "rx";
1623				interconnects = <&clk_virt MASTER_QUP_CORE_0 RPM_ALWAYS_TAG
1624						 &clk_virt SLAVE_QUP_CORE_0 RPM_ALWAYS_TAG>,
1625						<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1626						 &config_noc SLAVE_QUP_0 RPM_ALWAYS_TAG>,
1627						<&system_noc MASTER_QUP_0 RPM_ALWAYS_TAG
1628						 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>;
1629				interconnect-names = "qup-core",
1630						     "qup-config",
1631						     "qup-memory";
1632				#address-cells = <1>;
1633				#size-cells = <0>;
1634				status = "disabled";
1635			};
1636		};
1637
1638		usb: usb@4ef8800 {
1639			compatible = "qcom,sm6115-dwc3", "qcom,dwc3";
1640			reg = <0x0 0x04ef8800 0x0 0x400>;
1641			#address-cells = <2>;
1642			#size-cells = <2>;
1643			ranges;
1644
1645			clocks = <&gcc GCC_CFG_NOC_USB3_PRIM_AXI_CLK>,
1646				 <&gcc GCC_USB30_PRIM_MASTER_CLK>,
1647				 <&gcc GCC_SYS_NOC_USB3_PRIM_AXI_CLK>,
1648				 <&gcc GCC_USB30_PRIM_SLEEP_CLK>,
1649				 <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>,
1650				 <&gcc GCC_USB3_PRIM_CLKREF_CLK>;
1651			clock-names = "cfg_noc", "core", "iface", "sleep", "mock_utmi", "xo";
1652
1653			assigned-clocks = <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>,
1654					  <&gcc GCC_USB30_PRIM_MASTER_CLK>;
1655			assigned-clock-rates = <19200000>, <66666667>;
1656
1657			interrupts = <GIC_SPI 302 IRQ_TYPE_LEVEL_HIGH>,
1658				     <GIC_SPI 260 IRQ_TYPE_LEVEL_HIGH>,
1659				     <GIC_SPI 254 IRQ_TYPE_LEVEL_HIGH>,
1660				     <GIC_SPI 422 IRQ_TYPE_LEVEL_HIGH>;
1661			interrupt-names = "pwr_event",
1662					  "qusb2_phy",
1663					  "hs_phy_irq",
1664					  "ss_phy_irq";
1665
1666			resets = <&gcc GCC_USB30_PRIM_BCR>;
1667			power-domains = <&gcc GCC_USB30_PRIM_GDSC>;
1668			 /* TODO: USB<->IPA path */
1669			interconnects = <&system_noc MASTER_USB3 RPM_ALWAYS_TAG
1670					 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>,
1671					<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1672					 &config_noc SLAVE_USB3 RPM_ALWAYS_TAG>;
1673			interconnect-names = "usb-ddr",
1674					     "apps-usb";
1675
1676			status = "disabled";
1677
1678			usb_dwc3: usb@4e00000 {
1679				compatible = "snps,dwc3";
1680				reg = <0x0 0x04e00000 0x0 0xcd00>;
1681				interrupts = <GIC_SPI 255 IRQ_TYPE_LEVEL_HIGH>;
1682				phys = <&usb_hsphy>, <&usb_qmpphy>;
1683				phy-names = "usb2-phy", "usb3-phy";
1684				iommus = <&apps_smmu 0x120 0x0>;
1685				snps,dis_u2_susphy_quirk;
1686				snps,dis_enblslpm_quirk;
1687				snps,has-lpm-erratum;
1688				snps,hird-threshold = /bits/ 8 <0x10>;
1689				snps,usb3_lpm_capable;
1690				snps,parkmode-disable-ss-quirk;
1691
1692				usb-role-switch;
1693
1694				ports {
1695					#address-cells = <1>;
1696					#size-cells = <0>;
1697
1698					port@0 {
1699						reg = <0>;
1700
1701						usb_dwc3_hs: endpoint {
1702						};
1703					};
1704
1705					port@1 {
1706						reg = <1>;
1707
1708						usb_dwc3_ss: endpoint {
1709							remote-endpoint = <&usb_qmpphy_usb_ss_in>;
1710						};
1711					};
1712				};
1713			};
1714		};
1715
1716		gpu: gpu@5900000 {
1717			compatible = "qcom,adreno-610.0", "qcom,adreno";
1718			reg = <0x0 0x05900000 0x0 0x40000>;
1719			reg-names = "kgsl_3d0_reg_memory";
1720
1721			/* There's no (real) GMU, so we have to handle quite a bunch of clocks! */
1722			clocks = <&gpucc GPU_CC_GX_GFX3D_CLK>,
1723				 <&gpucc GPU_CC_AHB_CLK>,
1724				 <&gcc GCC_BIMC_GPU_AXI_CLK>,
1725				 <&gcc GCC_GPU_MEMNOC_GFX_CLK>,
1726				 <&gpucc GPU_CC_CX_GMU_CLK>,
1727				 <&gpucc GPU_CC_CXO_CLK>;
1728			clock-names = "core",
1729				      "iface",
1730				      "mem_iface",
1731				      "alt_mem_iface",
1732				      "gmu",
1733				      "xo";
1734
1735			interrupts = <GIC_SPI 177 IRQ_TYPE_LEVEL_HIGH>;
1736
1737			iommus = <&adreno_smmu 0 1>;
1738			operating-points-v2 = <&gpu_opp_table>;
1739			power-domains = <&rpmpd SM6115_VDDCX>;
1740			qcom,gmu = <&gmu_wrapper>;
1741
1742			nvmem-cells = <&gpu_speed_bin>;
1743			nvmem-cell-names = "speed_bin";
1744			#cooling-cells = <2>;
1745
1746			status = "disabled";
1747
1748			zap-shader {
1749				memory-region = <&pil_gpu_mem>;
1750			};
1751
1752			gpu_opp_table: opp-table {
1753				compatible = "operating-points-v2";
1754
1755				opp-320000000 {
1756					opp-hz = /bits/ 64 <320000000>;
1757					required-opps = <&rpmpd_opp_low_svs>;
1758					opp-supported-hw = <0x1f>;
1759				};
1760
1761				opp-465000000 {
1762					opp-hz = /bits/ 64 <465000000>;
1763					required-opps = <&rpmpd_opp_svs>;
1764					opp-supported-hw = <0x1f>;
1765				};
1766
1767				opp-600000000 {
1768					opp-hz = /bits/ 64 <600000000>;
1769					required-opps = <&rpmpd_opp_svs_plus>;
1770					opp-supported-hw = <0x1f>;
1771				};
1772
1773				opp-745000000 {
1774					opp-hz = /bits/ 64 <745000000>;
1775					required-opps = <&rpmpd_opp_nom>;
1776					opp-supported-hw = <0xf>;
1777				};
1778
1779				opp-820000000 {
1780					opp-hz = /bits/ 64 <820000000>;
1781					required-opps = <&rpmpd_opp_nom_plus>;
1782					opp-supported-hw = <0x7>;
1783				};
1784
1785				opp-900000000 {
1786					opp-hz = /bits/ 64 <900000000>;
1787					required-opps = <&rpmpd_opp_turbo>;
1788					opp-supported-hw = <0x7>;
1789				};
1790
1791				/* Speed bin 2 can reach 950 Mhz instead of 980 like the rest. */
1792				opp-950000000 {
1793					opp-hz = /bits/ 64 <950000000>;
1794					required-opps = <&rpmpd_opp_turbo_plus>;
1795					opp-supported-hw = <0x4>;
1796				};
1797
1798				opp-980000000 {
1799					opp-hz = /bits/ 64 <980000000>;
1800					required-opps = <&rpmpd_opp_turbo_plus>;
1801					opp-supported-hw = <0x3>;
1802				};
1803			};
1804		};
1805
1806		gmu_wrapper: gmu@596a000 {
1807			compatible = "qcom,adreno-gmu-wrapper";
1808			reg = <0x0 0x0596a000 0x0 0x30000>;
1809			reg-names = "gmu";
1810			power-domains = <&gpucc GPU_CX_GDSC>,
1811					<&gpucc GPU_GX_GDSC>;
1812			power-domain-names = "cx", "gx";
1813		};
1814
1815		gpucc: clock-controller@5990000 {
1816			compatible = "qcom,sm6115-gpucc";
1817			reg = <0x0 0x05990000 0x0 0x9000>;
1818			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>,
1819				 <&gcc GCC_GPU_GPLL0_CLK_SRC>,
1820				 <&gcc GCC_GPU_GPLL0_DIV_CLK_SRC>;
1821			#clock-cells = <1>;
1822			#reset-cells = <1>;
1823			#power-domain-cells = <1>;
1824		};
1825
1826		adreno_smmu: iommu@59a0000 {
1827			compatible = "qcom,sm6115-smmu-500", "qcom,adreno-smmu",
1828				     "qcom,smmu-500", "arm,mmu-500";
1829			reg = <0x0 0x059a0000 0x0 0x10000>;
1830			interrupts = <GIC_SPI 163 IRQ_TYPE_LEVEL_HIGH>,
1831				     <GIC_SPI 167 IRQ_TYPE_LEVEL_HIGH>,
1832				     <GIC_SPI 168 IRQ_TYPE_LEVEL_HIGH>,
1833				     <GIC_SPI 169 IRQ_TYPE_LEVEL_HIGH>,
1834				     <GIC_SPI 170 IRQ_TYPE_LEVEL_HIGH>,
1835				     <GIC_SPI 171 IRQ_TYPE_LEVEL_HIGH>,
1836				     <GIC_SPI 172 IRQ_TYPE_LEVEL_HIGH>,
1837				     <GIC_SPI 173 IRQ_TYPE_LEVEL_HIGH>,
1838				     <GIC_SPI 174 IRQ_TYPE_LEVEL_HIGH>;
1839
1840			clocks = <&gcc GCC_GPU_MEMNOC_GFX_CLK>,
1841				 <&gpucc GPU_CC_HLOS1_VOTE_GPU_SMMU_CLK>,
1842				 <&gcc GCC_GPU_SNOC_DVM_GFX_CLK>;
1843			clock-names = "mem",
1844				      "hlos",
1845				      "iface";
1846			power-domains = <&gpucc GPU_CX_GDSC>;
1847
1848			#global-interrupts = <1>;
1849			#iommu-cells = <2>;
1850		};
1851
1852		mdss: display-subsystem@5e00000 {
1853			compatible = "qcom,sm6115-mdss";
1854			reg = <0x0 0x05e00000 0x0 0x1000>;
1855			reg-names = "mdss";
1856
1857			power-domains = <&dispcc MDSS_GDSC>;
1858
1859			clocks = <&gcc GCC_DISP_AHB_CLK>,
1860				 <&gcc GCC_DISP_HF_AXI_CLK>,
1861				 <&dispcc DISP_CC_MDSS_MDP_CLK>;
1862
1863			interrupts = <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH>;
1864			interrupt-controller;
1865			#interrupt-cells = <1>;
1866
1867			iommus = <&apps_smmu 0x420 0x2>,
1868				 <&apps_smmu 0x421 0x0>;
1869
1870			interconnects = <&mmrt_virt MASTER_MDP_PORT0 RPM_ALWAYS_TAG
1871					 &bimc SLAVE_EBI_CH0 RPM_ALWAYS_TAG>,
1872					<&bimc MASTER_AMPSS_M0 RPM_ALWAYS_TAG
1873					 &config_noc SLAVE_DISPLAY_CFG RPM_ALWAYS_TAG>;
1874			interconnect-names = "mdp0-mem",
1875					     "cpu-cfg";
1876
1877			#address-cells = <2>;
1878			#size-cells = <2>;
1879			ranges;
1880
1881			status = "disabled";
1882
1883			mdp: display-controller@5e01000 {
1884				compatible = "qcom,sm6115-dpu";
1885				reg = <0x0 0x05e01000 0x0 0x8f000>,
1886				      <0x0 0x05eb0000 0x0 0x3000>;
1887				reg-names = "mdp", "vbif";
1888
1889				clocks = <&gcc GCC_DISP_HF_AXI_CLK>,
1890					 <&dispcc DISP_CC_MDSS_AHB_CLK>,
1891					 <&dispcc DISP_CC_MDSS_MDP_CLK>,
1892					 <&dispcc DISP_CC_MDSS_MDP_LUT_CLK>,
1893					 <&dispcc DISP_CC_MDSS_ROT_CLK>,
1894					 <&dispcc DISP_CC_MDSS_VSYNC_CLK>;
1895				clock-names = "bus",
1896					      "iface",
1897					      "core",
1898					      "lut",
1899					      "rot",
1900					      "vsync";
1901
1902				operating-points-v2 = <&mdp_opp_table>;
1903				power-domains = <&rpmpd SM6115_VDDCX>;
1904
1905				interrupt-parent = <&mdss>;
1906				interrupts = <0>;
1907
1908				ports {
1909					#address-cells = <1>;
1910					#size-cells = <0>;
1911
1912					port@0 {
1913						reg = <0>;
1914						dpu_intf1_out: endpoint {
1915							remote-endpoint = <&mdss_dsi0_in>;
1916						};
1917					};
1918				};
1919
1920				mdp_opp_table: opp-table {
1921					compatible = "operating-points-v2";
1922
1923					opp-19200000 {
1924						opp-hz = /bits/ 64 <19200000>;
1925						required-opps = <&rpmpd_opp_min_svs>;
1926					};
1927
1928					opp-192000000 {
1929						opp-hz = /bits/ 64 <192000000>;
1930						required-opps = <&rpmpd_opp_low_svs>;
1931					};
1932
1933					opp-256000000 {
1934						opp-hz = /bits/ 64 <256000000>;
1935						required-opps = <&rpmpd_opp_svs>;
1936					};
1937
1938					opp-307200000 {
1939						opp-hz = /bits/ 64 <307200000>;
1940						required-opps = <&rpmpd_opp_svs_plus>;
1941					};
1942
1943					opp-384000000 {
1944						opp-hz = /bits/ 64 <384000000>;
1945						required-opps = <&rpmpd_opp_nom>;
1946					};
1947				};
1948			};
1949
1950			mdss_dsi0: dsi@5e94000 {
1951				compatible = "qcom,sm6115-dsi-ctrl", "qcom,mdss-dsi-ctrl";
1952				reg = <0x0 0x05e94000 0x0 0x400>;
1953				reg-names = "dsi_ctrl";
1954
1955				interrupt-parent = <&mdss>;
1956				interrupts = <4>;
1957
1958				clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK>,
1959					 <&dispcc DISP_CC_MDSS_BYTE0_INTF_CLK>,
1960					 <&dispcc DISP_CC_MDSS_PCLK0_CLK>,
1961					 <&dispcc DISP_CC_MDSS_ESC0_CLK>,
1962					 <&dispcc DISP_CC_MDSS_AHB_CLK>,
1963					 <&gcc GCC_DISP_HF_AXI_CLK>;
1964				clock-names = "byte",
1965					      "byte_intf",
1966					      "pixel",
1967					      "core",
1968					      "iface",
1969					      "bus";
1970
1971				assigned-clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK_SRC>,
1972						  <&dispcc DISP_CC_MDSS_PCLK0_CLK_SRC>;
1973				assigned-clock-parents = <&mdss_dsi0_phy DSI_BYTE_PLL_CLK>,
1974							 <&mdss_dsi0_phy DSI_PIXEL_PLL_CLK>;
1975
1976				operating-points-v2 = <&dsi_opp_table>;
1977				power-domains = <&rpmpd SM6115_VDDCX>;
1978				phys = <&mdss_dsi0_phy>;
1979
1980				#address-cells = <1>;
1981				#size-cells = <0>;
1982
1983				status = "disabled";
1984
1985				ports {
1986					#address-cells = <1>;
1987					#size-cells = <0>;
1988
1989					port@0 {
1990						reg = <0>;
1991						mdss_dsi0_in: endpoint {
1992							remote-endpoint = <&dpu_intf1_out>;
1993						};
1994					};
1995
1996					port@1 {
1997						reg = <1>;
1998						mdss_dsi0_out: endpoint {
1999						};
2000					};
2001				};
2002
2003				dsi_opp_table: opp-table {
2004					compatible = "operating-points-v2";
2005
2006					opp-19200000 {
2007						opp-hz = /bits/ 64 <19200000>;
2008						required-opps = <&rpmpd_opp_min_svs>;
2009					};
2010
2011					opp-164000000 {
2012						opp-hz = /bits/ 64 <164000000>;
2013						required-opps = <&rpmpd_opp_low_svs>;
2014					};
2015
2016					opp-187500000 {
2017						opp-hz = /bits/ 64 <187500000>;
2018						required-opps = <&rpmpd_opp_svs>;
2019					};
2020				};
2021			};
2022
2023			mdss_dsi0_phy: phy@5e94400 {
2024				compatible = "qcom,dsi-phy-14nm-2290";
2025				reg = <0x0 0x05e94400 0x0 0x100>,
2026				      <0x0 0x05e94500 0x0 0x300>,
2027				      <0x0 0x05e94800 0x0 0x188>;
2028				reg-names = "dsi_phy",
2029					    "dsi_phy_lane",
2030					    "dsi_pll";
2031
2032				#clock-cells = <1>;
2033				#phy-cells = <0>;
2034
2035				clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>,
2036					 <&rpmcc RPM_SMD_XO_CLK_SRC>;
2037				clock-names = "iface", "ref";
2038
2039				status = "disabled";
2040			};
2041		};
2042
2043		dispcc: clock-controller@5f00000 {
2044			compatible = "qcom,sm6115-dispcc";
2045			reg = <0x0 0x05f00000 0 0x20000>;
2046			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>,
2047				 <&sleep_clk>,
2048				 <&mdss_dsi0_phy DSI_BYTE_PLL_CLK>,
2049				 <&mdss_dsi0_phy DSI_PIXEL_PLL_CLK>,
2050				 <&gcc GCC_DISP_GPLL0_DIV_CLK_SRC>;
2051			#clock-cells = <1>;
2052			#reset-cells = <1>;
2053			#power-domain-cells = <1>;
2054		};
2055
2056		remoteproc_mpss: remoteproc@6080000 {
2057			compatible = "qcom,sm6115-mpss-pas";
2058			reg = <0x0 0x06080000 0x0 0x10000>;
2059
2060			interrupts-extended = <&intc GIC_SPI 307 IRQ_TYPE_EDGE_RISING>,
2061					      <&modem_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
2062					      <&modem_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
2063					      <&modem_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
2064					      <&modem_smp2p_in 3 IRQ_TYPE_EDGE_RISING>,
2065					      <&modem_smp2p_in 7 IRQ_TYPE_EDGE_RISING>;
2066			interrupt-names = "wdog", "fatal", "ready", "handover",
2067					  "stop-ack", "shutdown-ack";
2068
2069			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>;
2070			clock-names = "xo";
2071
2072			power-domains = <&rpmpd SM6115_VDDCX>;
2073
2074			memory-region = <&pil_modem_mem>;
2075
2076			qcom,smem-states = <&modem_smp2p_out 0>;
2077			qcom,smem-state-names = "stop";
2078
2079			status = "disabled";
2080
2081			glink-edge {
2082				interrupts = <GIC_SPI 68 IRQ_TYPE_EDGE_RISING>;
2083				label = "mpss";
2084				qcom,remote-pid = <1>;
2085				mboxes = <&apcs_glb 12>;
2086			};
2087		};
2088
2089		stm@8002000 {
2090			compatible = "arm,coresight-stm", "arm,primecell";
2091			reg = <0x0 0x08002000 0x0 0x1000>,
2092			      <0x0 0x0e280000 0x0 0x180000>;
2093			reg-names = "stm-base", "stm-stimulus-base";
2094
2095			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2096			clock-names = "apb_pclk";
2097
2098			status = "disabled";
2099
2100			out-ports {
2101				port {
2102					stm_out: endpoint {
2103						remote-endpoint = <&funnel_in0_in>;
2104					};
2105				};
2106			};
2107		};
2108
2109		cti0: cti@8010000 {
2110			compatible = "arm,coresight-cti", "arm,primecell";
2111			reg = <0x0 0x08010000 0x0 0x1000>;
2112
2113			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2114			clock-names = "apb_pclk";
2115
2116			status = "disabled";
2117		};
2118
2119		cti1: cti@8011000 {
2120			compatible = "arm,coresight-cti", "arm,primecell";
2121			reg = <0x0 0x08011000 0x0 0x1000>;
2122
2123			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2124			clock-names = "apb_pclk";
2125
2126			status = "disabled";
2127		};
2128
2129		cti2: cti@8012000 {
2130			compatible = "arm,coresight-cti", "arm,primecell";
2131			reg = <0x0 0x08012000 0x0 0x1000>;
2132
2133			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2134			clock-names = "apb_pclk";
2135
2136			status = "disabled";
2137		};
2138
2139		cti3: cti@8013000 {
2140			compatible = "arm,coresight-cti", "arm,primecell";
2141			reg = <0x0 0x08013000 0x0 0x1000>;
2142
2143			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2144			clock-names = "apb_pclk";
2145
2146			status = "disabled";
2147		};
2148
2149		cti4: cti@8014000 {
2150			compatible = "arm,coresight-cti", "arm,primecell";
2151			reg = <0x0 0x08014000 0x0 0x1000>;
2152
2153			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2154			clock-names = "apb_pclk";
2155
2156			status = "disabled";
2157		};
2158
2159		cti5: cti@8015000 {
2160			compatible = "arm,coresight-cti", "arm,primecell";
2161			reg = <0x0 0x08015000 0x0 0x1000>;
2162
2163			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2164			clock-names = "apb_pclk";
2165
2166			status = "disabled";
2167		};
2168
2169		cti6: cti@8016000 {
2170			compatible = "arm,coresight-cti", "arm,primecell";
2171			reg = <0x0 0x08016000 0x0 0x1000>;
2172
2173			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2174			clock-names = "apb_pclk";
2175
2176			status = "disabled";
2177		};
2178
2179		cti7: cti@8017000 {
2180			compatible = "arm,coresight-cti", "arm,primecell";
2181			reg = <0x0 0x08017000 0x0 0x1000>;
2182
2183			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2184			clock-names = "apb_pclk";
2185
2186			status = "disabled";
2187		};
2188
2189		cti8: cti@8018000 {
2190			compatible = "arm,coresight-cti", "arm,primecell";
2191			reg = <0x0 0x08018000 0x0 0x1000>;
2192
2193			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2194			clock-names = "apb_pclk";
2195
2196			status = "disabled";
2197		};
2198
2199		cti9: cti@8019000 {
2200			compatible = "arm,coresight-cti", "arm,primecell";
2201			reg = <0x0 0x08019000 0x0 0x1000>;
2202
2203			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2204			clock-names = "apb_pclk";
2205
2206			status = "disabled";
2207		};
2208
2209		cti10: cti@801a000 {
2210			compatible = "arm,coresight-cti", "arm,primecell";
2211			reg = <0x0 0x0801a000 0x0 0x1000>;
2212
2213			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2214			clock-names = "apb_pclk";
2215
2216			status = "disabled";
2217		};
2218
2219		cti11: cti@801b000 {
2220			compatible = "arm,coresight-cti", "arm,primecell";
2221			reg = <0x0 0x0801b000 0x0 0x1000>;
2222
2223			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2224			clock-names = "apb_pclk";
2225
2226			status = "disabled";
2227		};
2228
2229		cti12: cti@801c000 {
2230			compatible = "arm,coresight-cti", "arm,primecell";
2231			reg = <0x0 0x0801c000 0x0 0x1000>;
2232
2233			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2234			clock-names = "apb_pclk";
2235
2236			status = "disabled";
2237		};
2238
2239		cti13: cti@801d000 {
2240			compatible = "arm,coresight-cti", "arm,primecell";
2241			reg = <0x0 0x0801d000 0x0 0x1000>;
2242
2243			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2244			clock-names = "apb_pclk";
2245
2246			status = "disabled";
2247		};
2248
2249		cti14: cti@801e000 {
2250			compatible = "arm,coresight-cti", "arm,primecell";
2251			reg = <0x0 0x0801e000 0x0 0x1000>;
2252
2253			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2254			clock-names = "apb_pclk";
2255
2256			status = "disabled";
2257		};
2258
2259		cti15: cti@801f000 {
2260			compatible = "arm,coresight-cti", "arm,primecell";
2261			reg = <0x0 0x0801f000 0x0 0x1000>;
2262
2263			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2264			clock-names = "apb_pclk";
2265
2266			status = "disabled";
2267		};
2268
2269		replicator@8046000 {
2270			compatible = "arm,coresight-dynamic-replicator", "arm,primecell";
2271			reg = <0x0 0x08046000 0x0 0x1000>;
2272
2273			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2274			clock-names = "apb_pclk";
2275
2276			status = "disabled";
2277
2278			out-ports {
2279				port {
2280					replicator_out: endpoint {
2281						remote-endpoint = <&etr_in>;
2282					};
2283				};
2284			};
2285
2286			in-ports {
2287				port {
2288					replicator_in: endpoint {
2289						remote-endpoint = <&etf_out>;
2290					};
2291				};
2292			};
2293		};
2294
2295		etf@8047000 {
2296			compatible = "arm,coresight-tmc", "arm,primecell";
2297			reg = <0x0 0x08047000 0x0 0x1000>;
2298
2299			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2300			clock-names = "apb_pclk";
2301
2302			status = "disabled";
2303
2304			in-ports {
2305				port {
2306					etf_in: endpoint {
2307						remote-endpoint = <&merge_funnel_out>;
2308					};
2309				};
2310			};
2311
2312			out-ports {
2313				port {
2314					etf_out: endpoint {
2315						remote-endpoint = <&replicator_in>;
2316					};
2317				};
2318			};
2319		};
2320
2321		etr@8048000 {
2322			compatible = "arm,coresight-tmc", "arm,primecell";
2323			reg = <0x0 0x08048000 0x0 0x1000>;
2324
2325			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2326			clock-names = "apb_pclk";
2327
2328			status = "disabled";
2329
2330			in-ports {
2331				port {
2332					etr_in: endpoint {
2333						remote-endpoint = <&replicator_out>;
2334					};
2335				};
2336			};
2337		};
2338
2339		funnel@8041000 {
2340			compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
2341			reg = <0x0 0x08041000 0x0 0x1000>;
2342
2343			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2344			clock-names = "apb_pclk";
2345
2346			status = "disabled";
2347
2348			out-ports {
2349				port {
2350					funnel_in0_out: endpoint {
2351						remote-endpoint = <&merge_funnel_in0>;
2352					};
2353				};
2354			};
2355
2356			in-ports {
2357				port {
2358					funnel_in0_in: endpoint {
2359						remote-endpoint = <&stm_out>;
2360					};
2361				};
2362			};
2363		};
2364
2365		funnel@8042000 {
2366			compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
2367			reg = <0x0 0x08042000 0x0 0x1000>;
2368
2369			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2370			clock-names = "apb_pclk";
2371
2372			status = "disabled";
2373
2374			out-ports {
2375				port {
2376					funnel_in1_out: endpoint {
2377						remote-endpoint = <&merge_funnel_in1>;
2378					};
2379				};
2380			};
2381
2382			in-ports {
2383				port {
2384					funnel_in1_in: endpoint {
2385						remote-endpoint = <&funnel_apss1_out>;
2386					};
2387				};
2388			};
2389		};
2390
2391		funnel@8045000 {
2392			compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
2393			reg = <0x0 0x08045000 0x0 0x1000>;
2394
2395			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2396			clock-names = "apb_pclk";
2397
2398			status = "disabled";
2399
2400			out-ports {
2401				port {
2402					merge_funnel_out: endpoint {
2403						remote-endpoint = <&etf_in>;
2404					};
2405				};
2406			};
2407
2408			in-ports {
2409				#address-cells = <1>;
2410				#size-cells = <0>;
2411
2412				port@0 {
2413					reg = <0>;
2414					merge_funnel_in0: endpoint {
2415						remote-endpoint = <&funnel_in0_out>;
2416					};
2417				};
2418
2419				port@1 {
2420					reg = <1>;
2421					merge_funnel_in1: endpoint {
2422						remote-endpoint = <&funnel_in1_out>;
2423					};
2424				};
2425			};
2426		};
2427
2428		etm@9040000 {
2429			compatible = "arm,coresight-etm4x", "arm,primecell";
2430			reg = <0x0 0x09040000 0x0 0x1000>;
2431
2432			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2433			clock-names = "apb_pclk";
2434			arm,coresight-loses-context-with-cpu;
2435
2436			cpu = <&cpu0>;
2437
2438			status = "disabled";
2439
2440			out-ports {
2441				port {
2442					etm0_out: endpoint {
2443						remote-endpoint = <&funnel_apss0_in0>;
2444					};
2445				};
2446			};
2447		};
2448
2449		etm@9140000 {
2450			compatible = "arm,coresight-etm4x", "arm,primecell";
2451			reg = <0x0 0x09140000 0x0 0x1000>;
2452
2453			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2454			clock-names = "apb_pclk";
2455			arm,coresight-loses-context-with-cpu;
2456
2457			cpu = <&cpu1>;
2458
2459			status = "disabled";
2460
2461			out-ports {
2462				port {
2463					etm1_out: endpoint {
2464						remote-endpoint = <&funnel_apss0_in1>;
2465					};
2466				};
2467			};
2468		};
2469
2470		etm@9240000 {
2471			compatible = "arm,coresight-etm4x", "arm,primecell";
2472			reg = <0x0 0x09240000 0x0 0x1000>;
2473
2474			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2475			clock-names = "apb_pclk";
2476			arm,coresight-loses-context-with-cpu;
2477
2478			cpu = <&cpu2>;
2479
2480			status = "disabled";
2481
2482			out-ports {
2483				port {
2484					etm2_out: endpoint {
2485						remote-endpoint = <&funnel_apss0_in2>;
2486					};
2487				};
2488			};
2489		};
2490
2491		etm@9340000 {
2492			compatible = "arm,coresight-etm4x", "arm,primecell";
2493			reg = <0x0 0x09340000 0x0 0x1000>;
2494
2495			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2496			clock-names = "apb_pclk";
2497			arm,coresight-loses-context-with-cpu;
2498
2499			cpu = <&cpu3>;
2500
2501			status = "disabled";
2502
2503			out-ports {
2504				port {
2505					etm3_out: endpoint {
2506						remote-endpoint = <&funnel_apss0_in3>;
2507					};
2508				};
2509			};
2510		};
2511
2512		etm@9440000 {
2513			compatible = "arm,coresight-etm4x", "arm,primecell";
2514			reg = <0x0 0x09440000 0x0 0x1000>;
2515
2516			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2517			clock-names = "apb_pclk";
2518			arm,coresight-loses-context-with-cpu;
2519
2520			cpu = <&cpu4>;
2521
2522			status = "disabled";
2523
2524			out-ports {
2525				port {
2526					etm4_out: endpoint {
2527						remote-endpoint = <&funnel_apss0_in4>;
2528					};
2529				};
2530			};
2531		};
2532
2533		etm@9540000 {
2534			compatible = "arm,coresight-etm4x", "arm,primecell";
2535			reg = <0x0 0x09540000 0x0 0x1000>;
2536
2537			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2538			clock-names = "apb_pclk";
2539			arm,coresight-loses-context-with-cpu;
2540
2541			cpu = <&cpu5>;
2542
2543			status = "disabled";
2544
2545			out-ports {
2546				port {
2547					etm5_out: endpoint {
2548						remote-endpoint = <&funnel_apss0_in5>;
2549					};
2550				};
2551			};
2552		};
2553
2554		etm@9640000 {
2555			compatible = "arm,coresight-etm4x", "arm,primecell";
2556			reg = <0x0 0x09640000 0x0 0x1000>;
2557
2558			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2559			clock-names = "apb_pclk";
2560			arm,coresight-loses-context-with-cpu;
2561
2562			cpu = <&cpu6>;
2563
2564			status = "disabled";
2565
2566			out-ports {
2567				port {
2568					etm6_out: endpoint {
2569						remote-endpoint = <&funnel_apss0_in6>;
2570					};
2571				};
2572			};
2573		};
2574
2575		etm@9740000 {
2576			compatible = "arm,coresight-etm4x", "arm,primecell";
2577			reg = <0x0 0x09740000 0x0 0x1000>;
2578
2579			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2580			clock-names = "apb_pclk";
2581			arm,coresight-loses-context-with-cpu;
2582
2583			cpu = <&cpu7>;
2584
2585			status = "disabled";
2586
2587			out-ports {
2588				port {
2589					etm7_out: endpoint {
2590						remote-endpoint = <&funnel_apss0_in7>;
2591					};
2592				};
2593			};
2594		};
2595
2596		funnel@9800000 {
2597			compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
2598			reg = <0x0 0x09800000 0x0 0x1000>;
2599
2600			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2601			clock-names = "apb_pclk";
2602
2603			status = "disabled";
2604
2605			out-ports {
2606				port {
2607					funnel_apss0_out: endpoint {
2608						remote-endpoint = <&funnel_apss1_in>;
2609					};
2610				};
2611			};
2612
2613			in-ports {
2614				#address-cells = <1>;
2615				#size-cells = <0>;
2616
2617				port@0 {
2618					reg = <0>;
2619					funnel_apss0_in0: endpoint {
2620						remote-endpoint = <&etm0_out>;
2621					};
2622				};
2623
2624				port@1 {
2625					reg = <1>;
2626					funnel_apss0_in1: endpoint {
2627						remote-endpoint = <&etm1_out>;
2628					};
2629				};
2630
2631				port@2 {
2632					reg = <2>;
2633					funnel_apss0_in2: endpoint {
2634						remote-endpoint = <&etm2_out>;
2635					};
2636				};
2637
2638				port@3 {
2639					reg = <3>;
2640					funnel_apss0_in3: endpoint {
2641						remote-endpoint = <&etm3_out>;
2642					};
2643				};
2644
2645				port@4 {
2646					reg = <4>;
2647					funnel_apss0_in4: endpoint {
2648						remote-endpoint = <&etm4_out>;
2649					};
2650				};
2651
2652				port@5 {
2653					reg = <5>;
2654					funnel_apss0_in5: endpoint {
2655						remote-endpoint = <&etm5_out>;
2656					};
2657				};
2658
2659				port@6 {
2660					reg = <6>;
2661					funnel_apss0_in6: endpoint {
2662						remote-endpoint = <&etm6_out>;
2663					};
2664				};
2665
2666				port@7 {
2667					reg = <7>;
2668					funnel_apss0_in7: endpoint {
2669						remote-endpoint = <&etm7_out>;
2670					};
2671				};
2672			};
2673		};
2674
2675		funnel@9810000 {
2676			compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
2677			reg = <0x0 0x09810000 0x0 0x1000>;
2678
2679			clocks = <&rpmcc RPM_SMD_QDSS_CLK>;
2680			clock-names = "apb_pclk";
2681
2682			status = "disabled";
2683
2684			out-ports {
2685				port {
2686					funnel_apss1_out: endpoint {
2687						remote-endpoint = <&funnel_in1_in>;
2688					};
2689				};
2690			};
2691
2692			in-ports {
2693				port {
2694					funnel_apss1_in: endpoint {
2695						remote-endpoint = <&funnel_apss0_out>;
2696					};
2697				};
2698			};
2699		};
2700
2701		remoteproc_adsp: remoteproc@a400000 {
2702			compatible = "qcom,sm6115-adsp-pas";
2703			reg = <0x0 0x0a400000 0x0 0x4040>;
2704
2705			interrupts-extended = <&intc GIC_SPI 282 IRQ_TYPE_EDGE_RISING>,
2706					      <&adsp_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
2707					      <&adsp_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
2708					      <&adsp_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
2709					      <&adsp_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
2710			interrupt-names = "wdog", "fatal", "ready",
2711					  "handover", "stop-ack";
2712
2713			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>;
2714			clock-names = "xo";
2715
2716			power-domains = <&rpmpd SM6115_VDD_LPI_CX>,
2717					<&rpmpd SM6115_VDD_LPI_MX>;
2718
2719			memory-region = <&pil_adsp_mem>;
2720
2721			qcom,smem-states = <&adsp_smp2p_out 0>;
2722			qcom,smem-state-names = "stop";
2723
2724			status = "disabled";
2725
2726			glink-edge {
2727				interrupts = <GIC_SPI 277 IRQ_TYPE_EDGE_RISING>;
2728				label = "lpass";
2729				qcom,remote-pid = <2>;
2730				mboxes = <&apcs_glb 8>;
2731
2732				apr {
2733					compatible = "qcom,apr-v2";
2734					qcom,glink-channels = "apr_audio_svc";
2735					qcom,domain = <APR_DOMAIN_ADSP>;
2736					#address-cells = <1>;
2737					#size-cells = <0>;
2738
2739					service@3 {
2740						reg = <APR_SVC_ADSP_CORE>;
2741						compatible = "qcom,q6core";
2742						qcom,protection-domain = "avs/audio",
2743									 "msm/adsp/audio_pd";
2744					};
2745
2746					q6afe: service@4 {
2747						compatible = "qcom,q6afe";
2748						reg = <APR_SVC_AFE>;
2749						qcom,protection-domain = "avs/audio",
2750									 "msm/adsp/audio_pd";
2751						q6afedai: dais {
2752							compatible = "qcom,q6afe-dais";
2753							#address-cells = <1>;
2754							#size-cells = <0>;
2755							#sound-dai-cells = <1>;
2756						};
2757
2758						q6afecc: clock-controller {
2759							compatible = "qcom,q6afe-clocks";
2760							#clock-cells = <2>;
2761						};
2762					};
2763
2764					q6asm: service@7 {
2765						compatible = "qcom,q6asm";
2766						reg = <APR_SVC_ASM>;
2767						qcom,protection-domain = "avs/audio",
2768									 "msm/adsp/audio_pd";
2769						q6asmdai: dais {
2770							compatible = "qcom,q6asm-dais";
2771							#address-cells = <1>;
2772							#size-cells = <0>;
2773							#sound-dai-cells = <1>;
2774							iommus = <&apps_smmu 0x1c1 0x0>;
2775
2776							dai@0 {
2777								reg = <MSM_FRONTEND_DAI_MULTIMEDIA1>;
2778							};
2779
2780							dai@1 {
2781								reg = <MSM_FRONTEND_DAI_MULTIMEDIA2>;
2782							};
2783
2784							dai@2 {
2785								reg = <MSM_FRONTEND_DAI_MULTIMEDIA3>;
2786							};
2787						};
2788					};
2789
2790					q6adm: service@8 {
2791						compatible = "qcom,q6adm";
2792						reg = <APR_SVC_ADM>;
2793						qcom,protection-domain = "avs/audio",
2794									 "msm/adsp/audio_pd";
2795						q6routing: routing {
2796							compatible = "qcom,q6adm-routing";
2797							#sound-dai-cells = <0>;
2798						};
2799					};
2800				};
2801
2802				fastrpc {
2803					compatible = "qcom,fastrpc";
2804					qcom,glink-channels = "fastrpcglink-apps-dsp";
2805					label = "adsp";
2806					qcom,non-secure-domain;
2807					#address-cells = <1>;
2808					#size-cells = <0>;
2809
2810					compute-cb@3 {
2811						compatible = "qcom,fastrpc-compute-cb";
2812						reg = <3>;
2813						iommus = <&apps_smmu 0x01c3 0x0>;
2814					};
2815
2816					compute-cb@4 {
2817						compatible = "qcom,fastrpc-compute-cb";
2818						reg = <4>;
2819						iommus = <&apps_smmu 0x01c4 0x0>;
2820					};
2821
2822					compute-cb@5 {
2823						compatible = "qcom,fastrpc-compute-cb";
2824						reg = <5>;
2825						iommus = <&apps_smmu 0x01c5 0x0>;
2826					};
2827
2828					compute-cb@6 {
2829						compatible = "qcom,fastrpc-compute-cb";
2830						reg = <6>;
2831						iommus = <&apps_smmu 0x01c6 0x0>;
2832					};
2833
2834					compute-cb@7 {
2835						compatible = "qcom,fastrpc-compute-cb";
2836						reg = <7>;
2837						iommus = <&apps_smmu 0x01c7 0x0>;
2838					};
2839				};
2840			};
2841		};
2842
2843		remoteproc_cdsp: remoteproc@b300000 {
2844			compatible = "qcom,sm6115-cdsp-pas";
2845			reg = <0x0 0x0b300000 0x0 0x4040>;
2846
2847			interrupts-extended = <&intc GIC_SPI 265 IRQ_TYPE_EDGE_RISING>,
2848					      <&cdsp_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
2849					      <&cdsp_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
2850					      <&cdsp_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
2851					      <&cdsp_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
2852			interrupt-names = "wdog", "fatal", "ready",
2853					  "handover", "stop-ack";
2854
2855			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>;
2856			clock-names = "xo";
2857
2858			power-domains = <&rpmpd SM6115_VDDCX>;
2859
2860			memory-region = <&pil_cdsp_mem>;
2861
2862			qcom,smem-states = <&cdsp_smp2p_out 0>;
2863			qcom,smem-state-names = "stop";
2864
2865			status = "disabled";
2866
2867			glink-edge {
2868				interrupts = <GIC_SPI 261 IRQ_TYPE_EDGE_RISING>;
2869				label = "cdsp";
2870				qcom,remote-pid = <5>;
2871				mboxes = <&apcs_glb 28>;
2872
2873				fastrpc {
2874					compatible = "qcom,fastrpc";
2875					qcom,glink-channels = "fastrpcglink-apps-dsp";
2876					label = "cdsp";
2877					qcom,non-secure-domain;
2878					#address-cells = <1>;
2879					#size-cells = <0>;
2880
2881					compute-cb@1 {
2882						compatible = "qcom,fastrpc-compute-cb";
2883						reg = <1>;
2884						iommus = <&apps_smmu 0x0c01 0x0>;
2885					};
2886
2887					compute-cb@2 {
2888						compatible = "qcom,fastrpc-compute-cb";
2889						reg = <2>;
2890						iommus = <&apps_smmu 0x0c02 0x0>;
2891					};
2892
2893					compute-cb@3 {
2894						compatible = "qcom,fastrpc-compute-cb";
2895						reg = <3>;
2896						iommus = <&apps_smmu 0x0c03 0x0>;
2897					};
2898
2899					compute-cb@4 {
2900						compatible = "qcom,fastrpc-compute-cb";
2901						reg = <4>;
2902						iommus = <&apps_smmu 0x0c04 0x0>;
2903					};
2904
2905					compute-cb@5 {
2906						compatible = "qcom,fastrpc-compute-cb";
2907						reg = <5>;
2908						iommus = <&apps_smmu 0x0c05 0x0>;
2909					};
2910
2911					compute-cb@6 {
2912						compatible = "qcom,fastrpc-compute-cb";
2913						reg = <6>;
2914						iommus = <&apps_smmu 0x0c06 0x0>;
2915					};
2916
2917					/* note: secure cb9 in downstream */
2918				};
2919			};
2920		};
2921
2922		apps_smmu: iommu@c600000 {
2923			compatible = "qcom,sm6115-smmu-500", "qcom,smmu-500", "arm,mmu-500";
2924			reg = <0x0 0x0c600000 0x0 0x80000>;
2925			#iommu-cells = <2>;
2926			#global-interrupts = <1>;
2927
2928			interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>,
2929				     <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>,
2930				     <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>,
2931				     <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>,
2932				     <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>,
2933				     <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>,
2934				     <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>,
2935				     <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>,
2936				     <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>,
2937				     <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>,
2938				     <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>,
2939				     <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>,
2940				     <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>,
2941				     <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>,
2942				     <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
2943				     <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>,
2944				     <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>,
2945				     <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
2946				     <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
2947				     <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
2948				     <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
2949				     <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
2950				     <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
2951				     <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
2952				     <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
2953				     <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
2954				     <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
2955				     <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
2956				     <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
2957				     <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
2958				     <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
2959				     <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
2960				     <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>,
2961				     <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>,
2962				     <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
2963				     <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>,
2964				     <GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>,
2965				     <GIC_SPI 124 IRQ_TYPE_LEVEL_HIGH>,
2966				     <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>,
2967				     <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>,
2968				     <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
2969				     <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>,
2970				     <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>,
2971				     <GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>,
2972				     <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>,
2973				     <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>,
2974				     <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>,
2975				     <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>,
2976				     <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
2977				     <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>,
2978				     <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>,
2979				     <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>,
2980				     <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>,
2981				     <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
2982				     <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
2983				     <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
2984				     <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>,
2985				     <GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH>,
2986				     <GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH>,
2987				     <GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>,
2988				     <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>,
2989				     <GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>,
2990				     <GIC_SPI 149 IRQ_TYPE_LEVEL_HIGH>,
2991				     <GIC_SPI 150 IRQ_TYPE_LEVEL_HIGH>,
2992				     <GIC_SPI 151 IRQ_TYPE_LEVEL_HIGH>;
2993		};
2994
2995		wifi: wifi@c800000 {
2996			compatible = "qcom,wcn3990-wifi";
2997			reg = <0x0 0x0c800000 0x0 0x800000>;
2998			reg-names = "membase";
2999			memory-region = <&wlan_msa_mem>;
3000			interrupts = <GIC_SPI 358 IRQ_TYPE_LEVEL_HIGH>,
3001				     <GIC_SPI 359 IRQ_TYPE_LEVEL_HIGH>,
3002				     <GIC_SPI 360 IRQ_TYPE_LEVEL_HIGH>,
3003				     <GIC_SPI 361 IRQ_TYPE_LEVEL_HIGH>,
3004				     <GIC_SPI 362 IRQ_TYPE_LEVEL_HIGH>,
3005				     <GIC_SPI 363 IRQ_TYPE_LEVEL_HIGH>,
3006				     <GIC_SPI 364 IRQ_TYPE_LEVEL_HIGH>,
3007				     <GIC_SPI 365 IRQ_TYPE_LEVEL_HIGH>,
3008				     <GIC_SPI 366 IRQ_TYPE_LEVEL_HIGH>,
3009				     <GIC_SPI 367 IRQ_TYPE_LEVEL_HIGH>,
3010				     <GIC_SPI 368 IRQ_TYPE_LEVEL_HIGH>,
3011				     <GIC_SPI 369 IRQ_TYPE_LEVEL_HIGH>;
3012			iommus = <&apps_smmu 0x1a0 0x1>;
3013			qcom,msa-fixed-perm;
3014			status = "disabled";
3015		};
3016
3017		watchdog@f017000 {
3018			compatible = "qcom,apss-wdt-sm6115", "qcom,kpss-wdt";
3019			reg = <0x0 0x0f017000 0x0 0x1000>;
3020			clocks = <&sleep_clk>;
3021			interrupts = <GIC_SPI 3 IRQ_TYPE_EDGE_RISING>;
3022		};
3023
3024		apcs_glb: mailbox@f111000 {
3025			compatible = "qcom,sm6115-apcs-hmss-global",
3026				     "qcom,msm8994-apcs-kpss-global";
3027			reg = <0x0 0x0f111000 0x0 0x1000>;
3028
3029			#mbox-cells = <1>;
3030		};
3031
3032		timer@f120000 {
3033			compatible = "arm,armv7-timer-mem";
3034			reg = <0x0 0x0f120000 0x0 0x1000>;
3035			#address-cells = <2>;
3036			#size-cells = <1>;
3037			ranges = <0x0 0x0 0x0 0x0 0x20000000>;
3038			clock-frequency = <19200000>;
3039
3040			frame@f121000 {
3041				reg = <0x0 0x0f121000 0x1000>, <0x0 0x0f122000 0x1000>;
3042				frame-number = <0>;
3043				interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>,
3044					     <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
3045			};
3046
3047			frame@f123000 {
3048				reg = <0x0 0x0f123000 0x1000>;
3049				frame-number = <1>;
3050				interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
3051				status = "disabled";
3052			};
3053
3054			frame@f124000 {
3055				reg = <0x0 0x0f124000 0x1000>;
3056				frame-number = <2>;
3057				interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
3058				status = "disabled";
3059			};
3060
3061			frame@f125000 {
3062				reg = <0x0 0x0f125000 0x1000>;
3063				frame-number = <3>;
3064				interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
3065				status = "disabled";
3066			};
3067
3068			frame@f126000 {
3069				reg = <0x0 0x0f126000 0x1000>;
3070				frame-number = <4>;
3071				interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
3072				status = "disabled";
3073			};
3074
3075			frame@f127000 {
3076				reg = <0x0 0x0f127000 0x1000>;
3077				frame-number = <5>;
3078				interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
3079				status = "disabled";
3080			};
3081
3082			frame@f128000 {
3083				reg = <0x0 0x0f128000 0x1000>;
3084				frame-number = <6>;
3085				interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
3086				status = "disabled";
3087			};
3088		};
3089
3090		intc: interrupt-controller@f200000 {
3091			compatible = "arm,gic-v3";
3092			reg = <0x0 0x0f200000 0x0 0x10000>,
3093			      <0x0 0x0f300000 0x0 0x100000>;
3094			#interrupt-cells = <3>;
3095			interrupt-controller;
3096			interrupt-parent = <&intc>;
3097			#redistributor-regions = <1>;
3098			redistributor-stride = <0x0 0x20000>;
3099			interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
3100		};
3101
3102		cpufreq_hw: cpufreq@f521000 {
3103			compatible = "qcom,sm6115-cpufreq-hw", "qcom,cpufreq-hw";
3104			reg = <0x0 0x0f521000 0x0 0x1000>,
3105			      <0x0 0x0f523000 0x0 0x1000>;
3106
3107			reg-names = "freq-domain0", "freq-domain1";
3108			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>, <&gcc GPLL0>;
3109			clock-names = "xo", "alternate";
3110
3111			#freq-domain-cells = <1>;
3112			#clock-cells = <1>;
3113		};
3114	};
3115
3116	thermal-zones {
3117		mapss-thermal {
3118			thermal-sensors = <&tsens0 0>;
3119
3120			trips {
3121				trip-point0 {
3122					temperature = <115000>;
3123					hysteresis = <5000>;
3124					type = "passive";
3125				};
3126
3127				trip-point1 {
3128					temperature = <125000>;
3129					hysteresis = <1000>;
3130					type = "passive";
3131				};
3132			};
3133		};
3134
3135		cdsp-hvx-thermal {
3136			thermal-sensors = <&tsens0 1>;
3137
3138			trips {
3139				trip-point0 {
3140					temperature = <115000>;
3141					hysteresis = <5000>;
3142					type = "passive";
3143				};
3144
3145				trip-point1 {
3146					temperature = <125000>;
3147					hysteresis = <1000>;
3148					type = "passive";
3149				};
3150			};
3151		};
3152
3153		wlan-thermal {
3154			thermal-sensors = <&tsens0 2>;
3155
3156			trips {
3157				trip-point0 {
3158					temperature = <115000>;
3159					hysteresis = <5000>;
3160					type = "passive";
3161				};
3162
3163				trip-point1 {
3164					temperature = <125000>;
3165					hysteresis = <1000>;
3166					type = "passive";
3167				};
3168			};
3169		};
3170
3171		camera-thermal {
3172			thermal-sensors = <&tsens0 3>;
3173
3174			trips {
3175				trip-point0 {
3176					temperature = <115000>;
3177					hysteresis = <5000>;
3178					type = "passive";
3179				};
3180
3181				trip-point1 {
3182					temperature = <125000>;
3183					hysteresis = <1000>;
3184					type = "passive";
3185				};
3186			};
3187		};
3188
3189		video-thermal {
3190			thermal-sensors = <&tsens0 4>;
3191
3192			trips {
3193				trip-point0 {
3194					temperature = <115000>;
3195					hysteresis = <5000>;
3196					type = "passive";
3197				};
3198
3199				trip-point1 {
3200					temperature = <125000>;
3201					hysteresis = <1000>;
3202					type = "passive";
3203				};
3204			};
3205		};
3206
3207		modem1-thermal {
3208			thermal-sensors = <&tsens0 5>;
3209
3210			trips {
3211				trip-point0 {
3212					temperature = <115000>;
3213					hysteresis = <5000>;
3214					type = "passive";
3215				};
3216
3217				trip-point1 {
3218					temperature = <125000>;
3219					hysteresis = <1000>;
3220					type = "passive";
3221				};
3222			};
3223		};
3224
3225		cpu4-thermal {
3226			thermal-sensors = <&tsens0 6>;
3227
3228			trips {
3229				cpu4_alert0: trip-point0 {
3230					temperature = <90000>;
3231					hysteresis = <2000>;
3232					type = "passive";
3233				};
3234
3235				cpu4_alert1: trip-point1 {
3236					temperature = <95000>;
3237					hysteresis = <2000>;
3238					type = "passive";
3239				};
3240
3241				cpu4_crit: cpu-crit {
3242					temperature = <110000>;
3243					hysteresis = <1000>;
3244					type = "critical";
3245				};
3246			};
3247		};
3248
3249		cpu5-thermal {
3250			thermal-sensors = <&tsens0 7>;
3251
3252			trips {
3253				cpu5_alert0: trip-point0 {
3254					temperature = <90000>;
3255					hysteresis = <2000>;
3256					type = "passive";
3257				};
3258
3259				cpu5_alert1: trip-point1 {
3260					temperature = <95000>;
3261					hysteresis = <2000>;
3262					type = "passive";
3263				};
3264
3265				cpu5_crit: cpu-crit {
3266					temperature = <110000>;
3267					hysteresis = <1000>;
3268					type = "critical";
3269				};
3270			};
3271		};
3272
3273		cpu6-thermal {
3274			thermal-sensors = <&tsens0 8>;
3275
3276			trips {
3277				cpu6_alert0: trip-point0 {
3278					temperature = <90000>;
3279					hysteresis = <2000>;
3280					type = "passive";
3281				};
3282
3283				cpu6_alert1: trip-point1 {
3284					temperature = <95000>;
3285					hysteresis = <2000>;
3286					type = "passive";
3287				};
3288
3289				cpu6_crit: cpu-crit {
3290					temperature = <110000>;
3291					hysteresis = <1000>;
3292					type = "critical";
3293				};
3294			};
3295		};
3296
3297		cpu7-thermal {
3298			thermal-sensors = <&tsens0 9>;
3299
3300			trips {
3301				cpu7_alert0: trip-point0 {
3302					temperature = <90000>;
3303					hysteresis = <2000>;
3304					type = "passive";
3305				};
3306
3307				cpu7_alert1: trip-point1 {
3308					temperature = <95000>;
3309					hysteresis = <2000>;
3310					type = "passive";
3311				};
3312
3313				cpu7_crit: cpu-crit {
3314					temperature = <110000>;
3315					hysteresis = <1000>;
3316					type = "critical";
3317				};
3318			};
3319		};
3320
3321		cpu45-thermal {
3322			thermal-sensors = <&tsens0 10>;
3323
3324			trips {
3325				cpu45_alert0: trip-point0 {
3326					temperature = <90000>;
3327					hysteresis = <2000>;
3328					type = "passive";
3329				};
3330
3331				cpu45_alert1: trip-point1 {
3332					temperature = <95000>;
3333					hysteresis = <2000>;
3334					type = "passive";
3335				};
3336
3337				cpu45_crit: cpu-crit {
3338					temperature = <110000>;
3339					hysteresis = <1000>;
3340					type = "critical";
3341				};
3342			};
3343		};
3344
3345		cpu67-thermal {
3346			thermal-sensors = <&tsens0 11>;
3347
3348			trips {
3349				cpu67_alert0: trip-point0 {
3350					temperature = <90000>;
3351					hysteresis = <2000>;
3352					type = "passive";
3353				};
3354
3355				cpu67_alert1: trip-point1 {
3356					temperature = <95000>;
3357					hysteresis = <2000>;
3358					type = "passive";
3359				};
3360
3361				cpu67_crit: cpu-crit {
3362					temperature = <110000>;
3363					hysteresis = <1000>;
3364					type = "critical";
3365				};
3366			};
3367		};
3368
3369		cpu0123-thermal {
3370			thermal-sensors = <&tsens0 12>;
3371
3372			trips {
3373				cpu0123_alert0: trip-point0 {
3374					temperature = <90000>;
3375					hysteresis = <2000>;
3376					type = "passive";
3377				};
3378
3379				cpu0123_alert1: trip-point1 {
3380					temperature = <95000>;
3381					hysteresis = <2000>;
3382					type = "passive";
3383				};
3384
3385				cpu0123_crit: cpu-crit {
3386					temperature = <110000>;
3387					hysteresis = <1000>;
3388					type = "critical";
3389				};
3390			};
3391		};
3392
3393		modem0-thermal {
3394			thermal-sensors = <&tsens0 13>;
3395
3396			trips {
3397				trip-point0 {
3398					temperature = <115000>;
3399					hysteresis = <5000>;
3400					type = "passive";
3401				};
3402
3403				trip-point1 {
3404					temperature = <125000>;
3405					hysteresis = <1000>;
3406					type = "passive";
3407				};
3408			};
3409		};
3410
3411		display-thermal {
3412			thermal-sensors = <&tsens0 14>;
3413
3414			trips {
3415				trip-point0 {
3416					temperature = <115000>;
3417					hysteresis = <5000>;
3418					type = "passive";
3419				};
3420
3421				trip-point1 {
3422					temperature = <125000>;
3423					hysteresis = <1000>;
3424					type = "passive";
3425				};
3426			};
3427		};
3428
3429		gpu-thermal {
3430			polling-delay-passive = <250>;
3431
3432			thermal-sensors = <&tsens0 15>;
3433
3434			cooling-maps {
3435				map0 {
3436					trip = <&gpu_alert0>;
3437					cooling-device = <&gpu THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
3438				};
3439			};
3440
3441			trips {
3442				gpu_alert0: trip-point0 {
3443					temperature = <85000>;
3444					hysteresis = <1000>;
3445					type = "passive";
3446				};
3447
3448				trip-point1 {
3449					temperature = <110000>;
3450					hysteresis = <1000>;
3451					type = "critical";
3452				};
3453			};
3454		};
3455	};
3456
3457	timer {
3458		compatible = "arm,armv8-timer";
3459		interrupts = <GIC_PPI 1 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
3460			     <GIC_PPI 2 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
3461			     <GIC_PPI 3 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
3462			     <GIC_PPI 0 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
3463	};
3464};
3465