xref: /linux/arch/arm64/boot/dts/qcom/sm6375.dtsi (revision 8f8d74ee110c02137f5b78ca0a2bd6c10331f267)
1// SPDX-License-Identifier: BSD-3-Clause
2/*
3 * Copyright (c) 2022, Konrad Dybcio <konrad.dybcio@somainline.org>
4 */
5
6#include <dt-bindings/clock/qcom,rpmcc.h>
7#include <dt-bindings/clock/qcom,sm6375-gcc.h>
8#include <dt-bindings/clock/qcom,sm6375-gpucc.h>
9#include <dt-bindings/dma/qcom-gpi.h>
10#include <dt-bindings/firmware/qcom,scm.h>
11#include <dt-bindings/interconnect/qcom,osm-l3.h>
12#include <dt-bindings/interrupt-controller/arm-gic.h>
13#include <dt-bindings/mailbox/qcom-ipcc.h>
14#include <dt-bindings/power/qcom-rpmpd.h>
15
16/ {
17	interrupt-parent = <&intc>;
18
19	#address-cells = <2>;
20	#size-cells = <2>;
21
22	chosen { };
23
24	clocks {
25		xo_board_clk: xo-board-clk {
26			compatible = "fixed-clock";
27			#clock-cells = <0>;
28		};
29
30		sleep_clk: sleep-clk {
31			compatible = "fixed-clock";
32			clock-frequency = <32000>;
33			#clock-cells = <0>;
34		};
35	};
36
37	cpus {
38		#address-cells = <2>;
39		#size-cells = <0>;
40
41		CPU0: cpu@0 {
42			device_type = "cpu";
43			compatible = "qcom,kryo660";
44			reg = <0x0 0x0>;
45			clocks = <&cpufreq_hw 0>;
46			enable-method = "psci";
47			next-level-cache = <&L2_0>;
48			qcom,freq-domain = <&cpufreq_hw 0>;
49			operating-points-v2 = <&cpu0_opp_table>;
50			interconnects = <&cpucp_l3 MASTER_EPSS_L3_APPS &cpucp_l3 SLAVE_EPSS_L3_SHARED>;
51			power-domains = <&CPU_PD0>;
52			power-domain-names = "psci";
53			#cooling-cells = <2>;
54			L2_0: l2-cache {
55				compatible = "cache";
56				cache-level = <2>;
57				cache-unified;
58				next-level-cache = <&L3_0>;
59				L3_0: l3-cache {
60					compatible = "cache";
61					cache-level = <3>;
62					cache-unified;
63				};
64			};
65		};
66
67		CPU1: cpu@100 {
68			device_type = "cpu";
69			compatible = "qcom,kryo660";
70			reg = <0x0 0x100>;
71			clocks = <&cpufreq_hw 0>;
72			enable-method = "psci";
73			next-level-cache = <&L2_100>;
74			qcom,freq-domain = <&cpufreq_hw 0>;
75			operating-points-v2 = <&cpu0_opp_table>;
76			interconnects = <&cpucp_l3 MASTER_EPSS_L3_APPS &cpucp_l3 SLAVE_EPSS_L3_SHARED>;
77			power-domains = <&CPU_PD1>;
78			power-domain-names = "psci";
79			#cooling-cells = <2>;
80			L2_100: l2-cache {
81				compatible = "cache";
82				cache-level = <2>;
83				cache-unified;
84				next-level-cache = <&L3_0>;
85			};
86		};
87
88		CPU2: cpu@200 {
89			device_type = "cpu";
90			compatible = "qcom,kryo660";
91			reg = <0x0 0x200>;
92			clocks = <&cpufreq_hw 0>;
93			enable-method = "psci";
94			next-level-cache = <&L2_200>;
95			qcom,freq-domain = <&cpufreq_hw 0>;
96			operating-points-v2 = <&cpu0_opp_table>;
97			interconnects = <&cpucp_l3 MASTER_EPSS_L3_APPS &cpucp_l3 SLAVE_EPSS_L3_SHARED>;
98			power-domains = <&CPU_PD2>;
99			power-domain-names = "psci";
100			#cooling-cells = <2>;
101			L2_200: l2-cache {
102				compatible = "cache";
103				cache-level = <2>;
104				cache-unified;
105				next-level-cache = <&L3_0>;
106			};
107		};
108
109		CPU3: cpu@300 {
110			device_type = "cpu";
111			compatible = "qcom,kryo660";
112			reg = <0x0 0x300>;
113			clocks = <&cpufreq_hw 0>;
114			enable-method = "psci";
115			next-level-cache = <&L2_300>;
116			qcom,freq-domain = <&cpufreq_hw 0>;
117			operating-points-v2 = <&cpu0_opp_table>;
118			interconnects = <&cpucp_l3 MASTER_EPSS_L3_APPS &cpucp_l3 SLAVE_EPSS_L3_SHARED>;
119			power-domains = <&CPU_PD3>;
120			power-domain-names = "psci";
121			#cooling-cells = <2>;
122			L2_300: l2-cache {
123				compatible = "cache";
124				cache-level = <2>;
125				cache-unified;
126				next-level-cache = <&L3_0>;
127			};
128		};
129
130		CPU4: cpu@400 {
131			device_type = "cpu";
132			compatible = "qcom,kryo660";
133			reg = <0x0 0x400>;
134			clocks = <&cpufreq_hw 0>;
135			enable-method = "psci";
136			next-level-cache = <&L2_400>;
137			qcom,freq-domain = <&cpufreq_hw 0>;
138			operating-points-v2 = <&cpu0_opp_table>;
139			interconnects = <&cpucp_l3 MASTER_EPSS_L3_APPS &cpucp_l3 SLAVE_EPSS_L3_SHARED>;
140			power-domains = <&CPU_PD4>;
141			power-domain-names = "psci";
142			#cooling-cells = <2>;
143			L2_400: l2-cache {
144				compatible = "cache";
145				cache-level = <2>;
146				cache-unified;
147				next-level-cache = <&L3_0>;
148			};
149		};
150
151		CPU5: cpu@500 {
152			device_type = "cpu";
153			compatible = "qcom,kryo660";
154			reg = <0x0 0x500>;
155			clocks = <&cpufreq_hw 0>;
156			enable-method = "psci";
157			next-level-cache = <&L2_500>;
158			qcom,freq-domain = <&cpufreq_hw 0>;
159			operating-points-v2 = <&cpu0_opp_table>;
160			interconnects = <&cpucp_l3 MASTER_EPSS_L3_APPS &cpucp_l3 SLAVE_EPSS_L3_SHARED>;
161			power-domains = <&CPU_PD5>;
162			power-domain-names = "psci";
163			#cooling-cells = <2>;
164			L2_500: l2-cache {
165				compatible = "cache";
166				cache-level = <2>;
167				cache-unified;
168				next-level-cache = <&L3_0>;
169			};
170		};
171
172		CPU6: cpu@600 {
173			device_type = "cpu";
174			compatible = "qcom,kryo660";
175			reg = <0x0 0x600>;
176			clocks = <&cpufreq_hw 1>;
177			enable-method = "psci";
178			next-level-cache = <&L2_600>;
179			qcom,freq-domain = <&cpufreq_hw 1>;
180			operating-points-v2 = <&cpu6_opp_table>;
181			interconnects = <&cpucp_l3 MASTER_EPSS_L3_APPS &cpucp_l3 SLAVE_EPSS_L3_SHARED>;
182			power-domains = <&CPU_PD6>;
183			power-domain-names = "psci";
184			#cooling-cells = <2>;
185			L2_600: l2-cache {
186				compatible = "cache";
187				cache-level = <2>;
188				cache-unified;
189				next-level-cache = <&L3_0>;
190			};
191		};
192
193		CPU7: cpu@700 {
194			device_type = "cpu";
195			compatible = "qcom,kryo660";
196			reg = <0x0 0x700>;
197			clocks = <&cpufreq_hw 1>;
198			enable-method = "psci";
199			next-level-cache = <&L2_700>;
200			qcom,freq-domain = <&cpufreq_hw 1>;
201			operating-points-v2 = <&cpu6_opp_table>;
202			interconnects = <&cpucp_l3 MASTER_EPSS_L3_APPS &cpucp_l3 SLAVE_EPSS_L3_SHARED>;
203			power-domains = <&CPU_PD7>;
204			power-domain-names = "psci";
205			#cooling-cells = <2>;
206			L2_700: l2-cache {
207				compatible = "cache";
208				cache-level = <2>;
209				cache-unified;
210				next-level-cache = <&L3_0>;
211			};
212		};
213
214		cpu-map {
215			cluster0 {
216				core0 {
217					cpu = <&CPU0>;
218				};
219
220				core1 {
221					cpu = <&CPU1>;
222				};
223
224				core2 {
225					cpu = <&CPU2>;
226				};
227
228				core3 {
229					cpu = <&CPU3>;
230				};
231
232				core4 {
233					cpu = <&CPU4>;
234				};
235
236				core5 {
237					cpu = <&CPU5>;
238				};
239
240				core6 {
241					cpu = <&CPU6>;
242				};
243
244				core7 {
245					cpu = <&CPU7>;
246				};
247			};
248		};
249
250		idle-states {
251			entry-method = "psci";
252
253			LITTLE_CPU_SLEEP_0: cpu-sleep-0-0 {
254				compatible = "arm,idle-state";
255				idle-state-name = "silver-power-collapse";
256				arm,psci-suspend-param = <0x40000003>;
257				entry-latency-us = <549>;
258				exit-latency-us = <901>;
259				min-residency-us = <1774>;
260				local-timer-stop;
261			};
262
263			LITTLE_CPU_SLEEP_1: cpu-sleep-0-1 {
264				compatible = "arm,idle-state";
265				idle-state-name = "silver-rail-power-collapse";
266				arm,psci-suspend-param = <0x40000004>;
267				entry-latency-us = <702>;
268				exit-latency-us = <915>;
269				min-residency-us = <4001>;
270				local-timer-stop;
271			};
272
273			BIG_CPU_SLEEP_0: cpu-sleep-1-0 {
274				compatible = "arm,idle-state";
275				idle-state-name = "gold-power-collapse";
276				arm,psci-suspend-param = <0x40000003>;
277				entry-latency-us = <523>;
278				exit-latency-us = <1244>;
279				min-residency-us = <2207>;
280				local-timer-stop;
281			};
282
283			BIG_CPU_SLEEP_1: cpu-sleep-1-1 {
284				compatible = "arm,idle-state";
285				idle-state-name = "gold-rail-power-collapse";
286				arm,psci-suspend-param = <0x40000004>;
287				entry-latency-us = <526>;
288				exit-latency-us = <1854>;
289				min-residency-us = <5555>;
290				local-timer-stop;
291			};
292		};
293
294		domain-idle-states {
295			CLUSTER_SLEEP_0: cluster-sleep-0 {
296				compatible = "domain-idle-state";
297				arm,psci-suspend-param = <0x41000044>;
298				entry-latency-us = <2752>;
299				exit-latency-us = <3048>;
300				min-residency-us = <6118>;
301			};
302		};
303	};
304
305	firmware {
306		scm {
307			compatible = "qcom,scm-sm6375", "qcom,scm";
308			clocks = <&rpmcc RPM_SMD_CE1_CLK>;
309			clock-names = "core";
310			#reset-cells = <1>;
311		};
312	};
313
314	mpm: interrupt-controller {
315		compatible = "qcom,mpm";
316		qcom,rpm-msg-ram = <&apss_mpm>;
317		interrupts = <GIC_SPI 197 IRQ_TYPE_EDGE_RISING>;
318		mboxes = <&ipcc IPCC_CLIENT_AOP IPCC_MPROC_SIGNAL_SMP2P>;
319		interrupt-controller;
320		#interrupt-cells = <2>;
321		#power-domain-cells = <0>;
322		interrupt-parent = <&intc>;
323		qcom,mpm-pin-count = <96>;
324		qcom,mpm-pin-map = <5 296>,  /* Soundwire wake_irq */
325				   <12 422>, /* DWC3 ss_phy_irq */
326				   <86 183>, /* MPM wake, SPMI */
327				   <89 314>, /* TSENS0 0C */
328				   <90 315>, /* TSENS1 0C */
329				   <93 164>, /* DWC3 dm_hs_phy_irq */
330				   <94 165>; /* DWC3 dp_hs_phy_irq */
331	};
332
333	memory@80000000 {
334		device_type = "memory";
335		/* We expect the bootloader to fill in the size */
336		reg = <0x0 0x80000000 0x0 0x0>;
337	};
338
339	cpu0_opp_table: opp-table-cpu0 {
340		compatible = "operating-points-v2";
341		opp-shared;
342
343		opp-300000000 {
344			opp-hz = /bits/ 64 <300000000>;
345			opp-peak-kBps = <(300000 * 32)>;
346		};
347
348		opp-576000000 {
349			opp-hz = /bits/ 64 <576000000>;
350			opp-peak-kBps = <(556800 * 32)>;
351		};
352
353		opp-691200000 {
354			opp-hz = /bits/ 64 <691200000>;
355			opp-peak-kBps = <(652800 * 32)>;
356		};
357
358		opp-940800000 {
359			opp-hz = /bits/ 64 <940800000>;
360			opp-peak-kBps = <(921600 * 32)>;
361		};
362
363		opp-1113600000 {
364			opp-hz = /bits/ 64 <1113600000>;
365			opp-peak-kBps = <(921600 * 32)>;
366		};
367
368		opp-1324800000 {
369			opp-hz = /bits/ 64 <1324800000>;
370			opp-peak-kBps = <(1171200 * 32)>;
371		};
372
373		opp-1516800000 {
374			opp-hz = /bits/ 64 <1516800000>;
375			opp-peak-kBps = <(1497600 * 32)>;
376		};
377
378		opp-1651200000 {
379			opp-hz = /bits/ 64 <1651200000>;
380			opp-peak-kBps = <(1497600 * 32)>;
381		};
382
383		opp-1708800000 {
384			opp-hz = /bits/ 64 <1708800000>;
385			opp-peak-kBps = <(1497600 * 32)>;
386		};
387
388		opp-1804800000 {
389			opp-hz = /bits/ 64 <1804800000>;
390			opp-peak-kBps = <(1497600 * 32)>;
391		};
392	};
393
394	cpu6_opp_table: opp-table-cpu6 {
395		compatible = "operating-points-v2";
396		opp-shared;
397
398		opp-691200000 {
399			opp-hz = /bits/ 64 <691200000>;
400			opp-peak-kBps = <(556800 * 32)>;
401		};
402
403		opp-940800000 {
404			opp-hz = /bits/ 64 <940800000>;
405			opp-peak-kBps = <(921600 * 32)>;
406		};
407
408		opp-1228800000 {
409			opp-hz = /bits/ 64 <1228800000>;
410			opp-peak-kBps = <(1171200 * 32)>;
411		};
412
413		opp-1401600000 {
414			opp-hz = /bits/ 64 <1401600000>;
415			opp-peak-kBps = <(1382400 * 32)>;
416		};
417
418		opp-1516800000 {
419			opp-hz = /bits/ 64 <1516800000>;
420			opp-peak-kBps = <(1497600 * 32)>;
421		};
422
423		opp-1651200000 {
424			opp-hz = /bits/ 64 <1651200000>;
425			opp-peak-kBps = <(1497600 * 32)>;
426		};
427
428		opp-1804800000 {
429			opp-hz = /bits/ 64 <1804800000>;
430			opp-peak-kBps = <(1497600 * 32)>;
431		};
432
433		opp-1900800000 {
434			opp-hz = /bits/ 64 <1900800000>;
435			opp-peak-kBps = <(1497600 * 32)>;
436		};
437
438		opp-2054400000 {
439			opp-hz = /bits/ 64 <2054400000>;
440			opp-peak-kBps = <(1497600 * 32)>;
441		};
442
443		opp-2208000000 {
444			opp-hz = /bits/ 64 <2208000000>;
445			opp-peak-kBps = <(1497600 * 32)>;
446		};
447	};
448
449	pmu {
450		compatible = "arm,armv8-pmuv3";
451		interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_LOW>;
452	};
453
454	psci {
455		compatible = "arm,psci-1.0";
456		method = "smc";
457
458		CPU_PD0: power-domain-cpu0 {
459			#power-domain-cells = <0>;
460			power-domains = <&CLUSTER_PD>;
461			domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
462		};
463
464		CPU_PD1: power-domain-cpu1 {
465			#power-domain-cells = <0>;
466			power-domains = <&CLUSTER_PD>;
467			domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
468		};
469
470		CPU_PD2: power-domain-cpu2 {
471			#power-domain-cells = <0>;
472			power-domains = <&CLUSTER_PD>;
473			domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
474		};
475
476		CPU_PD3: power-domain-cpu3 {
477			#power-domain-cells = <0>;
478			power-domains = <&CLUSTER_PD>;
479			domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
480		};
481
482		CPU_PD4: power-domain-cpu4 {
483			#power-domain-cells = <0>;
484			power-domains = <&CLUSTER_PD>;
485			domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
486		};
487
488		CPU_PD5: power-domain-cpu5 {
489			#power-domain-cells = <0>;
490			power-domains = <&CLUSTER_PD>;
491			domain-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
492		};
493
494		CPU_PD6: power-domain-cpu6 {
495			#power-domain-cells = <0>;
496			power-domains = <&CLUSTER_PD>;
497			domain-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
498		};
499
500		CPU_PD7: power-domain-cpu7 {
501			#power-domain-cells = <0>;
502			power-domains = <&CLUSTER_PD>;
503			domain-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
504		};
505
506		CLUSTER_PD: power-domain-cpu-cluster0 {
507			#power-domain-cells = <0>;
508			power-domains = <&mpm>;
509			domain-idle-states = <&CLUSTER_SLEEP_0>;
510		};
511	};
512
513	qup_opp_table: opp-table-qup {
514		compatible = "operating-points-v2";
515
516		opp-75000000 {
517			opp-hz = /bits/ 64 <75000000>;
518			required-opps = <&rpmpd_opp_low_svs>;
519		};
520
521		opp-100000000 {
522			opp-hz = /bits/ 64 <100000000>;
523			required-opps = <&rpmpd_opp_svs>;
524		};
525
526		opp-128000000 {
527			opp-hz = /bits/ 64 <128000000>;
528			required-opps = <&rpmpd_opp_nom>;
529		};
530	};
531
532	reserved_memory: reserved-memory {
533		#address-cells = <2>;
534		#size-cells = <2>;
535		ranges;
536
537		hyp_mem: hypervisor@80000000 {
538			reg = <0 0x80000000 0 0x600000>;
539			no-map;
540		};
541
542		xbl_aop_mem: xbl-aop@80700000 {
543			reg = <0 0x80700000 0 0x100000>;
544			no-map;
545		};
546
547		reserved_xbl_uefi: xbl-uefi-res@80880000 {
548			reg = <0 0x80880000 0 0x14000>;
549			no-map;
550		};
551
552		smem_mem: smem@80900000 {
553			compatible = "qcom,smem";
554			reg = <0 0x80900000 0 0x200000>;
555			hwlocks = <&tcsr_mutex 3>;
556			no-map;
557		};
558
559		fw_mem: fw@80b00000 {
560			reg = <0 0x80b00000 0 0x100000>;
561			no-map;
562		};
563
564		cdsp_secure_heap_mem: cdsp-sec-heap@80c00000 {
565			reg = <0 0x80c00000 0 0x1e00000>;
566			no-map;
567		};
568
569		dfps_data_mem: dpfs-data@85e00000 {
570			reg = <0 0x85e00000 0 0x100000>;
571			no-map;
572		};
573
574		pil_wlan_mem: pil-wlan@86500000 {
575			reg = <0 0x86500000 0 0x200000>;
576			no-map;
577		};
578
579		pil_adsp_mem: pil-adsp@86700000 {
580			reg = <0 0x86700000 0 0x2000000>;
581			no-map;
582		};
583
584		pil_cdsp_mem: pil-cdsp@88700000 {
585			reg = <0 0x88700000 0 0x1e00000>;
586			no-map;
587		};
588
589		pil_video_mem: pil-video@8a500000 {
590			reg = <0 0x8a500000 0 0x500000>;
591			no-map;
592		};
593
594		pil_ipa_fw_mem: pil-ipa-fw@8aa00000 {
595			reg = <0 0x8aa00000 0 0x10000>;
596			no-map;
597		};
598
599		pil_ipa_gsi_mem: pil-ipa-gsi@8aa10000 {
600			reg = <0 0x8aa10000 0 0xa000>;
601			no-map;
602		};
603
604		pil_gpu_micro_code_mem: pil-gpu-ucode@8aa1a000 {
605			reg = <0 0x8aa1a000 0 0x2000>;
606			no-map;
607		};
608
609		pil_mpss_wlan_mem: pil-mpss-wlan@8b800000 {
610			reg = <0 0x8b800000 0 0x10000000>;
611			no-map;
612		};
613
614		removed_mem: removed@c0000000 {
615			reg = <0 0xc0000000 0 0x5100000>;
616			no-map;
617		};
618
619		rmtfs_mem: rmtfs@f3900000 {
620			compatible = "qcom,rmtfs-mem";
621			reg = <0 0xf3900000 0 0x280000>;
622			no-map;
623
624			qcom,client-id = <1>;
625			qcom,vmid = <QCOM_SCM_VMID_MSS_MSA QCOM_SCM_VMID_NAV>;
626		};
627
628		debug_mem: debug@ffb00000 {
629			reg = <0 0xffb00000 0 0xc0000>;
630			no-map;
631		};
632
633		last_log_mem: lastlog@ffbc0000 {
634			reg = <0 0xffbc0000 0 0x80000>;
635			no-map;
636		};
637
638		cmdline_region: cmdline@ffd00000 {
639			reg = <0 0xffd00000 0 0x1000>;
640			no-map;
641		};
642	};
643
644	rpm: remoteproc {
645		compatible = "qcom,sm6375-rpm-proc", "qcom,rpm-proc";
646
647		glink-edge {
648			compatible = "qcom,glink-rpm";
649			interrupts-extended = <&ipcc IPCC_CLIENT_AOP
650						     IPCC_MPROC_SIGNAL_GLINK_QMP
651						     IRQ_TYPE_EDGE_RISING>;
652			qcom,rpm-msg-ram = <&rpm_msg_ram>;
653			mboxes = <&ipcc IPCC_CLIENT_AOP IPCC_MPROC_SIGNAL_GLINK_QMP>;
654
655			rpm_requests: rpm-requests {
656				compatible = "qcom,rpm-sm6375";
657				qcom,glink-channels = "rpm_requests";
658
659				rpmcc: clock-controller {
660					compatible = "qcom,rpmcc-sm6375", "qcom,rpmcc";
661					clocks = <&xo_board_clk>;
662					clock-names = "xo";
663					#clock-cells = <1>;
664				};
665
666				rpmpd: power-controller {
667					compatible = "qcom,sm6375-rpmpd";
668					#power-domain-cells = <1>;
669					operating-points-v2 = <&rpmpd_opp_table>;
670
671					rpmpd_opp_table: opp-table {
672						compatible = "operating-points-v2";
673
674						rpmpd_opp_ret: opp1 {
675							opp-level = <RPM_SMD_LEVEL_RETENTION>;
676						};
677
678						rpmpd_opp_min_svs: opp2 {
679							opp-level = <RPM_SMD_LEVEL_MIN_SVS>;
680						};
681
682						rpmpd_opp_low_svs: opp3 {
683							opp-level = <RPM_SMD_LEVEL_LOW_SVS>;
684						};
685
686						rpmpd_opp_svs: opp4 {
687							opp-level = <RPM_SMD_LEVEL_SVS>;
688						};
689
690						rpmpd_opp_svs_plus: opp5 {
691							opp-level = <RPM_SMD_LEVEL_SVS_PLUS>;
692						};
693
694						rpmpd_opp_nom: opp6 {
695							opp-level = <RPM_SMD_LEVEL_NOM>;
696						};
697
698						rpmpd_opp_nom_plus: opp7 {
699							opp-level = <RPM_SMD_LEVEL_NOM_PLUS>;
700						};
701
702						rpmpd_opp_turbo: opp8 {
703							opp-level = <RPM_SMD_LEVEL_TURBO>;
704						};
705
706						rpmpd_opp_turbo_no_cpr: opp9 {
707							opp-level = <RPM_SMD_LEVEL_TURBO_NO_CPR>;
708						};
709					};
710				};
711			};
712		};
713	};
714
715	smp2p-adsp {
716		compatible = "qcom,smp2p";
717		qcom,smem = <443>, <429>;
718		interrupts-extended = <&ipcc IPCC_CLIENT_LPASS
719					     IPCC_MPROC_SIGNAL_SMP2P
720					     IRQ_TYPE_EDGE_RISING>;
721		mboxes = <&ipcc IPCC_CLIENT_LPASS
722				IPCC_MPROC_SIGNAL_SMP2P>;
723
724		qcom,local-pid = <0>;
725		qcom,remote-pid = <2>;
726
727		smp2p_adsp_out: master-kernel {
728			qcom,entry-name = "master-kernel";
729			#qcom,smem-state-cells = <1>;
730		};
731
732		smp2p_adsp_in: slave-kernel {
733			qcom,entry-name = "slave-kernel";
734			interrupt-controller;
735			#interrupt-cells = <2>;
736		};
737	};
738
739	smp2p-cdsp {
740		compatible = "qcom,smp2p";
741		qcom,smem = <94>, <432>;
742		interrupts-extended = <&ipcc IPCC_CLIENT_CDSP
743					     IPCC_MPROC_SIGNAL_SMP2P
744					     IRQ_TYPE_EDGE_RISING>;
745		mboxes = <&ipcc IPCC_CLIENT_CDSP
746				IPCC_MPROC_SIGNAL_SMP2P>;
747
748		qcom,local-pid = <0>;
749		qcom,remote-pid = <5>;
750
751		smp2p_cdsp_out: master-kernel {
752			qcom,entry-name = "master-kernel";
753			#qcom,smem-state-cells = <1>;
754		};
755
756		smp2p_cdsp_in: slave-kernel {
757			qcom,entry-name = "slave-kernel";
758			interrupt-controller;
759			#interrupt-cells = <2>;
760		};
761	};
762
763	smp2p-modem {
764		compatible = "qcom,smp2p";
765		qcom,smem = <435>, <428>;
766		interrupts-extended = <&ipcc IPCC_CLIENT_MPSS
767					     IPCC_MPROC_SIGNAL_SMP2P
768					     IRQ_TYPE_EDGE_RISING>;
769		mboxes = <&ipcc IPCC_CLIENT_MPSS
770				IPCC_MPROC_SIGNAL_SMP2P>;
771
772		qcom,local-pid = <0>;
773		qcom,remote-pid = <1>;
774
775		smp2p_modem_out: master-kernel {
776			qcom,entry-name = "master-kernel";
777			#qcom,smem-state-cells = <1>;
778		};
779
780		smp2p_modem_in: slave-kernel {
781			qcom,entry-name = "slave-kernel";
782			interrupt-controller;
783			#interrupt-cells = <2>;
784		};
785
786		ipa_smp2p_out: ipa-ap-to-modem {
787			qcom,entry-name = "ipa";
788			#qcom,smem-state-cells = <1>;
789		};
790
791		ipa_smp2p_in: ipa-modem-to-ap {
792			qcom,entry-name = "ipa";
793			interrupt-controller;
794			#interrupt-cells = <2>;
795		};
796
797		wlan_smp2p_in: wlan-wpss-to-ap {
798			qcom,entry-name = "wlan";
799			interrupt-controller;
800			#interrupt-cells = <2>;
801		};
802	};
803
804	soc: soc@0 {
805		#address-cells = <2>;
806		#size-cells = <2>;
807		ranges = <0 0 0 0 0x10 0>;
808		dma-ranges = <0 0 0 0 0x10 0>;
809		compatible = "simple-bus";
810
811		ipcc: mailbox@208000 {
812			compatible = "qcom,sm6375-ipcc", "qcom,ipcc";
813			reg = <0 0x00208000 0 0x1000>;
814			interrupts = <GIC_SPI 334 IRQ_TYPE_LEVEL_HIGH>;
815			interrupt-controller;
816			#interrupt-cells = <3>;
817			#mbox-cells = <2>;
818		};
819
820		tcsr_mutex: hwlock@340000 {
821			compatible = "qcom,tcsr-mutex";
822			reg = <0x0 0x00340000 0x0 0x40000>;
823			#hwlock-cells = <1>;
824		};
825
826		tlmm: pinctrl@500000 {
827			compatible = "qcom,sm6375-tlmm";
828			reg = <0 0x00500000 0 0x800000>;
829			interrupts = <GIC_SPI 227 IRQ_TYPE_LEVEL_HIGH>;
830			gpio-ranges = <&tlmm 0 0 157>;
831			wakeup-parent = <&mpm>;
832			interrupt-controller;
833			gpio-controller;
834			#interrupt-cells = <2>;
835			#gpio-cells = <2>;
836
837			sdc2_off_state: sdc2-off-state {
838				clk-pins {
839					pins = "sdc2_clk";
840					drive-strength = <2>;
841					bias-disable;
842				};
843
844				cmd-pins {
845					pins = "sdc2_cmd";
846					drive-strength = <2>;
847					bias-pull-up;
848				};
849
850				data-pins {
851					pins = "sdc2_data";
852					drive-strength = <2>;
853					bias-pull-up;
854				};
855			};
856
857			sdc2_on_state: sdc2-on-state {
858				clk-pins {
859					pins = "sdc2_clk";
860					drive-strength = <16>;
861					bias-disable;
862				};
863
864				cmd-pins {
865					pins = "sdc2_cmd";
866					drive-strength = <10>;
867					bias-pull-up;
868				};
869
870				data-pins {
871					pins = "sdc2_data";
872					drive-strength = <10>;
873					bias-pull-up;
874				};
875			};
876
877			qup_i2c0_default: qup-i2c0-default-state {
878				pins = "gpio0", "gpio1";
879				function = "qup00";
880				drive-strength = <2>;
881				bias-pull-up;
882			};
883
884			qup_i2c1_default: qup-i2c1-default-state {
885				pins = "gpio61", "gpio62";
886				function = "qup01";
887				drive-strength = <2>;
888				bias-pull-up;
889			};
890
891			qup_i2c2_default: qup-i2c2-default-state {
892				pins = "gpio45", "gpio46";
893				function = "qup02";
894				drive-strength = <2>;
895				bias-pull-up;
896			};
897
898			qup_i2c8_default: qup-i2c8-default-state {
899				pins = "gpio19", "gpio20";
900				/* TLMM, GCC and vendor DT all have different indices.. */
901				function = "qup12";
902				drive-strength = <2>;
903				bias-pull-up;
904			};
905
906			qup_i2c10_default: qup-i2c10-default-state {
907				pins = "gpio4", "gpio5";
908				function = "qup10";
909				drive-strength = <2>;
910				bias-pull-up;
911			};
912
913			qup_spi0_default: qup-spi0-default-state {
914				pins = "gpio0", "gpio1", "gpio2", "gpio3";
915				function = "qup00";
916				drive-strength = <6>;
917				bias-disable;
918			};
919
920			qup_uart1_default: qup-uart1-default-state {
921				cts-pins {
922					pins = "gpio61";
923					function = "qup01";
924					drive-strength = <2>;
925					bias-pull-down;
926				};
927
928				rts-pins {
929					pins = "gpio62";
930					function = "qup01";
931					drive-strength = <2>;
932					bias-disable;
933				};
934
935				tx-pins {
936					pins = "gpio63";
937					function = "qup01";
938					drive-strength = <2>;
939					bias-disable;
940				};
941
942				rx-pins {
943					pins = "gpio64";
944					function = "qup01";
945					drive-strength = <2>;
946					bias-pull-up;
947				};
948			};
949		};
950
951		gcc: clock-controller@1400000 {
952			compatible = "qcom,sm6375-gcc";
953			reg = <0 0x01400000 0 0x1f0000>;
954			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>,
955				 <&rpmcc RPM_SMD_XO_A_CLK_SRC>,
956				 <&sleep_clk>;
957			#power-domain-cells = <1>;
958			#clock-cells = <1>;
959			#reset-cells = <1>;
960		};
961
962		usb_1_hsphy: phy@162b000 {
963			compatible = "qcom,sm6375-usb-hs-phy", "qcom,usb-snps-hs-7nm-phy";
964			reg = <0 0x0162b000 0 0x400>;
965
966			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>;
967			clock-names = "ref";
968			resets = <&gcc GCC_QUSB2PHY_PRIM_BCR>;
969			#phy-cells = <0>;
970
971			status = "disabled";
972		};
973
974		spmi_bus: spmi@1c40000 {
975			compatible = "qcom,spmi-pmic-arb";
976			reg = <0 0x01c40000 0 0x1100>,
977			      <0 0x01e00000 0 0x2000000>,
978			      <0 0x03e00000 0 0x100000>,
979			      <0 0x03f00000 0 0xa0000>,
980			      <0 0x01c0a000 0 0x26000>;
981			reg-names = "core", "chnls", "obsrvr", "intr", "cnfg";
982			interrupt-names = "periph_irq";
983			interrupts-extended = <&mpm 86 IRQ_TYPE_LEVEL_HIGH>;
984			qcom,ee = <0>;
985			qcom,channel = <0>;
986			#address-cells = <2>;
987			#size-cells = <0>;
988			interrupt-controller;
989			#interrupt-cells = <4>;
990		};
991
992		tsens0: thermal-sensor@4411000 {
993			compatible = "qcom,sm6375-tsens", "qcom,tsens-v2";
994			reg = <0 0x04411000 0 0x140>, /* TM */
995			      <0 0x04410000 0 0x20>;  /* SROT */
996			interrupts = <GIC_SPI 275 IRQ_TYPE_LEVEL_HIGH>,
997				     <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>;
998			interrupt-names = "uplow", "critical";
999			#thermal-sensor-cells = <1>;
1000			#qcom,sensors = <15>;
1001		};
1002
1003		tsens1: thermal-sensor@4413000 {
1004			compatible = "qcom,sm6375-tsens", "qcom,tsens-v2";
1005			reg = <0 0x04413000 0 0x140>, /* TM */
1006			      <0 0x04412000 0 0x20>;  /* SROT */
1007			interrupts = <GIC_SPI 293 IRQ_TYPE_LEVEL_HIGH>,
1008				     <GIC_SPI 316 IRQ_TYPE_LEVEL_HIGH>;
1009			interrupt-names = "uplow", "critical";
1010			#thermal-sensor-cells = <1>;
1011			#qcom,sensors = <11>;
1012		};
1013
1014		rpm_msg_ram: sram@45f0000 {
1015			compatible = "qcom,rpm-msg-ram", "mmio-sram";
1016			reg = <0 0x045f0000 0 0x7000>;
1017			#address-cells = <1>;
1018			#size-cells = <1>;
1019			ranges = <0 0x0 0x045f0000 0x7000>;
1020
1021			apss_mpm: sram@1b8 {
1022				reg = <0x1b8 0x48>;
1023			};
1024		};
1025
1026		sram@4690000 {
1027			compatible = "qcom,rpm-stats";
1028			reg = <0 0x04690000 0 0x400>;
1029		};
1030
1031		sdhc_2: mmc@4784000 {
1032			compatible = "qcom,sm6375-sdhci", "qcom,sdhci-msm-v5";
1033			reg = <0 0x04784000 0 0x1000>;
1034
1035			interrupts = <GIC_SPI 350 IRQ_TYPE_LEVEL_HIGH>,
1036				     <GIC_SPI 353 IRQ_TYPE_LEVEL_HIGH>;
1037			interrupt-names = "hc_irq", "pwr_irq";
1038
1039			clocks = <&gcc GCC_SDCC2_AHB_CLK>,
1040				 <&gcc GCC_SDCC2_APPS_CLK>,
1041				 <&rpmcc RPM_SMD_XO_CLK_SRC>;
1042			clock-names = "iface", "core", "xo";
1043			resets = <&gcc GCC_SDCC2_BCR>;
1044			iommus = <&apps_smmu 0x40 0x0>;
1045
1046			pinctrl-0 = <&sdc2_on_state>;
1047			pinctrl-1 = <&sdc2_off_state>;
1048			pinctrl-names = "default", "sleep";
1049
1050			qcom,dll-config = <0x0007642c>;
1051			qcom,ddr-config = <0x80040868>;
1052			power-domains = <&rpmpd SM6375_VDDCX>;
1053			operating-points-v2 = <&sdhc2_opp_table>;
1054			bus-width = <4>;
1055
1056			status = "disabled";
1057
1058			sdhc2_opp_table: opp-table {
1059				compatible = "operating-points-v2";
1060
1061				opp-100000000 {
1062					opp-hz = /bits/ 64 <100000000>;
1063					required-opps = <&rpmpd_opp_low_svs>;
1064				};
1065
1066				opp-202000000 {
1067					opp-hz = /bits/ 64 <202000000>;
1068					required-opps = <&rpmpd_opp_svs_plus>;
1069				};
1070			};
1071		};
1072
1073		gpi_dma0: dma-controller@4a00000 {
1074			compatible = "qcom,sm6375-gpi-dma", "qcom,sm6350-gpi-dma";
1075			reg = <0 0x04a00000 0 0x60000>;
1076			interrupts = <GIC_SPI 335 IRQ_TYPE_LEVEL_HIGH>,
1077				     <GIC_SPI 336 IRQ_TYPE_LEVEL_HIGH>,
1078				     <GIC_SPI 337 IRQ_TYPE_LEVEL_HIGH>,
1079				     <GIC_SPI 338 IRQ_TYPE_LEVEL_HIGH>,
1080				     <GIC_SPI 339 IRQ_TYPE_LEVEL_HIGH>,
1081				     <GIC_SPI 340 IRQ_TYPE_LEVEL_HIGH>,
1082				     <GIC_SPI 341 IRQ_TYPE_LEVEL_HIGH>,
1083				     <GIC_SPI 342 IRQ_TYPE_LEVEL_HIGH>,
1084				     <GIC_SPI 343 IRQ_TYPE_LEVEL_HIGH>,
1085				     <GIC_SPI 344 IRQ_TYPE_LEVEL_HIGH>;
1086			dma-channels = <10>;
1087			dma-channel-mask = <0x1f>;
1088			iommus = <&apps_smmu 0x16 0x0>;
1089			#dma-cells = <3>;
1090			status = "disabled";
1091		};
1092
1093		qupv3_id_0: geniqup@4ac0000 {
1094			compatible = "qcom,geni-se-qup";
1095			reg = <0x0 0x04ac0000 0x0 0x2000>;
1096			clock-names = "m-ahb", "s-ahb";
1097			clocks = <&gcc GCC_QUPV3_WRAP_0_M_AHB_CLK>,
1098				 <&gcc GCC_QUPV3_WRAP_0_S_AHB_CLK>;
1099			iommus = <&apps_smmu 0x3 0x0>;
1100			#address-cells = <2>;
1101			#size-cells = <2>;
1102			ranges;
1103			status = "disabled";
1104
1105			i2c0: i2c@4a80000 {
1106				compatible = "qcom,geni-i2c";
1107				reg = <0x0 0x04a80000 0x0 0x4000>;
1108				clock-names = "se";
1109				clocks = <&gcc GCC_QUPV3_WRAP0_S0_CLK>;
1110				interrupts = <GIC_SPI 327 IRQ_TYPE_LEVEL_HIGH>;
1111				pinctrl-names = "default";
1112				pinctrl-0 = <&qup_i2c0_default>;
1113				dmas = <&gpi_dma0 0 0 QCOM_GPI_I2C>,
1114				       <&gpi_dma0 1 0 QCOM_GPI_I2C>;
1115				dma-names = "tx", "rx";
1116				#address-cells = <1>;
1117				#size-cells = <0>;
1118				status = "disabled";
1119			};
1120
1121			spi0: spi@4a80000 {
1122				compatible = "qcom,geni-spi";
1123				reg = <0x0 0x04a80000 0x0 0x4000>;
1124				clock-names = "se";
1125				clocks = <&gcc GCC_QUPV3_WRAP0_S0_CLK>;
1126				interrupts = <GIC_SPI 327 IRQ_TYPE_LEVEL_HIGH>;
1127				pinctrl-names = "default";
1128				pinctrl-0 = <&qup_spi0_default>;
1129				power-domains = <&rpmpd SM6375_VDDCX>;
1130				operating-points-v2 = <&qup_opp_table>;
1131				dmas = <&gpi_dma0 0 0 QCOM_GPI_SPI>,
1132				       <&gpi_dma0 1 0 QCOM_GPI_SPI>;
1133				dma-names = "tx", "rx";
1134				#address-cells = <1>;
1135				#size-cells = <0>;
1136				status = "disabled";
1137			};
1138
1139			i2c1: i2c@4a84000 {
1140				compatible = "qcom,geni-i2c";
1141				reg = <0x0 0x04a84000 0x0 0x4000>;
1142				clock-names = "se";
1143				clocks = <&gcc GCC_QUPV3_WRAP0_S1_CLK>;
1144				interrupts = <GIC_SPI 328 IRQ_TYPE_LEVEL_HIGH>;
1145				pinctrl-names = "default";
1146				pinctrl-0 = <&qup_i2c1_default>;
1147				dmas = <&gpi_dma0 0 1 QCOM_GPI_I2C>,
1148				       <&gpi_dma0 1 1 QCOM_GPI_I2C>;
1149				dma-names = "tx", "rx";
1150				#address-cells = <1>;
1151				#size-cells = <0>;
1152				status = "disabled";
1153			};
1154
1155			spi1: spi@4a84000 {
1156				compatible = "qcom,geni-spi";
1157				reg = <0x0 0x04a84000 0x0 0x4000>;
1158				clock-names = "se";
1159				clocks = <&gcc GCC_QUPV3_WRAP0_S1_CLK>;
1160				interrupts = <GIC_SPI 328 IRQ_TYPE_LEVEL_HIGH>;
1161				power-domains = <&rpmpd SM6375_VDDCX>;
1162				operating-points-v2 = <&qup_opp_table>;
1163				dmas = <&gpi_dma0 0 1 QCOM_GPI_SPI>,
1164				       <&gpi_dma0 1 1 QCOM_GPI_SPI>;
1165				dma-names = "tx", "rx";
1166				#address-cells = <1>;
1167				#size-cells = <0>;
1168				status = "disabled";
1169			};
1170
1171			uart1: serial@4a84000 {
1172				compatible = "qcom,geni-uart";
1173				reg = <0x0 0x04a84000 0x0 0x4000>;
1174				interrupts = <GIC_SPI 328 IRQ_TYPE_LEVEL_HIGH>;
1175				clocks = <&gcc GCC_QUPV3_WRAP0_S1_CLK>;
1176				clock-names = "se";
1177				power-domains = <&rpmpd SM6375_VDDCX>;
1178				operating-points-v2 = <&qup_opp_table>;
1179				pinctrl-0 = <&qup_uart1_default>;
1180				pinctrl-names = "default";
1181				status = "disabled";
1182			};
1183
1184			i2c2: i2c@4a88000 {
1185				compatible = "qcom,geni-i2c";
1186				reg = <0x0 0x04a88000 0x0 0x4000>;
1187				clock-names = "se";
1188				clocks = <&gcc GCC_QUPV3_WRAP0_S2_CLK>;
1189				interrupts = <GIC_SPI 329 IRQ_TYPE_LEVEL_HIGH>;
1190				pinctrl-names = "default";
1191				pinctrl-0 = <&qup_i2c2_default>;
1192				dmas = <&gpi_dma0 0 2 QCOM_GPI_I2C>,
1193				       <&gpi_dma0 1 2 QCOM_GPI_I2C>;
1194				dma-names = "tx", "rx";
1195				#address-cells = <1>;
1196				#size-cells = <0>;
1197				status = "disabled";
1198			};
1199
1200			spi2: spi@4a88000 {
1201				compatible = "qcom,geni-spi";
1202				reg = <0x0 0x04a88000 0x0 0x4000>;
1203				clock-names = "se";
1204				clocks = <&gcc GCC_QUPV3_WRAP0_S2_CLK>;
1205				interrupts = <GIC_SPI 329 IRQ_TYPE_LEVEL_HIGH>;
1206				power-domains = <&rpmpd SM6375_VDDCX>;
1207				operating-points-v2 = <&qup_opp_table>;
1208				dmas = <&gpi_dma0 0 2 QCOM_GPI_SPI>,
1209				       <&gpi_dma0 1 2 QCOM_GPI_SPI>;
1210				dma-names = "tx", "rx";
1211				#address-cells = <1>;
1212				#size-cells = <0>;
1213				status = "disabled";
1214			};
1215
1216			/*
1217			 * As per GCC, QUP3/4/5/11 also exist, but are not even defined downstream.
1218			 * There is a comment in the included DTSI of another SoC saying that they
1219			 * are not "bolled out" (probably meaning not routed to solder balls)
1220			 * TLMM driver however, suggests there are as many as 15 QUPs in total!
1221			 * Most of which don't even have pin configurations for.. Sad stuff!
1222			 */
1223		};
1224
1225		gpi_dma1: dma-controller@4c00000 {
1226			compatible = "qcom,sm6375-gpi-dma", "qcom,sm6350-gpi-dma";
1227			reg = <0 0x04c00000 0 0x60000>;
1228			interrupts = <GIC_SPI 497 IRQ_TYPE_LEVEL_HIGH>,
1229				     <GIC_SPI 498 IRQ_TYPE_LEVEL_HIGH>,
1230				     <GIC_SPI 499 IRQ_TYPE_LEVEL_HIGH>,
1231				     <GIC_SPI 500 IRQ_TYPE_LEVEL_HIGH>,
1232				     <GIC_SPI 501 IRQ_TYPE_LEVEL_HIGH>,
1233				     <GIC_SPI 502 IRQ_TYPE_LEVEL_HIGH>,
1234				     <GIC_SPI 503 IRQ_TYPE_LEVEL_HIGH>,
1235				     <GIC_SPI 504 IRQ_TYPE_LEVEL_HIGH>,
1236				     <GIC_SPI 505 IRQ_TYPE_LEVEL_HIGH>,
1237				     <GIC_SPI 506 IRQ_TYPE_LEVEL_HIGH>;
1238			dma-channels = <10>;
1239			dma-channel-mask = <0x1f>;
1240			iommus = <&apps_smmu 0xd6 0x0>;
1241			#dma-cells = <3>;
1242			status = "disabled";
1243		};
1244
1245		qupv3_id_1: geniqup@4cc0000 {
1246			compatible = "qcom,geni-se-qup";
1247			reg = <0x0 0x04cc0000 0x0 0x2000>;
1248			clock-names = "m-ahb", "s-ahb";
1249			clocks = <&gcc GCC_QUPV3_WRAP_1_M_AHB_CLK>,
1250				 <&gcc GCC_QUPV3_WRAP_1_S_AHB_CLK>;
1251			iommus = <&apps_smmu 0xc3 0x0>;
1252			#address-cells = <2>;
1253			#size-cells = <2>;
1254			ranges;
1255			status = "disabled";
1256
1257			i2c6: i2c@4c80000 {
1258				compatible = "qcom,geni-i2c";
1259				reg = <0x0 0x04c80000 0x0 0x4000>;
1260				clock-names = "se";
1261				clocks = <&gcc GCC_QUPV3_WRAP1_S0_CLK>;
1262				interrupts = <GIC_SPI 507 IRQ_TYPE_LEVEL_HIGH>;
1263				dmas = <&gpi_dma1 0 0 QCOM_GPI_I2C>,
1264				       <&gpi_dma1 1 0 QCOM_GPI_I2C>;
1265				dma-names = "tx", "rx";
1266				#address-cells = <1>;
1267				#size-cells = <0>;
1268				status = "disabled";
1269			};
1270
1271			spi6: spi@4c80000 {
1272				compatible = "qcom,geni-spi";
1273				reg = <0x0 0x04c80000 0x0 0x4000>;
1274				clock-names = "se";
1275				clocks = <&gcc GCC_QUPV3_WRAP1_S0_CLK>;
1276				interrupts = <GIC_SPI 507 IRQ_TYPE_LEVEL_HIGH>;
1277				power-domains = <&rpmpd SM6375_VDDCX>;
1278				operating-points-v2 = <&qup_opp_table>;
1279				dmas = <&gpi_dma1 0 0 QCOM_GPI_SPI>,
1280				       <&gpi_dma1 1 0 QCOM_GPI_SPI>;
1281				dma-names = "tx", "rx";
1282				#address-cells = <1>;
1283				#size-cells = <0>;
1284				status = "disabled";
1285			};
1286
1287			i2c7: i2c@4c84000 {
1288				compatible = "qcom,geni-i2c";
1289				reg = <0x0 0x04c84000 0x0 0x4000>;
1290				clock-names = "se";
1291				clocks = <&gcc GCC_QUPV3_WRAP1_S1_CLK>;
1292				interrupts = <GIC_SPI 508 IRQ_TYPE_LEVEL_HIGH>;
1293				dmas = <&gpi_dma1 0 1 QCOM_GPI_I2C>,
1294				       <&gpi_dma1 1 1 QCOM_GPI_I2C>;
1295				dma-names = "tx", "rx";
1296				#address-cells = <1>;
1297				#size-cells = <0>;
1298				status = "disabled";
1299			};
1300
1301			spi7: spi@4c84000 {
1302				compatible = "qcom,geni-spi";
1303				reg = <0x0 0x04c84000 0x0 0x4000>;
1304				clock-names = "se";
1305				clocks = <&gcc GCC_QUPV3_WRAP1_S1_CLK>;
1306				interrupts = <GIC_SPI 508 IRQ_TYPE_LEVEL_HIGH>;
1307				power-domains = <&rpmpd SM6375_VDDCX>;
1308				operating-points-v2 = <&qup_opp_table>;
1309				dmas = <&gpi_dma1 0 1 QCOM_GPI_SPI>,
1310				       <&gpi_dma1 1 1 QCOM_GPI_SPI>;
1311				dma-names = "tx", "rx";
1312				#address-cells = <1>;
1313				#size-cells = <0>;
1314				status = "disabled";
1315			};
1316
1317			i2c8: i2c@4c88000 {
1318				compatible = "qcom,geni-i2c";
1319				reg = <0x0 0x04c88000 0x0 0x4000>;
1320				clock-names = "se";
1321				clocks = <&gcc GCC_QUPV3_WRAP1_S2_CLK>;
1322				interrupts = <GIC_SPI 509 IRQ_TYPE_LEVEL_HIGH>;
1323				pinctrl-names = "default";
1324				pinctrl-0 = <&qup_i2c8_default>;
1325				dmas = <&gpi_dma1 0 2 QCOM_GPI_I2C>,
1326				       <&gpi_dma1 1 2 QCOM_GPI_I2C>;
1327				dma-names = "tx", "rx";
1328				#address-cells = <1>;
1329				#size-cells = <0>;
1330				status = "disabled";
1331			};
1332
1333			spi8: spi@4c88000 {
1334				compatible = "qcom,geni-spi";
1335				reg = <0x0 0x04c88000 0x0 0x4000>;
1336				clock-names = "se";
1337				clocks = <&gcc GCC_QUPV3_WRAP1_S2_CLK>;
1338				interrupts = <GIC_SPI 509 IRQ_TYPE_LEVEL_HIGH>;
1339				power-domains = <&rpmpd SM6375_VDDCX>;
1340				operating-points-v2 = <&qup_opp_table>;
1341				dmas = <&gpi_dma1 0 2 QCOM_GPI_SPI>,
1342				       <&gpi_dma1 1 2 QCOM_GPI_SPI>;
1343				dma-names = "tx", "rx";
1344				#address-cells = <1>;
1345				#size-cells = <0>;
1346				status = "disabled";
1347			};
1348
1349			i2c9: i2c@4c8c000 {
1350				compatible = "qcom,geni-i2c";
1351				reg = <0x0 0x04c8c000 0x0 0x4000>;
1352				clock-names = "se";
1353				clocks = <&gcc GCC_QUPV3_WRAP1_S3_CLK>;
1354				interrupts = <GIC_SPI 510 IRQ_TYPE_LEVEL_HIGH>;
1355				dmas = <&gpi_dma1 0 3 QCOM_GPI_I2C>,
1356				       <&gpi_dma1 1 3 QCOM_GPI_I2C>;
1357				dma-names = "tx", "rx";
1358				#address-cells = <1>;
1359				#size-cells = <0>;
1360				status = "disabled";
1361			};
1362
1363			spi9: spi@4c8c000 {
1364				compatible = "qcom,geni-spi";
1365				reg = <0x0 0x04c8c000 0x0 0x4000>;
1366				clock-names = "se";
1367				clocks = <&gcc GCC_QUPV3_WRAP1_S3_CLK>;
1368				interrupts = <GIC_SPI 510 IRQ_TYPE_LEVEL_HIGH>;
1369				power-domains = <&rpmpd SM6375_VDDCX>;
1370				operating-points-v2 = <&qup_opp_table>;
1371				dmas = <&gpi_dma1 0 3 QCOM_GPI_SPI>,
1372				       <&gpi_dma1 1 3 QCOM_GPI_SPI>;
1373				dma-names = "tx", "rx";
1374				#address-cells = <1>;
1375				#size-cells = <0>;
1376				status = "disabled";
1377			};
1378
1379			i2c10: i2c@4c90000 {
1380				compatible = "qcom,geni-i2c";
1381				reg = <0x0 0x04c90000 0x0 0x4000>;
1382				clock-names = "se";
1383				clocks = <&gcc GCC_QUPV3_WRAP1_S4_CLK>;
1384				interrupts = <GIC_SPI 511 IRQ_TYPE_LEVEL_HIGH>;
1385				pinctrl-names = "default";
1386				pinctrl-0 = <&qup_i2c10_default>;
1387				dmas = <&gpi_dma1 0 4 QCOM_GPI_I2C>,
1388				       <&gpi_dma1 1 4 QCOM_GPI_I2C>;
1389				dma-names = "tx", "rx";
1390				#address-cells = <1>;
1391				#size-cells = <0>;
1392				status = "disabled";
1393			};
1394
1395			spi10: spi@4c90000 {
1396				compatible = "qcom,geni-spi";
1397				reg = <0x0 0x04c90000 0x0 0x4000>;
1398				clock-names = "se";
1399				clocks = <&gcc GCC_QUPV3_WRAP1_S4_CLK>;
1400				interrupts = <GIC_SPI 511 IRQ_TYPE_LEVEL_HIGH>;
1401				power-domains = <&rpmpd SM6375_VDDCX>;
1402				operating-points-v2 = <&qup_opp_table>;
1403				dmas = <&gpi_dma1 0 4 QCOM_GPI_SPI>,
1404				       <&gpi_dma1 1 4 QCOM_GPI_SPI>;
1405				dma-names = "tx", "rx";
1406				#address-cells = <1>;
1407				#size-cells = <0>;
1408				status = "disabled";
1409			};
1410		};
1411
1412		usb_1: usb@4ef8800 {
1413			compatible = "qcom,sm6375-dwc3", "qcom,dwc3";
1414			reg = <0 0x04ef8800 0 0x400>;
1415
1416			clocks = <&gcc GCC_CFG_NOC_USB3_PRIM_AXI_CLK>,
1417				 <&gcc GCC_USB30_PRIM_MASTER_CLK>,
1418				 <&gcc GCC_SYS_NOC_USB3_PRIM_AXI_CLK>,
1419				 <&gcc GCC_USB30_PRIM_SLEEP_CLK>,
1420				 <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>,
1421				 <&gcc GCC_USB3_PRIM_CLKREF_CLK>;
1422			clock-names = "cfg_noc",
1423				      "core",
1424				      "iface",
1425				      "sleep",
1426				      "mock_utmi",
1427				      "xo";
1428
1429			assigned-clocks = <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>,
1430					  <&gcc GCC_USB30_PRIM_MASTER_CLK>;
1431			assigned-clock-rates = <19200000>, <133333333>;
1432
1433			interrupts-extended = <&intc GIC_SPI 302 IRQ_TYPE_LEVEL_HIGH>,
1434					      <&intc GIC_SPI 254 IRQ_TYPE_LEVEL_HIGH>,
1435					      <&mpm 94 IRQ_TYPE_EDGE_BOTH>,
1436					      <&mpm 93 IRQ_TYPE_EDGE_BOTH>,
1437					      <&mpm 12 IRQ_TYPE_LEVEL_HIGH>;
1438			interrupt-names = "pwr_event",
1439					  "hs_phy_irq",
1440					  "dp_hs_phy_irq",
1441					  "dm_hs_phy_irq",
1442					  "ss_phy_irq";
1443
1444			power-domains = <&gcc USB30_PRIM_GDSC>;
1445
1446			resets = <&gcc GCC_USB30_PRIM_BCR>;
1447
1448			/*
1449			 * This property is there to allow USB2 to work, as
1450			 * USB3 is not implemented yet - (re)move it when
1451			 * proper support is in place.
1452			 */
1453			qcom,select-utmi-as-pipe-clk;
1454
1455			#address-cells = <2>;
1456			#size-cells = <2>;
1457			ranges;
1458
1459			status = "disabled";
1460
1461			usb_1_dwc3: usb@4e00000 {
1462				compatible = "snps,dwc3";
1463				reg = <0 0x04e00000 0 0xcd00>;
1464				interrupts = <GIC_SPI 255 IRQ_TYPE_LEVEL_HIGH>;
1465				maximum-speed = "high-speed";
1466				phys = <&usb_1_hsphy>;
1467				phy-names = "usb2-phy";
1468				iommus = <&apps_smmu 0xe0 0x0>;
1469
1470				/* Yes, this impl *does* have an unfunny number of quirks.. */
1471				snps,hird-threshold = /bits/ 8 <0x10>;
1472				snps,usb2-gadget-lpm-disable;
1473				snps,dis_u2_susphy_quirk;
1474				snps,is-utmi-l1-suspend;
1475				snps,dis-u1-entry-quirk;
1476				snps,dis-u2-entry-quirk;
1477				snps,usb3_lpm_capable;
1478				snps,has-lpm-erratum;
1479				tx-fifo-resize;
1480			};
1481		};
1482
1483		adreno_smmu: iommu@5940000 {
1484			compatible = "qcom,sm6375-smmu-v2", "qcom,smmu-v2";
1485			reg = <0 0x05940000 0 0x10000>;
1486			#iommu-cells = <1>;
1487			#global-interrupts = <2>;
1488			interrupts = <GIC_SPI 379 IRQ_TYPE_LEVEL_HIGH>,
1489				     <GIC_SPI 381 IRQ_TYPE_LEVEL_HIGH>,
1490				     <GIC_SPI 457 IRQ_TYPE_LEVEL_HIGH>,
1491				     <GIC_SPI 458 IRQ_TYPE_LEVEL_HIGH>,
1492				     <GIC_SPI 459 IRQ_TYPE_LEVEL_HIGH>,
1493				     <GIC_SPI 460 IRQ_TYPE_LEVEL_HIGH>,
1494				     <GIC_SPI 461 IRQ_TYPE_LEVEL_HIGH>,
1495				     <GIC_SPI 462 IRQ_TYPE_LEVEL_HIGH>,
1496				     <GIC_SPI 463 IRQ_TYPE_LEVEL_HIGH>,
1497				     <GIC_SPI 464 IRQ_TYPE_LEVEL_HIGH>;
1498
1499			clocks = <&gcc GCC_GPU_MEMNOC_GFX_CLK>;
1500			clock-names = "bus";
1501
1502			power-domains = <&gpucc GPU_CX_GDSC>;
1503		};
1504
1505		gpucc: clock-controller@5990000 {
1506			compatible = "qcom,sm6375-gpucc";
1507			reg = <0 0x05990000 0 0x9000>;
1508			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>,
1509				 <&gcc GCC_GPU_GPLL0_CLK_SRC>,
1510				 <&gcc GCC_GPU_GPLL0_DIV_CLK_SRC>,
1511				 <&gcc GCC_GPU_SNOC_DVM_GFX_CLK>;
1512			power-domains = <&rpmpd SM6375_VDDGX>;
1513			required-opps = <&rpmpd_opp_low_svs>;
1514			#clock-cells = <1>;
1515			#reset-cells = <1>;
1516			#power-domain-cells = <1>;
1517		};
1518
1519		remoteproc_mss: remoteproc@6000000 {
1520			compatible = "qcom,sm6375-mpss-pas";
1521			reg = <0 0x06000000 0 0x4040>;
1522
1523			interrupts-extended = <&intc GIC_SPI 307 IRQ_TYPE_EDGE_RISING>,
1524					      <&smp2p_modem_in 0 IRQ_TYPE_EDGE_RISING>,
1525					      <&smp2p_modem_in 1 IRQ_TYPE_EDGE_RISING>,
1526					      <&smp2p_modem_in 2 IRQ_TYPE_EDGE_RISING>,
1527					      <&smp2p_modem_in 3 IRQ_TYPE_EDGE_RISING>,
1528					      <&smp2p_modem_in 7 IRQ_TYPE_EDGE_RISING>;
1529			interrupt-names = "wdog",
1530					  "fatal",
1531					  "ready",
1532					  "handover",
1533					  "stop-ack",
1534					  "shutdown-ack";
1535
1536			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>;
1537			clock-names = "xo";
1538
1539			power-domains = <&rpmpd SM6375_VDDCX>;
1540			power-domain-names = "cx";
1541
1542			memory-region = <&pil_mpss_wlan_mem>;
1543
1544			qcom,smem-states = <&smp2p_modem_out 0>;
1545			qcom,smem-state-names = "stop";
1546
1547			status = "disabled";
1548
1549			glink-edge {
1550				interrupts-extended = <&ipcc IPCC_CLIENT_MPSS
1551							     IPCC_MPROC_SIGNAL_GLINK_QMP
1552							     IRQ_TYPE_EDGE_RISING>;
1553				mboxes = <&ipcc IPCC_CLIENT_MPSS
1554						IPCC_MPROC_SIGNAL_GLINK_QMP>;
1555				label = "modem";
1556				qcom,remote-pid = <1>;
1557			};
1558		};
1559
1560		remoteproc_adsp: remoteproc@a400000 {
1561			compatible = "qcom,sm6375-adsp-pas";
1562			reg = <0 0x0a400000 0 0x100>;
1563
1564			interrupts-extended = <&intc GIC_SPI 282 IRQ_TYPE_EDGE_RISING>,
1565					      <&smp2p_adsp_in 0 IRQ_TYPE_EDGE_RISING>,
1566					      <&smp2p_adsp_in 1 IRQ_TYPE_EDGE_RISING>,
1567					      <&smp2p_adsp_in 2 IRQ_TYPE_EDGE_RISING>,
1568					      <&smp2p_adsp_in 3 IRQ_TYPE_EDGE_RISING>;
1569			interrupt-names = "wdog", "fatal", "ready",
1570					  "handover", "stop-ack";
1571
1572			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>;
1573			clock-names = "xo";
1574
1575			power-domains = <&rpmpd SM6375_VDD_LPI_CX>,
1576					<&rpmpd SM6375_VDD_LPI_MX>;
1577			power-domain-names = "lcx", "lmx";
1578
1579			memory-region = <&pil_adsp_mem>;
1580
1581			qcom,smem-states = <&smp2p_adsp_out 0>;
1582			qcom,smem-state-names = "stop";
1583
1584			status = "disabled";
1585
1586			glink-edge {
1587				interrupts-extended = <&ipcc IPCC_CLIENT_LPASS
1588							     IPCC_MPROC_SIGNAL_GLINK_QMP
1589							     IRQ_TYPE_EDGE_RISING>;
1590				mboxes = <&ipcc IPCC_CLIENT_LPASS
1591						IPCC_MPROC_SIGNAL_GLINK_QMP>;
1592
1593				label = "lpass";
1594				qcom,remote-pid = <2>;
1595			};
1596		};
1597
1598		remoteproc_cdsp: remoteproc@b000000 {
1599			compatible = "qcom,sm6375-cdsp-pas";
1600			reg = <0x0 0x0b000000 0x0 0x100000>;
1601
1602			interrupts-extended = <&intc GIC_SPI 265 IRQ_TYPE_EDGE_RISING>,
1603					      <&smp2p_cdsp_in 0 IRQ_TYPE_EDGE_RISING>,
1604					      <&smp2p_cdsp_in 1 IRQ_TYPE_EDGE_RISING>,
1605					      <&smp2p_cdsp_in 2 IRQ_TYPE_EDGE_RISING>,
1606					      <&smp2p_cdsp_in 3 IRQ_TYPE_EDGE_RISING>;
1607			interrupt-names = "wdog", "fatal", "ready",
1608					  "handover", "stop-ack";
1609
1610			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>;
1611			clock-names = "xo";
1612
1613			power-domains = <&rpmpd SM6375_VDDCX>;
1614			power-domain-names = "cx";
1615
1616			memory-region = <&pil_cdsp_mem>;
1617
1618			qcom,smem-states = <&smp2p_cdsp_out 0>;
1619			qcom,smem-state-names = "stop";
1620
1621			status = "disabled";
1622
1623			glink-edge {
1624				interrupts-extended = <&ipcc IPCC_CLIENT_CDSP
1625							     IPCC_MPROC_SIGNAL_GLINK_QMP
1626							     IRQ_TYPE_EDGE_RISING>;
1627				mboxes = <&ipcc IPCC_CLIENT_CDSP
1628						IPCC_MPROC_SIGNAL_GLINK_QMP>;
1629				label = "cdsp";
1630				qcom,remote-pid = <5>;
1631			};
1632		};
1633
1634		sram@c125000 {
1635			compatible = "qcom,sm6375-imem", "syscon", "simple-mfd";
1636			reg = <0 0x0c125000 0 0x1000>;
1637			ranges = <0 0 0x0c125000 0x1000>;
1638
1639			#address-cells = <1>;
1640			#size-cells = <1>;
1641
1642			pil-reloc@94c {
1643				compatible = "qcom,pil-reloc-info";
1644				reg = <0x94c 0xc8>;
1645			};
1646		};
1647
1648		apps_smmu: iommu@c600000 {
1649			compatible = "qcom,sm6375-smmu-500", "arm,mmu-500";
1650			reg = <0 0x0c600000 0 0x100000>;
1651			interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>,
1652				     <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>,
1653				     <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>,
1654				     <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>,
1655				     <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>,
1656				     <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>,
1657				     <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>,
1658				     <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>,
1659				     <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>,
1660				     <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>,
1661				     <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>,
1662				     <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>,
1663				     <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>,
1664				     <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
1665				     <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>,
1666				     <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>,
1667				     <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
1668				     <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
1669				     <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
1670				     <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
1671				     <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
1672				     <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
1673				     <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
1674				     <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
1675				     <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
1676				     <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
1677				     <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
1678				     <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
1679				     <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
1680				     <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
1681				     <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
1682				     <GIC_SPI 119 IRQ_TYPE_LEVEL_HIGH>,
1683				     <GIC_SPI 120 IRQ_TYPE_LEVEL_HIGH>,
1684				     <GIC_SPI 121 IRQ_TYPE_LEVEL_HIGH>,
1685				     <GIC_SPI 122 IRQ_TYPE_LEVEL_HIGH>,
1686				     <GIC_SPI 123 IRQ_TYPE_LEVEL_HIGH>,
1687				     <GIC_SPI 124 IRQ_TYPE_LEVEL_HIGH>,
1688				     <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>,
1689				     <GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>,
1690				     <GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
1691				     <GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>,
1692				     <GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>,
1693				     <GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>,
1694				     <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>,
1695				     <GIC_SPI 132 IRQ_TYPE_LEVEL_HIGH>,
1696				     <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>,
1697				     <GIC_SPI 134 IRQ_TYPE_LEVEL_HIGH>,
1698				     <GIC_SPI 135 IRQ_TYPE_LEVEL_HIGH>,
1699				     <GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>,
1700				     <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>,
1701				     <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>,
1702				     <GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>,
1703				     <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
1704				     <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
1705				     <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
1706				     <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>,
1707				     <GIC_SPI 144 IRQ_TYPE_LEVEL_HIGH>,
1708				     <GIC_SPI 145 IRQ_TYPE_LEVEL_HIGH>,
1709				     <GIC_SPI 146 IRQ_TYPE_LEVEL_HIGH>,
1710				     <GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>,
1711				     <GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>,
1712				     <GIC_SPI 149 IRQ_TYPE_LEVEL_HIGH>,
1713				     <GIC_SPI 150 IRQ_TYPE_LEVEL_HIGH>,
1714				     <GIC_SPI 151 IRQ_TYPE_LEVEL_HIGH>,
1715				     <GIC_SPI 152 IRQ_TYPE_LEVEL_HIGH>;
1716
1717			power-domains = <&gcc HLOS1_VOTE_MM_SNOC_MMU_TBU_RT_GDSC>,
1718					<&gcc HLOS1_VOTE_MM_SNOC_MMU_TBU_NRT_GDSC>,
1719					<&gcc HLOS1_VOTE_TURING_MMU_TBU0_GDSC>;
1720			#global-interrupts = <1>;
1721			#iommu-cells = <2>;
1722		};
1723
1724		wifi: wifi@c800000 {
1725			compatible = "qcom,wcn3990-wifi";
1726			reg = <0 0x0c800000 0 0x800000>;
1727			reg-names = "membase";
1728			memory-region = <&pil_wlan_mem>;
1729			interrupts = <GIC_SPI 358 IRQ_TYPE_LEVEL_HIGH>,
1730				     <GIC_SPI 359 IRQ_TYPE_LEVEL_HIGH>,
1731				     <GIC_SPI 360 IRQ_TYPE_LEVEL_HIGH>,
1732				     <GIC_SPI 361 IRQ_TYPE_LEVEL_HIGH>,
1733				     <GIC_SPI 362 IRQ_TYPE_LEVEL_HIGH>,
1734				     <GIC_SPI 363 IRQ_TYPE_LEVEL_HIGH>,
1735				     <GIC_SPI 364 IRQ_TYPE_LEVEL_HIGH>,
1736				     <GIC_SPI 365 IRQ_TYPE_LEVEL_HIGH>,
1737				     <GIC_SPI 366 IRQ_TYPE_LEVEL_HIGH>,
1738				     <GIC_SPI 367 IRQ_TYPE_LEVEL_HIGH>,
1739				     <GIC_SPI 368 IRQ_TYPE_LEVEL_HIGH>,
1740				     <GIC_SPI 369 IRQ_TYPE_LEVEL_HIGH>;
1741			iommus = <&apps_smmu 0x80 0x1>;
1742			qcom,msa-fixed-perm;
1743			status = "disabled";
1744		};
1745
1746		intc: interrupt-controller@f200000 {
1747			compatible = "arm,gic-v3";
1748			reg = <0x0 0x0f200000 0x0 0x10000>,  /* GICD */
1749			      <0x0 0x0f240000 0x0 0x100000>; /* GICR * 8 */
1750			interrupts = <GIC_PPI 8 IRQ_TYPE_LEVEL_HIGH>;
1751			#redistributor-regions = <1>;
1752			#interrupt-cells = <3>;
1753			redistributor-stride = <0 0x20000>;
1754			interrupt-controller;
1755		};
1756
1757		timer@f420000 {
1758			compatible = "arm,armv7-timer-mem";
1759			reg = <0 0x0f420000 0 0x1000>;
1760			ranges = <0 0 0 0x20000000>;
1761			#address-cells = <1>;
1762			#size-cells = <1>;
1763
1764			frame@f421000 {
1765				reg = <0x0f421000 0x1000>, <0x0f422000 0x1000>;
1766				interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>,
1767					     <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
1768				frame-number = <0>;
1769			};
1770
1771			frame@f423000 {
1772				reg = <0x0f243000 0x1000>;
1773				interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
1774				frame-number = <1>;
1775				status = "disabled";
1776			};
1777
1778			frame@f425000 {
1779				reg = <0x0f425000 0x1000>;
1780				interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
1781				frame-number = <2>;
1782				status = "disabled";
1783			};
1784
1785			frame@f427000 {
1786				reg = <0x0f427000 0x1000>;
1787				interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
1788				frame-number = <3>;
1789				status = "disabled";
1790			};
1791
1792			frame@f429000 {
1793				reg = <0x0f429000 0x1000>;
1794				interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
1795				frame-number = <4>;
1796				status = "disabled";
1797			};
1798
1799			frame@f42b000 {
1800				reg = <0x0f42b000 0x1000>;
1801				interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
1802				frame-number = <5>;
1803				status = "disabled";
1804			};
1805
1806			frame@f42d000 {
1807				reg = <0x0f42d000 0x1000>;
1808				interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
1809				frame-number = <6>;
1810				status = "disabled";
1811			};
1812		};
1813
1814		cpucp_l3: interconnect@fd90000 {
1815			compatible = "qcom,sm6375-cpucp-l3", "qcom,epss-l3";
1816			reg = <0 0x0fd90000 0 0x1000>;
1817
1818			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>, <&gcc GPLL0>;
1819			clock-names = "xo", "alternate";
1820			#interconnect-cells = <1>;
1821		};
1822
1823		cpufreq_hw: cpufreq@fd91000 {
1824			compatible = "qcom,sm6375-cpufreq-epss", "qcom,cpufreq-epss";
1825			reg = <0 0x0fd91000 0 0x1000>, <0 0x0fd92000 0 0x1000>;
1826			reg-names = "freq-domain0", "freq-domain1";
1827
1828			clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>, <&gcc GPLL0>;
1829			clock-names = "xo", "alternate";
1830			interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>,
1831				     <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
1832			interrupt-names = "dcvsh-irq-0", "dcvsh-irq-1";
1833			#freq-domain-cells = <1>;
1834			#clock-cells = <1>;
1835		};
1836	};
1837
1838	thermal-zones {
1839		mapss0-thermal {
1840			polling-delay-passive = <0>;
1841			polling-delay = <0>;
1842
1843			thermal-sensors = <&tsens0 0>;
1844
1845			trips {
1846				mapss0_alert0: trip-point0 {
1847					temperature = <90000>;
1848					hysteresis = <2000>;
1849					type = "passive";
1850				};
1851
1852				mapss0_alert1: trip-point1 {
1853					temperature = <95000>;
1854					hysteresis = <2000>;
1855					type = "passive";
1856				};
1857
1858				mapss0_crit: mapss-crit {
1859					temperature = <110000>;
1860					hysteresis = <1000>;
1861					type = "critical";
1862				};
1863			};
1864		};
1865
1866		cpu0-thermal {
1867			polling-delay-passive = <0>;
1868			polling-delay = <0>;
1869
1870			thermal-sensors = <&tsens0 1>;
1871
1872			trips {
1873				cpu0_alert0: trip-point0 {
1874					temperature = <90000>;
1875					hysteresis = <2000>;
1876					type = "passive";
1877				};
1878
1879				cpu0_alert1: trip-point1 {
1880					temperature = <95000>;
1881					hysteresis = <2000>;
1882					type = "passive";
1883				};
1884
1885				cpu0_crit: cpu-crit {
1886					temperature = <110000>;
1887					hysteresis = <1000>;
1888					type = "critical";
1889				};
1890			};
1891		};
1892
1893		cpu1-thermal {
1894			polling-delay-passive = <0>;
1895			polling-delay = <0>;
1896
1897			thermal-sensors = <&tsens0 2>;
1898
1899			trips {
1900				cpu1_alert0: trip-point0 {
1901					temperature = <90000>;
1902					hysteresis = <2000>;
1903					type = "passive";
1904				};
1905
1906				cpu1_alert1: trip-point1 {
1907					temperature = <95000>;
1908					hysteresis = <2000>;
1909					type = "passive";
1910				};
1911
1912				cpu1_crit: cpu-crit {
1913					temperature = <110000>;
1914					hysteresis = <1000>;
1915					type = "critical";
1916				};
1917			};
1918		};
1919
1920		cpu2-thermal {
1921			polling-delay-passive = <0>;
1922			polling-delay = <0>;
1923
1924			thermal-sensors = <&tsens0 3>;
1925
1926			trips {
1927				cpu2_alert0: trip-point0 {
1928					temperature = <90000>;
1929					hysteresis = <2000>;
1930					type = "passive";
1931				};
1932
1933				cpu2_alert1: trip-point1 {
1934					temperature = <95000>;
1935					hysteresis = <2000>;
1936					type = "passive";
1937				};
1938
1939				cpu2_crit: cpu-crit {
1940					temperature = <110000>;
1941					hysteresis = <1000>;
1942					type = "critical";
1943				};
1944			};
1945		};
1946
1947		cpu3-thermal {
1948			polling-delay-passive = <0>;
1949			polling-delay = <0>;
1950
1951			thermal-sensors = <&tsens0 4>;
1952
1953			trips {
1954				cpu3_alert0: trip-point0 {
1955					temperature = <90000>;
1956					hysteresis = <2000>;
1957					type = "passive";
1958				};
1959
1960				cpu3_alert1: trip-point1 {
1961					temperature = <95000>;
1962					hysteresis = <2000>;
1963					type = "passive";
1964				};
1965
1966				cpu3_crit: cpu-crit {
1967					temperature = <110000>;
1968					hysteresis = <1000>;
1969					type = "critical";
1970				};
1971			};
1972		};
1973
1974		cpu4-thermal {
1975			polling-delay-passive = <0>;
1976			polling-delay = <0>;
1977
1978			thermal-sensors = <&tsens0 5>;
1979
1980			trips {
1981				cpu4_alert0: trip-point0 {
1982					temperature = <90000>;
1983					hysteresis = <2000>;
1984					type = "passive";
1985				};
1986
1987				cpu4_alert1: trip-point1 {
1988					temperature = <95000>;
1989					hysteresis = <2000>;
1990					type = "passive";
1991				};
1992
1993				cpu4_crit: cpu-crit {
1994					temperature = <110000>;
1995					hysteresis = <1000>;
1996					type = "critical";
1997				};
1998			};
1999		};
2000
2001		cpu5-thermal {
2002			polling-delay-passive = <0>;
2003			polling-delay = <0>;
2004
2005			thermal-sensors = <&tsens0 6>;
2006
2007			trips {
2008				cpu5_alert0: trip-point0 {
2009					temperature = <90000>;
2010					hysteresis = <2000>;
2011					type = "passive";
2012				};
2013
2014				cpu5_alert1: trip-point1 {
2015					temperature = <95000>;
2016					hysteresis = <2000>;
2017					type = "passive";
2018				};
2019
2020				cpu5_crit: cpu-crit {
2021					temperature = <110000>;
2022					hysteresis = <1000>;
2023					type = "critical";
2024				};
2025			};
2026		};
2027
2028		cluster0-thermal {
2029			polling-delay-passive = <0>;
2030			polling-delay = <0>;
2031
2032			thermal-sensors = <&tsens0 7>;
2033
2034			trips {
2035				cluster0_alert0: trip-point0 {
2036					temperature = <90000>;
2037					hysteresis = <2000>;
2038					type = "passive";
2039				};
2040
2041				cluster0_alert1: trip-point1 {
2042					temperature = <95000>;
2043					hysteresis = <2000>;
2044					type = "passive";
2045				};
2046
2047				cluster0_crit: cpu-crit {
2048					temperature = <110000>;
2049					hysteresis = <1000>;
2050					type = "critical";
2051				};
2052			};
2053		};
2054
2055		cluster1-thermal {
2056			polling-delay-passive = <0>;
2057			polling-delay = <0>;
2058
2059			thermal-sensors = <&tsens0 8>;
2060
2061			trips {
2062				cluster1_alert0: trip-point0 {
2063					temperature = <90000>;
2064					hysteresis = <2000>;
2065					type = "passive";
2066				};
2067
2068				cluster1_alert1: trip-point1 {
2069					temperature = <95000>;
2070					hysteresis = <2000>;
2071					type = "passive";
2072				};
2073
2074				cluster1_crit: cpu-crit {
2075					temperature = <110000>;
2076					hysteresis = <1000>;
2077					type = "critical";
2078				};
2079			};
2080		};
2081
2082		cpu6-thermal {
2083			polling-delay-passive = <0>;
2084			polling-delay = <0>;
2085
2086			thermal-sensors = <&tsens0 9>;
2087
2088			trips {
2089				cpu6_alert0: trip-point0 {
2090					temperature = <90000>;
2091					hysteresis = <2000>;
2092					type = "passive";
2093				};
2094
2095				cpu6_alert1: trip-point1 {
2096					temperature = <95000>;
2097					hysteresis = <2000>;
2098					type = "passive";
2099				};
2100
2101				cpu6_crit: cpu-crit {
2102					temperature = <110000>;
2103					hysteresis = <1000>;
2104					type = "critical";
2105				};
2106			};
2107		};
2108
2109		cpu7-thermal {
2110			polling-delay-passive = <0>;
2111			polling-delay = <0>;
2112
2113			thermal-sensors = <&tsens0 10>;
2114
2115			trips {
2116				cpu7_alert0: trip-point0 {
2117					temperature = <90000>;
2118					hysteresis = <2000>;
2119					type = "passive";
2120				};
2121
2122				cpu7_alert1: trip-point1 {
2123					temperature = <95000>;
2124					hysteresis = <2000>;
2125					type = "passive";
2126				};
2127
2128				cpu7_crit: cpu-crit {
2129					temperature = <110000>;
2130					hysteresis = <1000>;
2131					type = "critical";
2132				};
2133			};
2134		};
2135
2136		cpu-unk0-thermal {
2137			polling-delay-passive = <0>;
2138			polling-delay = <0>;
2139
2140			thermal-sensors = <&tsens0 11>;
2141
2142			trips {
2143				cpu_unk0_alert0: trip-point0 {
2144					temperature = <90000>;
2145					hysteresis = <2000>;
2146					type = "passive";
2147				};
2148
2149				cpu_unk0_alert1: trip-point1 {
2150					temperature = <95000>;
2151					hysteresis = <2000>;
2152					type = "passive";
2153				};
2154
2155				cpu_unk0_crit: cpu-crit {
2156					temperature = <110000>;
2157					hysteresis = <1000>;
2158					type = "critical";
2159				};
2160			};
2161		};
2162
2163		cpu-unk1-thermal {
2164			polling-delay-passive = <0>;
2165			polling-delay = <0>;
2166
2167			thermal-sensors = <&tsens0 12>;
2168
2169			trips {
2170				cpu_unk1_alert0: trip-point0 {
2171					temperature = <90000>;
2172					hysteresis = <2000>;
2173					type = "passive";
2174				};
2175
2176				cpu_unk1_alert1: trip-point1 {
2177					temperature = <95000>;
2178					hysteresis = <2000>;
2179					type = "passive";
2180				};
2181
2182				cpu_unk1_crit: cpu-crit {
2183					temperature = <110000>;
2184					hysteresis = <1000>;
2185					type = "critical";
2186				};
2187			};
2188		};
2189
2190		gpuss0-thermal {
2191			polling-delay-passive = <0>;
2192			polling-delay = <0>;
2193
2194			thermal-sensors = <&tsens0 13>;
2195
2196			trips {
2197				gpuss0_alert0: trip-point0 {
2198					temperature = <90000>;
2199					hysteresis = <2000>;
2200					type = "passive";
2201				};
2202
2203				gpuss0_alert1: trip-point1 {
2204					temperature = <95000>;
2205					hysteresis = <2000>;
2206					type = "passive";
2207				};
2208
2209				gpuss0_crit: gpu-crit {
2210					temperature = <110000>;
2211					hysteresis = <1000>;
2212					type = "critical";
2213				};
2214			};
2215		};
2216
2217		gpuss1-thermal {
2218			polling-delay-passive = <0>;
2219			polling-delay = <0>;
2220
2221			thermal-sensors = <&tsens0 14>;
2222
2223			trips {
2224				gpuss1_alert0: trip-point0 {
2225					temperature = <90000>;
2226					hysteresis = <2000>;
2227					type = "passive";
2228				};
2229
2230				gpuss1_alert1: trip-point1 {
2231					temperature = <95000>;
2232					hysteresis = <2000>;
2233					type = "passive";
2234				};
2235
2236				gpuss1_crit: gpu-crit {
2237					temperature = <110000>;
2238					hysteresis = <1000>;
2239					type = "critical";
2240				};
2241			};
2242		};
2243
2244		mapss1-thermal {
2245			polling-delay-passive = <0>;
2246			polling-delay = <0>;
2247
2248			thermal-sensors = <&tsens1 0>;
2249
2250			trips {
2251				mapss1_alert0: trip-point0 {
2252					temperature = <90000>;
2253					hysteresis = <2000>;
2254					type = "passive";
2255				};
2256
2257				mapss1_alert1: trip-point1 {
2258					temperature = <95000>;
2259					hysteresis = <2000>;
2260					type = "passive";
2261				};
2262
2263				mapss1_crit: mapss-crit {
2264					temperature = <110000>;
2265					hysteresis = <1000>;
2266					type = "critical";
2267				};
2268			};
2269		};
2270
2271		cwlan-thermal {
2272			polling-delay-passive = <0>;
2273			polling-delay = <0>;
2274
2275			thermal-sensors = <&tsens1 1>;
2276
2277			trips {
2278				cwlan_alert0: trip-point0 {
2279					temperature = <90000>;
2280					hysteresis = <2000>;
2281					type = "passive";
2282				};
2283
2284				cwlan_alert1: trip-point1 {
2285					temperature = <95000>;
2286					hysteresis = <2000>;
2287					type = "passive";
2288				};
2289
2290				cwlan_crit: cwlan-crit {
2291					temperature = <110000>;
2292					hysteresis = <1000>;
2293					type = "critical";
2294				};
2295			};
2296		};
2297
2298		audio-thermal {
2299			polling-delay-passive = <0>;
2300			polling-delay = <0>;
2301
2302			thermal-sensors = <&tsens1 2>;
2303
2304			trips {
2305				audio_alert0: trip-point0 {
2306					temperature = <90000>;
2307					hysteresis = <2000>;
2308					type = "passive";
2309				};
2310
2311				audio_alert1: trip-point1 {
2312					temperature = <95000>;
2313					hysteresis = <2000>;
2314					type = "passive";
2315				};
2316
2317				audio_crit: audio-crit {
2318					temperature = <110000>;
2319					hysteresis = <1000>;
2320					type = "critical";
2321				};
2322			};
2323		};
2324
2325		ddr-thermal {
2326			polling-delay-passive = <0>;
2327			polling-delay = <0>;
2328
2329			thermal-sensors = <&tsens1 3>;
2330
2331			trips {
2332				ddr_alert0: trip-point0 {
2333					temperature = <90000>;
2334					hysteresis = <2000>;
2335					type = "passive";
2336				};
2337
2338				ddr_alert1: trip-point1 {
2339					temperature = <95000>;
2340					hysteresis = <2000>;
2341					type = "passive";
2342				};
2343
2344				ddr_crit: ddr-crit {
2345					temperature = <110000>;
2346					hysteresis = <1000>;
2347					type = "critical";
2348				};
2349			};
2350		};
2351
2352		q6hvx-thermal {
2353			polling-delay-passive = <0>;
2354			polling-delay = <0>;
2355
2356			thermal-sensors = <&tsens1 4>;
2357
2358			trips {
2359				q6hvx_alert0: trip-point0 {
2360					temperature = <90000>;
2361					hysteresis = <2000>;
2362					type = "passive";
2363				};
2364
2365				q6hvx_alert1: trip-point1 {
2366					temperature = <95000>;
2367					hysteresis = <2000>;
2368					type = "passive";
2369				};
2370
2371				q6hvx_crit: q6hvx-crit {
2372					temperature = <110000>;
2373					hysteresis = <1000>;
2374					type = "critical";
2375				};
2376			};
2377		};
2378
2379		camera-thermal {
2380			polling-delay-passive = <0>;
2381			polling-delay = <0>;
2382
2383			thermal-sensors = <&tsens1 5>;
2384
2385			trips {
2386				camera_alert0: trip-point0 {
2387					temperature = <90000>;
2388					hysteresis = <2000>;
2389					type = "passive";
2390				};
2391
2392				camera_alert1: trip-point1 {
2393					temperature = <95000>;
2394					hysteresis = <2000>;
2395					type = "passive";
2396				};
2397
2398				camera_crit: camera-crit {
2399					temperature = <110000>;
2400					hysteresis = <1000>;
2401					type = "critical";
2402				};
2403			};
2404		};
2405
2406		mdm-core0-thermal {
2407			polling-delay-passive = <0>;
2408			polling-delay = <0>;
2409
2410			thermal-sensors = <&tsens1 6>;
2411
2412			trips {
2413				mdm_core0_alert0: trip-point0 {
2414					temperature = <90000>;
2415					hysteresis = <2000>;
2416					type = "passive";
2417				};
2418
2419				mdm_core0_alert1: trip-point1 {
2420					temperature = <95000>;
2421					hysteresis = <2000>;
2422					type = "passive";
2423				};
2424
2425				mdm_core0_crit: mdm-core0-crit {
2426					temperature = <110000>;
2427					hysteresis = <1000>;
2428					type = "critical";
2429				};
2430			};
2431		};
2432
2433		mdm-core1-thermal {
2434			polling-delay-passive = <0>;
2435			polling-delay = <0>;
2436
2437			thermal-sensors = <&tsens1 7>;
2438
2439			trips {
2440				mdm_core1_alert0: trip-point0 {
2441					temperature = <90000>;
2442					hysteresis = <2000>;
2443					type = "passive";
2444				};
2445
2446				mdm_core1_alert1: trip-point1 {
2447					temperature = <95000>;
2448					hysteresis = <2000>;
2449					type = "passive";
2450				};
2451
2452				mdm_core1_crit: mdm-core1-crit {
2453					temperature = <110000>;
2454					hysteresis = <1000>;
2455					type = "critical";
2456				};
2457			};
2458		};
2459
2460		mdm-vec-thermal {
2461			polling-delay-passive = <0>;
2462			polling-delay = <0>;
2463
2464			thermal-sensors = <&tsens1 8>;
2465
2466			trips {
2467				mdm_vec_alert0: trip-point0 {
2468					temperature = <90000>;
2469					hysteresis = <2000>;
2470					type = "passive";
2471				};
2472
2473				mdm_vec_alert1: trip-point1 {
2474					temperature = <95000>;
2475					hysteresis = <2000>;
2476					type = "passive";
2477				};
2478
2479				mdm_vec_crit: mdm-vec-crit {
2480					temperature = <110000>;
2481					hysteresis = <1000>;
2482					type = "critical";
2483				};
2484			};
2485		};
2486
2487		msm-scl-thermal {
2488			polling-delay-passive = <0>;
2489			polling-delay = <0>;
2490
2491			thermal-sensors = <&tsens1 9>;
2492
2493			trips {
2494				msm_scl_alert0: trip-point0 {
2495					temperature = <90000>;
2496					hysteresis = <2000>;
2497					type = "passive";
2498				};
2499
2500				msm_scl_alert1: trip-point1 {
2501					temperature = <95000>;
2502					hysteresis = <2000>;
2503					type = "passive";
2504				};
2505
2506				msm_scl_crit: msm-scl-crit {
2507					temperature = <110000>;
2508					hysteresis = <1000>;
2509					type = "critical";
2510				};
2511			};
2512		};
2513
2514		video-thermal {
2515			polling-delay-passive = <0>;
2516			polling-delay = <0>;
2517
2518			thermal-sensors = <&tsens1 10>;
2519
2520			trips {
2521				video_alert0: trip-point0 {
2522					temperature = <90000>;
2523					hysteresis = <2000>;
2524					type = "passive";
2525				};
2526
2527				video_alert1: trip-point1 {
2528					temperature = <95000>;
2529					hysteresis = <2000>;
2530					type = "passive";
2531				};
2532
2533				video_crit: video-crit {
2534					temperature = <110000>;
2535					hysteresis = <1000>;
2536					type = "critical";
2537				};
2538			};
2539		};
2540	};
2541
2542	timer {
2543		compatible = "arm,armv8-timer";
2544		interrupts = <GIC_PPI 1 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
2545			     <GIC_PPI 2 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
2546			     <GIC_PPI 3 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
2547			     <GIC_PPI 0 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>;
2548	};
2549};
2550