blob: ee1ba5a8c8fc2fc25345f5b356b9f9f410f70b6a [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001// SPDX-License-Identifier: BSD-3-Clause
2/*
3 * Copyright (c) 2022, Linaro Limited
4 */
5
6#include <dt-bindings/clock/qcom,rpmh.h>
7#include <dt-bindings/clock/qcom,sm8450-videocc.h>
8#include <dt-bindings/clock/qcom,sm8550-camcc.h>
9#include <dt-bindings/clock/qcom,sm8550-gcc.h>
10#include <dt-bindings/clock/qcom,sm8550-gpucc.h>
11#include <dt-bindings/clock/qcom,sm8550-tcsr.h>
12#include <dt-bindings/clock/qcom,sm8550-dispcc.h>
13#include <dt-bindings/dma/qcom-gpi.h>
14#include <dt-bindings/firmware/qcom,scm.h>
15#include <dt-bindings/gpio/gpio.h>
16#include <dt-bindings/interrupt-controller/arm-gic.h>
17#include <dt-bindings/interconnect/qcom,sm8550-rpmh.h>
18#include <dt-bindings/mailbox/qcom-ipcc.h>
19#include <dt-bindings/power/qcom-rpmpd.h>
20#include <dt-bindings/power/qcom,rpmhpd.h>
21#include <dt-bindings/soc/qcom,gpr.h>
22#include <dt-bindings/soc/qcom,rpmh-rsc.h>
23#include <dt-bindings/sound/qcom,q6dsp-lpass-ports.h>
24#include <dt-bindings/phy/phy-qcom-qmp.h>
25#include <dt-bindings/thermal/thermal.h>
26
27/ {
28 interrupt-parent = <&intc>;
29
30 #address-cells = <2>;
31 #size-cells = <2>;
32
33 chosen { };
34
35 clocks {
36 xo_board: xo-board {
37 compatible = "fixed-clock";
38 #clock-cells = <0>;
39 };
40
41 sleep_clk: sleep-clk {
42 compatible = "fixed-clock";
43 #clock-cells = <0>;
44 };
45
46 bi_tcxo_div2: bi-tcxo-div2-clk {
47 #clock-cells = <0>;
48 compatible = "fixed-factor-clock";
49 clocks = <&rpmhcc RPMH_CXO_CLK>;
50 clock-mult = <1>;
51 clock-div = <2>;
52 };
53
54 bi_tcxo_ao_div2: bi-tcxo-ao-div2-clk {
55 #clock-cells = <0>;
56 compatible = "fixed-factor-clock";
57 clocks = <&rpmhcc RPMH_CXO_CLK_A>;
58 clock-mult = <1>;
59 clock-div = <2>;
60 };
61
62 pcie_1_phy_aux_clk: pcie-1-phy-aux-clk {
63 compatible = "fixed-clock";
64 #clock-cells = <0>;
65 };
66 };
67
68 cpus {
69 #address-cells = <2>;
70 #size-cells = <0>;
71
72 CPU0: cpu@0 {
73 device_type = "cpu";
74 compatible = "arm,cortex-a510";
75 reg = <0 0>;
76 clocks = <&cpufreq_hw 0>;
77 enable-method = "psci";
78 next-level-cache = <&L2_0>;
79 power-domains = <&CPU_PD0>;
80 power-domain-names = "psci";
81 qcom,freq-domain = <&cpufreq_hw 0>;
82 capacity-dmips-mhz = <1024>;
83 dynamic-power-coefficient = <100>;
84 #cooling-cells = <2>;
85 L2_0: l2-cache {
86 compatible = "cache";
87 cache-level = <2>;
88 cache-unified;
89 next-level-cache = <&L3_0>;
90 L3_0: l3-cache {
91 compatible = "cache";
92 cache-level = <3>;
93 cache-unified;
94 };
95 };
96 };
97
98 CPU1: cpu@100 {
99 device_type = "cpu";
100 compatible = "arm,cortex-a510";
101 reg = <0 0x100>;
102 clocks = <&cpufreq_hw 0>;
103 enable-method = "psci";
104 next-level-cache = <&L2_100>;
105 power-domains = <&CPU_PD1>;
106 power-domain-names = "psci";
107 qcom,freq-domain = <&cpufreq_hw 0>;
108 capacity-dmips-mhz = <1024>;
109 dynamic-power-coefficient = <100>;
110 #cooling-cells = <2>;
111 L2_100: l2-cache {
112 compatible = "cache";
113 cache-level = <2>;
114 cache-unified;
115 next-level-cache = <&L3_0>;
116 };
117 };
118
119 CPU2: cpu@200 {
120 device_type = "cpu";
121 compatible = "arm,cortex-a510";
122 reg = <0 0x200>;
123 clocks = <&cpufreq_hw 0>;
124 enable-method = "psci";
125 next-level-cache = <&L2_200>;
126 power-domains = <&CPU_PD2>;
127 power-domain-names = "psci";
128 qcom,freq-domain = <&cpufreq_hw 0>;
129 capacity-dmips-mhz = <1024>;
130 dynamic-power-coefficient = <100>;
131 #cooling-cells = <2>;
132 L2_200: l2-cache {
133 compatible = "cache";
134 cache-level = <2>;
135 cache-unified;
136 next-level-cache = <&L3_0>;
137 };
138 };
139
140 CPU3: cpu@300 {
141 device_type = "cpu";
142 compatible = "arm,cortex-a715";
143 reg = <0 0x300>;
144 clocks = <&cpufreq_hw 1>;
145 enable-method = "psci";
146 next-level-cache = <&L2_300>;
147 power-domains = <&CPU_PD3>;
148 power-domain-names = "psci";
149 qcom,freq-domain = <&cpufreq_hw 1>;
150 capacity-dmips-mhz = <1792>;
151 dynamic-power-coefficient = <270>;
152 #cooling-cells = <2>;
153 L2_300: l2-cache {
154 compatible = "cache";
155 cache-level = <2>;
156 cache-unified;
157 next-level-cache = <&L3_0>;
158 };
159 };
160
161 CPU4: cpu@400 {
162 device_type = "cpu";
163 compatible = "arm,cortex-a715";
164 reg = <0 0x400>;
165 clocks = <&cpufreq_hw 1>;
166 enable-method = "psci";
167 next-level-cache = <&L2_400>;
168 power-domains = <&CPU_PD4>;
169 power-domain-names = "psci";
170 qcom,freq-domain = <&cpufreq_hw 1>;
171 capacity-dmips-mhz = <1792>;
172 dynamic-power-coefficient = <270>;
173 #cooling-cells = <2>;
174 L2_400: l2-cache {
175 compatible = "cache";
176 cache-level = <2>;
177 cache-unified;
178 next-level-cache = <&L3_0>;
179 };
180 };
181
182 CPU5: cpu@500 {
183 device_type = "cpu";
184 compatible = "arm,cortex-a710";
185 reg = <0 0x500>;
186 clocks = <&cpufreq_hw 1>;
187 enable-method = "psci";
188 next-level-cache = <&L2_500>;
189 power-domains = <&CPU_PD5>;
190 power-domain-names = "psci";
191 qcom,freq-domain = <&cpufreq_hw 1>;
192 capacity-dmips-mhz = <1792>;
193 dynamic-power-coefficient = <270>;
194 #cooling-cells = <2>;
195 L2_500: l2-cache {
196 compatible = "cache";
197 cache-level = <2>;
198 cache-unified;
199 next-level-cache = <&L3_0>;
200 };
201 };
202
203 CPU6: cpu@600 {
204 device_type = "cpu";
205 compatible = "arm,cortex-a710";
206 reg = <0 0x600>;
207 clocks = <&cpufreq_hw 1>;
208 enable-method = "psci";
209 next-level-cache = <&L2_600>;
210 power-domains = <&CPU_PD6>;
211 power-domain-names = "psci";
212 qcom,freq-domain = <&cpufreq_hw 1>;
213 capacity-dmips-mhz = <1792>;
214 dynamic-power-coefficient = <270>;
215 #cooling-cells = <2>;
216 L2_600: l2-cache {
217 compatible = "cache";
218 cache-level = <2>;
219 cache-unified;
220 next-level-cache = <&L3_0>;
221 };
222 };
223
224 CPU7: cpu@700 {
225 device_type = "cpu";
226 compatible = "arm,cortex-x3";
227 reg = <0 0x700>;
228 clocks = <&cpufreq_hw 2>;
229 enable-method = "psci";
230 next-level-cache = <&L2_700>;
231 power-domains = <&CPU_PD7>;
232 power-domain-names = "psci";
233 qcom,freq-domain = <&cpufreq_hw 2>;
234 capacity-dmips-mhz = <1894>;
235 dynamic-power-coefficient = <588>;
236 #cooling-cells = <2>;
237 L2_700: l2-cache {
238 compatible = "cache";
239 cache-level = <2>;
240 cache-unified;
241 next-level-cache = <&L3_0>;
242 };
243 };
244
245 cpu-map {
246 cluster0 {
247 core0 {
248 cpu = <&CPU0>;
249 };
250
251 core1 {
252 cpu = <&CPU1>;
253 };
254
255 core2 {
256 cpu = <&CPU2>;
257 };
258
259 core3 {
260 cpu = <&CPU3>;
261 };
262
263 core4 {
264 cpu = <&CPU4>;
265 };
266
267 core5 {
268 cpu = <&CPU5>;
269 };
270
271 core6 {
272 cpu = <&CPU6>;
273 };
274
275 core7 {
276 cpu = <&CPU7>;
277 };
278 };
279 };
280
281 idle-states {
282 entry-method = "psci";
283
284 LITTLE_CPU_SLEEP_0: cpu-sleep-0-0 {
285 compatible = "arm,idle-state";
286 idle-state-name = "silver-rail-power-collapse";
287 arm,psci-suspend-param = <0x40000004>;
Tom Rini93743d22024-04-01 09:08:13 -0400288 entry-latency-us = <550>;
Tom Rini53633a82024-02-29 12:33:36 -0500289 exit-latency-us = <750>;
Tom Rini93743d22024-04-01 09:08:13 -0400290 min-residency-us = <6700>;
Tom Rini53633a82024-02-29 12:33:36 -0500291 local-timer-stop;
292 };
293
294 BIG_CPU_SLEEP_0: cpu-sleep-1-0 {
295 compatible = "arm,idle-state";
296 idle-state-name = "gold-rail-power-collapse";
297 arm,psci-suspend-param = <0x40000004>;
298 entry-latency-us = <600>;
Tom Rini93743d22024-04-01 09:08:13 -0400299 exit-latency-us = <1300>;
300 min-residency-us = <8136>;
Tom Rini53633a82024-02-29 12:33:36 -0500301 local-timer-stop;
302 };
Tom Rini93743d22024-04-01 09:08:13 -0400303
304 PRIME_CPU_SLEEP_0: cpu-sleep-2-0 {
305 compatible = "arm,idle-state";
306 idle-state-name = "goldplus-rail-power-collapse";
307 arm,psci-suspend-param = <0x40000004>;
308 entry-latency-us = <500>;
309 exit-latency-us = <1350>;
310 min-residency-us = <7480>;
311 local-timer-stop;
312 };
Tom Rini53633a82024-02-29 12:33:36 -0500313 };
314
315 domain-idle-states {
316 CLUSTER_SLEEP_0: cluster-sleep-0 {
317 compatible = "domain-idle-state";
318 arm,psci-suspend-param = <0x41000044>;
Tom Rini93743d22024-04-01 09:08:13 -0400319 entry-latency-us = <750>;
320 exit-latency-us = <2350>;
321 min-residency-us = <9144>;
Tom Rini53633a82024-02-29 12:33:36 -0500322 };
323
324 CLUSTER_SLEEP_1: cluster-sleep-1 {
325 compatible = "domain-idle-state";
326 arm,psci-suspend-param = <0x4100c344>;
Tom Rini93743d22024-04-01 09:08:13 -0400327 entry-latency-us = <2800>;
328 exit-latency-us = <4400>;
329 min-residency-us = <10150>;
Tom Rini53633a82024-02-29 12:33:36 -0500330 };
331 };
332 };
333
334 firmware {
335 scm: scm {
336 compatible = "qcom,scm-sm8550", "qcom,scm";
Tom Rini93743d22024-04-01 09:08:13 -0400337 qcom,dload-mode = <&tcsr 0x19000>;
Tom Rini53633a82024-02-29 12:33:36 -0500338 interconnects = <&aggre2_noc MASTER_CRYPTO 0 &mc_virt SLAVE_EBI1 0>;
339 };
340 };
341
342 clk_virt: interconnect-0 {
343 compatible = "qcom,sm8550-clk-virt";
344 #interconnect-cells = <2>;
345 qcom,bcm-voters = <&apps_bcm_voter>;
346 };
347
348 mc_virt: interconnect-1 {
349 compatible = "qcom,sm8550-mc-virt";
350 #interconnect-cells = <2>;
351 qcom,bcm-voters = <&apps_bcm_voter>;
352 };
353
354 memory@a0000000 {
355 device_type = "memory";
356 /* We expect the bootloader to fill in the size */
357 reg = <0 0xa0000000 0 0>;
358 };
359
360 pmu {
361 compatible = "arm,armv8-pmuv3";
362 interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_LOW>;
363 };
364
365 psci {
366 compatible = "arm,psci-1.0";
367 method = "smc";
368
369 CPU_PD0: power-domain-cpu0 {
370 #power-domain-cells = <0>;
371 power-domains = <&CLUSTER_PD>;
372 domain-idle-states = <&LITTLE_CPU_SLEEP_0>;
373 };
374
375 CPU_PD1: power-domain-cpu1 {
376 #power-domain-cells = <0>;
377 power-domains = <&CLUSTER_PD>;
378 domain-idle-states = <&LITTLE_CPU_SLEEP_0>;
379 };
380
381 CPU_PD2: power-domain-cpu2 {
382 #power-domain-cells = <0>;
383 power-domains = <&CLUSTER_PD>;
384 domain-idle-states = <&LITTLE_CPU_SLEEP_0>;
385 };
386
387 CPU_PD3: power-domain-cpu3 {
388 #power-domain-cells = <0>;
389 power-domains = <&CLUSTER_PD>;
390 domain-idle-states = <&BIG_CPU_SLEEP_0>;
391 };
392
393 CPU_PD4: power-domain-cpu4 {
394 #power-domain-cells = <0>;
395 power-domains = <&CLUSTER_PD>;
396 domain-idle-states = <&BIG_CPU_SLEEP_0>;
397 };
398
399 CPU_PD5: power-domain-cpu5 {
400 #power-domain-cells = <0>;
401 power-domains = <&CLUSTER_PD>;
402 domain-idle-states = <&BIG_CPU_SLEEP_0>;
403 };
404
405 CPU_PD6: power-domain-cpu6 {
406 #power-domain-cells = <0>;
407 power-domains = <&CLUSTER_PD>;
408 domain-idle-states = <&BIG_CPU_SLEEP_0>;
409 };
410
411 CPU_PD7: power-domain-cpu7 {
412 #power-domain-cells = <0>;
413 power-domains = <&CLUSTER_PD>;
Tom Rini93743d22024-04-01 09:08:13 -0400414 domain-idle-states = <&PRIME_CPU_SLEEP_0>;
Tom Rini53633a82024-02-29 12:33:36 -0500415 };
416
417 CLUSTER_PD: power-domain-cluster {
418 #power-domain-cells = <0>;
419 domain-idle-states = <&CLUSTER_SLEEP_0>, <&CLUSTER_SLEEP_1>;
420 };
421 };
422
423 reserved_memory: reserved-memory {
424 #address-cells = <2>;
425 #size-cells = <2>;
426 ranges;
427
428 hyp_mem: hyp-region@80000000 {
429 reg = <0 0x80000000 0 0xa00000>;
430 no-map;
431 };
432
433 cpusys_vm_mem: cpusys-vm-region@80a00000 {
434 reg = <0 0x80a00000 0 0x400000>;
435 no-map;
436 };
437
438 hyp_tags_mem: hyp-tags-region@80e00000 {
439 reg = <0 0x80e00000 0 0x3d0000>;
440 no-map;
441 };
442
443 xbl_sc_mem: xbl-sc-region@d8100000 {
444 reg = <0 0xd8100000 0 0x40000>;
445 no-map;
446 };
447
448 hyp_tags_reserved_mem: hyp-tags-reserved-region@811d0000 {
449 reg = <0 0x811d0000 0 0x30000>;
450 no-map;
451 };
452
453 /* merged xbl_dt_log, xbl_ramdump, aop_image */
454 xbl_dt_log_merged_mem: xbl-dt-log-merged-region@81a00000 {
455 reg = <0 0x81a00000 0 0x260000>;
456 no-map;
457 };
458
459 aop_cmd_db_mem: aop-cmd-db-region@81c60000 {
460 compatible = "qcom,cmd-db";
461 reg = <0 0x81c60000 0 0x20000>;
462 no-map;
463 };
464
465 /* merged aop_config, tme_crash_dump, tme_log, uefi_log */
466 aop_config_merged_mem: aop-config-merged-region@81c80000 {
467 reg = <0 0x81c80000 0 0x74000>;
468 no-map;
469 };
470
471 /* secdata region can be reused by apps */
472 smem: smem@81d00000 {
473 compatible = "qcom,smem";
474 reg = <0 0x81d00000 0 0x200000>;
475 hwlocks = <&tcsr_mutex 3>;
476 no-map;
477 };
478
479 adsp_mhi_mem: adsp-mhi-region@81f00000 {
480 reg = <0 0x81f00000 0 0x20000>;
481 no-map;
482 };
483
484 global_sync_mem: global-sync-region@82600000 {
485 reg = <0 0x82600000 0 0x100000>;
486 no-map;
487 };
488
489 tz_stat_mem: tz-stat-region@82700000 {
490 reg = <0 0x82700000 0 0x100000>;
491 no-map;
492 };
493
494 cdsp_secure_heap_mem: cdsp-secure-heap-region@82800000 {
495 reg = <0 0x82800000 0 0x4600000>;
496 no-map;
497 };
498
499 mpss_mem: mpss-region@8a800000 {
500 reg = <0 0x8a800000 0 0x10800000>;
501 no-map;
502 };
503
504 q6_mpss_dtb_mem: q6-mpss-dtb-region@9b000000 {
505 reg = <0 0x9b000000 0 0x80000>;
506 no-map;
507 };
508
509 ipa_fw_mem: ipa-fw-region@9b080000 {
510 reg = <0 0x9b080000 0 0x10000>;
511 no-map;
512 };
513
514 ipa_gsi_mem: ipa-gsi-region@9b090000 {
515 reg = <0 0x9b090000 0 0xa000>;
516 no-map;
517 };
518
519 gpu_micro_code_mem: gpu-micro-code-region@9b09a000 {
520 reg = <0 0x9b09a000 0 0x2000>;
521 no-map;
522 };
523
524 spss_region_mem: spss-region@9b100000 {
525 reg = <0 0x9b100000 0 0x180000>;
526 no-map;
527 };
528
529 /* First part of the "SPU secure shared memory" region */
530 spu_tz_shared_mem: spu-tz-shared-region@9b280000 {
531 reg = <0 0x9b280000 0 0x60000>;
532 no-map;
533 };
534
535 /* Second part of the "SPU secure shared memory" region */
536 spu_modem_shared_mem: spu-modem-shared-region@9b2e0000 {
537 reg = <0 0x9b2e0000 0 0x20000>;
538 no-map;
539 };
540
541 camera_mem: camera-region@9b300000 {
542 reg = <0 0x9b300000 0 0x800000>;
543 no-map;
544 };
545
546 video_mem: video-region@9bb00000 {
547 reg = <0 0x9bb00000 0 0x700000>;
548 no-map;
549 };
550
551 cvp_mem: cvp-region@9c200000 {
552 reg = <0 0x9c200000 0 0x700000>;
553 no-map;
554 };
555
556 cdsp_mem: cdsp-region@9c900000 {
557 reg = <0 0x9c900000 0 0x2000000>;
558 no-map;
559 };
560
561 q6_cdsp_dtb_mem: q6-cdsp-dtb-region@9e900000 {
562 reg = <0 0x9e900000 0 0x80000>;
563 no-map;
564 };
565
566 q6_adsp_dtb_mem: q6-adsp-dtb-region@9e980000 {
567 reg = <0 0x9e980000 0 0x80000>;
568 no-map;
569 };
570
571 adspslpi_mem: adspslpi-region@9ea00000 {
572 reg = <0 0x9ea00000 0 0x4080000>;
573 no-map;
574 };
575
576 /* uefi region can be reused by apps */
577
578 /* Linux kernel image is loaded at 0xa8000000 */
579
580 rmtfs_mem: rmtfs-region@d4a80000 {
581 compatible = "qcom,rmtfs-mem";
582 reg = <0x0 0xd4a80000 0x0 0x280000>;
583 no-map;
584
585 qcom,client-id = <1>;
586 qcom,vmid = <QCOM_SCM_VMID_MSS_MSA>;
587 };
588
589 mpss_dsm_mem: mpss-dsm-region@d4d00000 {
590 reg = <0 0xd4d00000 0 0x3300000>;
591 no-map;
592 };
593
594 tz_reserved_mem: tz-reserved-region@d8000000 {
595 reg = <0 0xd8000000 0 0x100000>;
596 no-map;
597 };
598
599 cpucp_fw_mem: cpucp-fw-region@d8140000 {
600 reg = <0 0xd8140000 0 0x1c0000>;
601 no-map;
602 };
603
604 qtee_mem: qtee-region@d8300000 {
605 reg = <0 0xd8300000 0 0x500000>;
606 no-map;
607 };
608
609 ta_mem: ta-region@d8800000 {
610 reg = <0 0xd8800000 0 0x8a00000>;
611 no-map;
612 };
613
614 tz_tags_mem: tz-tags-region@e1200000 {
615 reg = <0 0xe1200000 0 0x2740000>;
616 no-map;
617 };
618
619 hwfence_shbuf: hwfence-shbuf-region@e6440000 {
620 reg = <0 0xe6440000 0 0x279000>;
621 no-map;
622 };
623
624 trust_ui_vm_mem: trust-ui-vm-region@f3600000 {
625 reg = <0 0xf3600000 0 0x4aee000>;
626 no-map;
627 };
628
629 trust_ui_vm_dump: trust-ui-vm-dump-region@f80ee000 {
630 reg = <0 0xf80ee000 0 0x1000>;
631 no-map;
632 };
633
634 trust_ui_vm_qrtr: trust-ui-vm-qrt-region@f80ef000 {
635 reg = <0 0xf80ef000 0 0x9000>;
636 no-map;
637 };
638
639 trust_ui_vm_vblk0_ring: trust-ui-vm-vblk0-ring-region@f80f8000 {
640 reg = <0 0xf80f8000 0 0x4000>;
641 no-map;
642 };
643
644 trust_ui_vm_vblk1_ring: trust-ui-vm-vblk1-ring-region@f80fc000 {
645 reg = <0 0xf80fc000 0 0x4000>;
646 no-map;
647 };
648
649 trust_ui_vm_swiotlb: trust-ui-vm-swiotlb-region@f8100000 {
650 reg = <0 0xf8100000 0 0x100000>;
651 no-map;
652 };
653
654 oem_vm_mem: oem-vm-region@f8400000 {
655 reg = <0 0xf8400000 0 0x4800000>;
656 no-map;
657 };
658
659 oem_vm_vblk0_ring: oem-vm-vblk0-ring-region@fcc00000 {
660 reg = <0 0xfcc00000 0 0x4000>;
661 no-map;
662 };
663
664 oem_vm_swiotlb: oem-vm-swiotlb-region@fcc04000 {
665 reg = <0 0xfcc04000 0 0x100000>;
666 no-map;
667 };
668
669 hyp_ext_tags_mem: hyp-ext-tags-region@fce00000 {
670 reg = <0 0xfce00000 0 0x2900000>;
671 no-map;
672 };
673
674 hyp_ext_reserved_mem: hyp-ext-reserved-region@ff700000 {
675 reg = <0 0xff700000 0 0x100000>;
676 no-map;
677 };
678 };
679
680 smp2p-adsp {
681 compatible = "qcom,smp2p";
682 qcom,smem = <443>, <429>;
683 interrupts-extended = <&ipcc IPCC_CLIENT_LPASS
684 IPCC_MPROC_SIGNAL_SMP2P
685 IRQ_TYPE_EDGE_RISING>;
686 mboxes = <&ipcc IPCC_CLIENT_LPASS
687 IPCC_MPROC_SIGNAL_SMP2P>;
688
689 qcom,local-pid = <0>;
690 qcom,remote-pid = <2>;
691
692 smp2p_adsp_out: master-kernel {
693 qcom,entry-name = "master-kernel";
694 #qcom,smem-state-cells = <1>;
695 };
696
697 smp2p_adsp_in: slave-kernel {
698 qcom,entry-name = "slave-kernel";
699 interrupt-controller;
700 #interrupt-cells = <2>;
701 };
702 };
703
704 smp2p-cdsp {
705 compatible = "qcom,smp2p";
706 qcom,smem = <94>, <432>;
707 interrupts-extended = <&ipcc IPCC_CLIENT_CDSP
708 IPCC_MPROC_SIGNAL_SMP2P
709 IRQ_TYPE_EDGE_RISING>;
710 mboxes = <&ipcc IPCC_CLIENT_CDSP
711 IPCC_MPROC_SIGNAL_SMP2P>;
712
713 qcom,local-pid = <0>;
714 qcom,remote-pid = <5>;
715
716 smp2p_cdsp_out: master-kernel {
717 qcom,entry-name = "master-kernel";
718 #qcom,smem-state-cells = <1>;
719 };
720
721 smp2p_cdsp_in: slave-kernel {
722 qcom,entry-name = "slave-kernel";
723 interrupt-controller;
724 #interrupt-cells = <2>;
725 };
726 };
727
728 smp2p-modem {
729 compatible = "qcom,smp2p";
730 qcom,smem = <435>, <428>;
731 interrupts-extended = <&ipcc IPCC_CLIENT_MPSS
732 IPCC_MPROC_SIGNAL_SMP2P
733 IRQ_TYPE_EDGE_RISING>;
734 mboxes = <&ipcc IPCC_CLIENT_MPSS
735 IPCC_MPROC_SIGNAL_SMP2P>;
736
737 qcom,local-pid = <0>;
738 qcom,remote-pid = <1>;
739
740 smp2p_modem_out: master-kernel {
741 qcom,entry-name = "master-kernel";
742 #qcom,smem-state-cells = <1>;
743 };
744
745 smp2p_modem_in: slave-kernel {
746 qcom,entry-name = "slave-kernel";
747 interrupt-controller;
748 #interrupt-cells = <2>;
749 };
750
751 ipa_smp2p_out: ipa-ap-to-modem {
752 qcom,entry-name = "ipa";
753 #qcom,smem-state-cells = <1>;
754 };
755
756 ipa_smp2p_in: ipa-modem-to-ap {
757 qcom,entry-name = "ipa";
758 interrupt-controller;
759 #interrupt-cells = <2>;
760 };
761 };
762
763 soc: soc@0 {
764 compatible = "simple-bus";
765 ranges = <0 0 0 0 0x10 0>;
766 dma-ranges = <0 0 0 0 0x10 0>;
767
768 #address-cells = <2>;
769 #size-cells = <2>;
770
771 gcc: clock-controller@100000 {
772 compatible = "qcom,sm8550-gcc";
773 reg = <0 0x00100000 0 0x1f4200>;
774 #clock-cells = <1>;
775 #reset-cells = <1>;
776 #power-domain-cells = <1>;
777 clocks = <&bi_tcxo_div2>, <&sleep_clk>,
778 <&pcie0_phy>,
779 <&pcie1_phy>,
780 <&pcie_1_phy_aux_clk>,
781 <&ufs_mem_phy 0>,
782 <&ufs_mem_phy 1>,
783 <&ufs_mem_phy 2>,
784 <&usb_dp_qmpphy QMP_USB43DP_USB3_PIPE_CLK>;
785 };
786
787 ipcc: mailbox@408000 {
788 compatible = "qcom,sm8550-ipcc", "qcom,ipcc";
789 reg = <0 0x00408000 0 0x1000>;
790 interrupts = <GIC_SPI 229 IRQ_TYPE_LEVEL_HIGH>;
791 interrupt-controller;
792 #interrupt-cells = <3>;
793 #mbox-cells = <2>;
794 };
795
796 gpi_dma2: dma-controller@800000 {
797 compatible = "qcom,sm8550-gpi-dma", "qcom,sm6350-gpi-dma";
798 #dma-cells = <3>;
799 reg = <0 0x00800000 0 0x60000>;
800 interrupts = <GIC_SPI 588 IRQ_TYPE_LEVEL_HIGH>,
801 <GIC_SPI 589 IRQ_TYPE_LEVEL_HIGH>,
802 <GIC_SPI 590 IRQ_TYPE_LEVEL_HIGH>,
803 <GIC_SPI 591 IRQ_TYPE_LEVEL_HIGH>,
804 <GIC_SPI 592 IRQ_TYPE_LEVEL_HIGH>,
805 <GIC_SPI 593 IRQ_TYPE_LEVEL_HIGH>,
806 <GIC_SPI 594 IRQ_TYPE_LEVEL_HIGH>,
807 <GIC_SPI 595 IRQ_TYPE_LEVEL_HIGH>,
808 <GIC_SPI 596 IRQ_TYPE_LEVEL_HIGH>,
809 <GIC_SPI 597 IRQ_TYPE_LEVEL_HIGH>,
810 <GIC_SPI 598 IRQ_TYPE_LEVEL_HIGH>,
811 <GIC_SPI 599 IRQ_TYPE_LEVEL_HIGH>;
812 dma-channels = <12>;
813 dma-channel-mask = <0x3e>;
814 iommus = <&apps_smmu 0x436 0>;
815 status = "disabled";
816 };
817
818 qupv3_id_1: geniqup@8c0000 {
819 compatible = "qcom,geni-se-qup";
820 reg = <0 0x008c0000 0 0x2000>;
821 ranges;
822 clock-names = "m-ahb", "s-ahb";
823 clocks = <&gcc GCC_QUPV3_WRAP_2_M_AHB_CLK>,
824 <&gcc GCC_QUPV3_WRAP_2_S_AHB_CLK>;
825 iommus = <&apps_smmu 0x423 0>;
826 #address-cells = <2>;
827 #size-cells = <2>;
828 status = "disabled";
829
830 i2c8: i2c@880000 {
831 compatible = "qcom,geni-i2c";
832 reg = <0 0x00880000 0 0x4000>;
833 clock-names = "se";
834 clocks = <&gcc GCC_QUPV3_WRAP2_S0_CLK>;
835 pinctrl-names = "default";
836 pinctrl-0 = <&qup_i2c8_data_clk>;
837 interrupts = <GIC_SPI 373 IRQ_TYPE_LEVEL_HIGH>;
838 #address-cells = <1>;
839 #size-cells = <0>;
840 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
841 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
842 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
843 interconnect-names = "qup-core", "qup-config", "qup-memory";
844 dmas = <&gpi_dma2 0 0 QCOM_GPI_I2C>,
845 <&gpi_dma2 1 0 QCOM_GPI_I2C>;
846 dma-names = "tx", "rx";
847 status = "disabled";
848 };
849
850 spi8: spi@880000 {
851 compatible = "qcom,geni-spi";
852 reg = <0 0x00880000 0 0x4000>;
853 clock-names = "se";
854 clocks = <&gcc GCC_QUPV3_WRAP2_S0_CLK>;
855 interrupts = <GIC_SPI 373 IRQ_TYPE_LEVEL_HIGH>;
856 pinctrl-names = "default";
857 pinctrl-0 = <&qup_spi8_data_clk>, <&qup_spi8_cs>;
858 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
859 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
860 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
861 interconnect-names = "qup-core", "qup-config", "qup-memory";
862 dmas = <&gpi_dma2 0 0 QCOM_GPI_SPI>,
863 <&gpi_dma2 1 0 QCOM_GPI_SPI>;
864 dma-names = "tx", "rx";
865 #address-cells = <1>;
866 #size-cells = <0>;
867 status = "disabled";
868 };
869
870 i2c9: i2c@884000 {
871 compatible = "qcom,geni-i2c";
872 reg = <0 0x00884000 0 0x4000>;
873 clock-names = "se";
874 clocks = <&gcc GCC_QUPV3_WRAP2_S1_CLK>;
875 pinctrl-names = "default";
876 pinctrl-0 = <&qup_i2c9_data_clk>;
877 interrupts = <GIC_SPI 583 IRQ_TYPE_LEVEL_HIGH>;
878 #address-cells = <1>;
879 #size-cells = <0>;
880 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
881 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
882 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
883 interconnect-names = "qup-core", "qup-config", "qup-memory";
884 dmas = <&gpi_dma2 0 1 QCOM_GPI_I2C>,
885 <&gpi_dma2 1 1 QCOM_GPI_I2C>;
886 dma-names = "tx", "rx";
887 status = "disabled";
888 };
889
890 spi9: spi@884000 {
891 compatible = "qcom,geni-spi";
892 reg = <0 0x00884000 0 0x4000>;
893 clock-names = "se";
894 clocks = <&gcc GCC_QUPV3_WRAP2_S1_CLK>;
895 interrupts = <GIC_SPI 583 IRQ_TYPE_LEVEL_HIGH>;
896 pinctrl-names = "default";
897 pinctrl-0 = <&qup_spi9_data_clk>, <&qup_spi9_cs>;
898 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
899 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
900 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
901 interconnect-names = "qup-core", "qup-config", "qup-memory";
902 dmas = <&gpi_dma2 0 1 QCOM_GPI_SPI>,
903 <&gpi_dma2 1 1 QCOM_GPI_SPI>;
904 dma-names = "tx", "rx";
905 #address-cells = <1>;
906 #size-cells = <0>;
907 status = "disabled";
908 };
909
910 i2c10: i2c@888000 {
911 compatible = "qcom,geni-i2c";
912 reg = <0 0x00888000 0 0x4000>;
913 clock-names = "se";
914 clocks = <&gcc GCC_QUPV3_WRAP2_S2_CLK>;
915 pinctrl-names = "default";
916 pinctrl-0 = <&qup_i2c10_data_clk>;
917 interrupts = <GIC_SPI 584 IRQ_TYPE_LEVEL_HIGH>;
918 #address-cells = <1>;
919 #size-cells = <0>;
920 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
921 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
922 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
923 interconnect-names = "qup-core", "qup-config", "qup-memory";
924 dmas = <&gpi_dma2 0 2 QCOM_GPI_I2C>,
925 <&gpi_dma2 1 2 QCOM_GPI_I2C>;
926 dma-names = "tx", "rx";
927 status = "disabled";
928 };
929
930 spi10: spi@888000 {
931 compatible = "qcom,geni-spi";
932 reg = <0 0x00888000 0 0x4000>;
933 clock-names = "se";
934 clocks = <&gcc GCC_QUPV3_WRAP2_S2_CLK>;
935 interrupts = <GIC_SPI 584 IRQ_TYPE_LEVEL_HIGH>;
936 pinctrl-names = "default";
937 pinctrl-0 = <&qup_spi10_data_clk>, <&qup_spi10_cs>;
938 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
939 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
940 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
941 interconnect-names = "qup-core", "qup-config", "qup-memory";
942 dmas = <&gpi_dma2 0 2 QCOM_GPI_SPI>,
943 <&gpi_dma2 1 2 QCOM_GPI_SPI>;
944 dma-names = "tx", "rx";
945 #address-cells = <1>;
946 #size-cells = <0>;
947 status = "disabled";
948 };
949
950 i2c11: i2c@88c000 {
951 compatible = "qcom,geni-i2c";
952 reg = <0 0x0088c000 0 0x4000>;
953 clock-names = "se";
954 clocks = <&gcc GCC_QUPV3_WRAP2_S3_CLK>;
955 pinctrl-names = "default";
956 pinctrl-0 = <&qup_i2c11_data_clk>;
957 interrupts = <GIC_SPI 585 IRQ_TYPE_LEVEL_HIGH>;
958 #address-cells = <1>;
959 #size-cells = <0>;
960 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
961 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
962 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
963 interconnect-names = "qup-core", "qup-config", "qup-memory";
964 dmas = <&gpi_dma2 0 3 QCOM_GPI_I2C>,
965 <&gpi_dma2 1 3 QCOM_GPI_I2C>;
966 dma-names = "tx", "rx";
967 status = "disabled";
968 };
969
970 spi11: spi@88c000 {
971 compatible = "qcom,geni-spi";
972 reg = <0 0x0088c000 0 0x4000>;
973 clock-names = "se";
974 clocks = <&gcc GCC_QUPV3_WRAP2_S3_CLK>;
975 interrupts = <GIC_SPI 585 IRQ_TYPE_LEVEL_HIGH>;
976 pinctrl-names = "default";
977 pinctrl-0 = <&qup_spi11_data_clk>, <&qup_spi11_cs>;
978 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
979 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
980 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
981 interconnect-names = "qup-core", "qup-config", "qup-memory";
982 dmas = <&gpi_dma2 0 3 QCOM_GPI_I2C>,
983 <&gpi_dma2 1 3 QCOM_GPI_I2C>;
984 dma-names = "tx", "rx";
985 #address-cells = <1>;
986 #size-cells = <0>;
987 status = "disabled";
988 };
989
990 i2c12: i2c@890000 {
991 compatible = "qcom,geni-i2c";
992 reg = <0 0x00890000 0 0x4000>;
993 clock-names = "se";
994 clocks = <&gcc GCC_QUPV3_WRAP2_S4_CLK>;
995 pinctrl-names = "default";
996 pinctrl-0 = <&qup_i2c12_data_clk>;
997 interrupts = <GIC_SPI 586 IRQ_TYPE_LEVEL_HIGH>;
998 #address-cells = <1>;
999 #size-cells = <0>;
1000 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
1001 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
1002 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
1003 interconnect-names = "qup-core", "qup-config", "qup-memory";
1004 dmas = <&gpi_dma2 0 4 QCOM_GPI_I2C>,
1005 <&gpi_dma2 1 4 QCOM_GPI_I2C>;
1006 dma-names = "tx", "rx";
1007 status = "disabled";
1008 };
1009
1010 spi12: spi@890000 {
1011 compatible = "qcom,geni-spi";
1012 reg = <0 0x00890000 0 0x4000>;
1013 clock-names = "se";
1014 clocks = <&gcc GCC_QUPV3_WRAP2_S4_CLK>;
1015 interrupts = <GIC_SPI 586 IRQ_TYPE_LEVEL_HIGH>;
1016 pinctrl-names = "default";
1017 pinctrl-0 = <&qup_spi12_data_clk>, <&qup_spi12_cs>;
1018 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
1019 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
1020 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
1021 interconnect-names = "qup-core", "qup-config", "qup-memory";
1022 dmas = <&gpi_dma2 0 4 QCOM_GPI_I2C>,
1023 <&gpi_dma2 1 4 QCOM_GPI_I2C>;
1024 dma-names = "tx", "rx";
1025 #address-cells = <1>;
1026 #size-cells = <0>;
1027 status = "disabled";
1028 };
1029
1030 i2c13: i2c@894000 {
1031 compatible = "qcom,geni-i2c";
1032 reg = <0 0x00894000 0 0x4000>;
1033 clock-names = "se";
1034 clocks = <&gcc GCC_QUPV3_WRAP2_S5_CLK>;
1035 pinctrl-names = "default";
1036 pinctrl-0 = <&qup_i2c13_data_clk>;
1037 interrupts = <GIC_SPI 587 IRQ_TYPE_LEVEL_HIGH>;
1038 #address-cells = <1>;
1039 #size-cells = <0>;
1040 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
1041 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
1042 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
1043 interconnect-names = "qup-core", "qup-config", "qup-memory";
1044 dmas = <&gpi_dma2 0 5 QCOM_GPI_I2C>,
1045 <&gpi_dma2 1 5 QCOM_GPI_I2C>;
1046 dma-names = "tx", "rx";
1047 status = "disabled";
1048 };
1049
1050 spi13: spi@894000 {
1051 compatible = "qcom,geni-spi";
1052 reg = <0 0x00894000 0 0x4000>;
1053 clock-names = "se";
1054 clocks = <&gcc GCC_QUPV3_WRAP2_S5_CLK>;
1055 interrupts = <GIC_SPI 587 IRQ_TYPE_LEVEL_HIGH>;
1056 pinctrl-names = "default";
1057 pinctrl-0 = <&qup_spi13_data_clk>, <&qup_spi13_cs>;
1058 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
1059 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
1060 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
1061 interconnect-names = "qup-core", "qup-config", "qup-memory";
1062 dmas = <&gpi_dma2 0 5 QCOM_GPI_SPI>,
1063 <&gpi_dma2 1 5 QCOM_GPI_SPI>;
1064 dma-names = "tx", "rx";
1065 #address-cells = <1>;
1066 #size-cells = <0>;
1067 status = "disabled";
1068 };
1069
1070 uart14: serial@898000 {
1071 compatible = "qcom,geni-uart";
1072 reg = <0 0x898000 0 0x4000>;
1073 clock-names = "se";
1074 clocks = <&gcc GCC_QUPV3_WRAP2_S6_CLK>;
1075 pinctrl-names = "default";
1076 pinctrl-0 = <&qup_uart14_default>, <&qup_uart14_cts_rts>;
1077 interrupts = <GIC_SPI 461 IRQ_TYPE_LEVEL_HIGH>;
1078 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
1079 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>;
1080 interconnect-names = "qup-core", "qup-config";
1081 status = "disabled";
1082 };
1083
1084 i2c15: i2c@89c000 {
1085 compatible = "qcom,geni-i2c";
1086 reg = <0 0x0089c000 0 0x4000>;
1087 clock-names = "se";
1088 clocks = <&gcc GCC_QUPV3_WRAP2_S7_CLK>;
1089 pinctrl-names = "default";
1090 pinctrl-0 = <&qup_i2c15_data_clk>;
1091 interrupts = <GIC_SPI 462 IRQ_TYPE_LEVEL_HIGH>;
1092 #address-cells = <1>;
1093 #size-cells = <0>;
1094 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
1095 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
1096 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
1097 interconnect-names = "qup-core", "qup-config", "qup-memory";
1098 dmas = <&gpi_dma2 0 7 QCOM_GPI_I2C>,
1099 <&gpi_dma2 1 7 QCOM_GPI_I2C>;
1100 dma-names = "tx", "rx";
1101 status = "disabled";
1102 };
1103
1104 spi15: spi@89c000 {
1105 compatible = "qcom,geni-spi";
1106 reg = <0 0x0089c000 0 0x4000>;
1107 clock-names = "se";
1108 clocks = <&gcc GCC_QUPV3_WRAP2_S7_CLK>;
1109 interrupts = <GIC_SPI 462 IRQ_TYPE_LEVEL_HIGH>;
1110 pinctrl-names = "default";
1111 pinctrl-0 = <&qup_spi15_data_clk>, <&qup_spi15_cs>;
1112 interconnects = <&clk_virt MASTER_QUP_CORE_2 0 &clk_virt SLAVE_QUP_CORE_2 0>,
1113 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_2 0>,
1114 <&aggre2_noc MASTER_QUP_2 0 &mc_virt SLAVE_EBI1 0>;
1115 interconnect-names = "qup-core", "qup-config", "qup-memory";
1116 dmas = <&gpi_dma2 0 7 QCOM_GPI_SPI>,
1117 <&gpi_dma2 1 7 QCOM_GPI_SPI>;
1118 dma-names = "tx", "rx";
1119 #address-cells = <1>;
1120 #size-cells = <0>;
1121 status = "disabled";
1122 };
1123 };
1124
1125 i2c_master_hub_0: geniqup@9c0000 {
1126 compatible = "qcom,geni-se-i2c-master-hub";
1127 reg = <0x0 0x009c0000 0x0 0x2000>;
1128 clock-names = "s-ahb";
1129 clocks = <&gcc GCC_QUPV3_I2C_S_AHB_CLK>;
1130 #address-cells = <2>;
1131 #size-cells = <2>;
1132 ranges;
1133 status = "disabled";
1134
1135 i2c_hub_0: i2c@980000 {
1136 compatible = "qcom,geni-i2c-master-hub";
1137 reg = <0x0 0x00980000 0x0 0x4000>;
1138 clock-names = "se", "core";
1139 clocks = <&gcc GCC_QUPV3_I2C_S0_CLK>,
1140 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1141 pinctrl-names = "default";
1142 pinctrl-0 = <&hub_i2c0_data_clk>;
1143 interrupts = <GIC_SPI 464 IRQ_TYPE_LEVEL_HIGH>;
1144 #address-cells = <1>;
1145 #size-cells = <0>;
1146 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1147 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1148 interconnect-names = "qup-core", "qup-config";
1149 status = "disabled";
1150 };
1151
1152 i2c_hub_1: i2c@984000 {
1153 compatible = "qcom,geni-i2c-master-hub";
1154 reg = <0x0 0x00984000 0x0 0x4000>;
1155 clock-names = "se", "core";
1156 clocks = <&gcc GCC_QUPV3_I2C_S1_CLK>,
1157 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1158 pinctrl-names = "default";
1159 pinctrl-0 = <&hub_i2c1_data_clk>;
1160 interrupts = <GIC_SPI 465 IRQ_TYPE_LEVEL_HIGH>;
1161 #address-cells = <1>;
1162 #size-cells = <0>;
1163 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1164 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1165 interconnect-names = "qup-core", "qup-config";
1166 status = "disabled";
1167 };
1168
1169 i2c_hub_2: i2c@988000 {
1170 compatible = "qcom,geni-i2c-master-hub";
1171 reg = <0x0 0x00988000 0x0 0x4000>;
1172 clock-names = "se", "core";
1173 clocks = <&gcc GCC_QUPV3_I2C_S2_CLK>,
1174 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1175 pinctrl-names = "default";
1176 pinctrl-0 = <&hub_i2c2_data_clk>;
1177 interrupts = <GIC_SPI 466 IRQ_TYPE_LEVEL_HIGH>;
1178 #address-cells = <1>;
1179 #size-cells = <0>;
1180 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1181 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1182 interconnect-names = "qup-core", "qup-config";
1183 status = "disabled";
1184 };
1185
1186 i2c_hub_3: i2c@98c000 {
1187 compatible = "qcom,geni-i2c-master-hub";
1188 reg = <0x0 0x0098c000 0x0 0x4000>;
1189 clock-names = "se", "core";
1190 clocks = <&gcc GCC_QUPV3_I2C_S3_CLK>,
1191 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1192 pinctrl-names = "default";
1193 pinctrl-0 = <&hub_i2c3_data_clk>;
1194 interrupts = <GIC_SPI 467 IRQ_TYPE_LEVEL_HIGH>;
1195 #address-cells = <1>;
1196 #size-cells = <0>;
1197 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1198 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1199 interconnect-names = "qup-core", "qup-config";
1200 status = "disabled";
1201 };
1202
1203 i2c_hub_4: i2c@990000 {
1204 compatible = "qcom,geni-i2c-master-hub";
1205 reg = <0x0 0x00990000 0x0 0x4000>;
1206 clock-names = "se", "core";
1207 clocks = <&gcc GCC_QUPV3_I2C_S4_CLK>,
1208 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1209 pinctrl-names = "default";
1210 pinctrl-0 = <&hub_i2c4_data_clk>;
1211 interrupts = <GIC_SPI 468 IRQ_TYPE_LEVEL_HIGH>;
1212 #address-cells = <1>;
1213 #size-cells = <0>;
1214 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1215 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1216 interconnect-names = "qup-core", "qup-config";
1217 status = "disabled";
1218 };
1219
1220 i2c_hub_5: i2c@994000 {
1221 compatible = "qcom,geni-i2c-master-hub";
1222 reg = <0 0x00994000 0 0x4000>;
1223 clock-names = "se", "core";
1224 clocks = <&gcc GCC_QUPV3_I2C_S5_CLK>,
1225 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1226 pinctrl-names = "default";
1227 pinctrl-0 = <&hub_i2c5_data_clk>;
1228 interrupts = <GIC_SPI 469 IRQ_TYPE_LEVEL_HIGH>;
1229 #address-cells = <1>;
1230 #size-cells = <0>;
1231 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1232 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1233 interconnect-names = "qup-core", "qup-config";
1234 status = "disabled";
1235 };
1236
1237 i2c_hub_6: i2c@998000 {
1238 compatible = "qcom,geni-i2c-master-hub";
1239 reg = <0 0x00998000 0 0x4000>;
1240 clock-names = "se", "core";
1241 clocks = <&gcc GCC_QUPV3_I2C_S6_CLK>,
1242 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1243 pinctrl-names = "default";
1244 pinctrl-0 = <&hub_i2c6_data_clk>;
1245 interrupts = <GIC_SPI 470 IRQ_TYPE_LEVEL_HIGH>;
1246 #address-cells = <1>;
1247 #size-cells = <0>;
1248 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1249 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1250 interconnect-names = "qup-core", "qup-config";
1251 status = "disabled";
1252 };
1253
1254 i2c_hub_7: i2c@99c000 {
1255 compatible = "qcom,geni-i2c-master-hub";
1256 reg = <0 0x0099c000 0 0x4000>;
1257 clock-names = "se", "core";
1258 clocks = <&gcc GCC_QUPV3_I2C_S7_CLK>,
1259 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1260 pinctrl-names = "default";
1261 pinctrl-0 = <&hub_i2c7_data_clk>;
1262 interrupts = <GIC_SPI 471 IRQ_TYPE_LEVEL_HIGH>;
1263 #address-cells = <1>;
1264 #size-cells = <0>;
1265 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1266 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1267 interconnect-names = "qup-core", "qup-config";
1268 status = "disabled";
1269 };
1270
1271 i2c_hub_8: i2c@9a0000 {
1272 compatible = "qcom,geni-i2c-master-hub";
1273 reg = <0 0x009a0000 0 0x4000>;
1274 clock-names = "se", "core";
1275 clocks = <&gcc GCC_QUPV3_I2C_S8_CLK>,
1276 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1277 pinctrl-names = "default";
1278 pinctrl-0 = <&hub_i2c8_data_clk>;
1279 interrupts = <GIC_SPI 472 IRQ_TYPE_LEVEL_HIGH>;
1280 #address-cells = <1>;
1281 #size-cells = <0>;
1282 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1283 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1284 interconnect-names = "qup-core", "qup-config";
1285 status = "disabled";
1286 };
1287
1288 i2c_hub_9: i2c@9a4000 {
1289 compatible = "qcom,geni-i2c-master-hub";
1290 reg = <0 0x009a4000 0 0x4000>;
1291 clock-names = "se", "core";
1292 clocks = <&gcc GCC_QUPV3_I2C_S9_CLK>,
1293 <&gcc GCC_QUPV3_I2C_CORE_CLK>;
1294 pinctrl-names = "default";
1295 pinctrl-0 = <&hub_i2c9_data_clk>;
1296 interrupts = <GIC_SPI 473 IRQ_TYPE_LEVEL_HIGH>;
1297 #address-cells = <1>;
1298 #size-cells = <0>;
1299 interconnects = <&clk_virt MASTER_QUP_CORE_0 0 &clk_virt SLAVE_QUP_CORE_0 0>,
1300 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_I2C 0>;
1301 interconnect-names = "qup-core", "qup-config";
1302 status = "disabled";
1303 };
1304 };
1305
1306 gpi_dma1: dma-controller@a00000 {
1307 compatible = "qcom,sm8550-gpi-dma", "qcom,sm6350-gpi-dma";
1308 #dma-cells = <3>;
1309 reg = <0 0x00a00000 0 0x60000>;
1310 interrupts = <GIC_SPI 279 IRQ_TYPE_LEVEL_HIGH>,
1311 <GIC_SPI 280 IRQ_TYPE_LEVEL_HIGH>,
1312 <GIC_SPI 281 IRQ_TYPE_LEVEL_HIGH>,
1313 <GIC_SPI 282 IRQ_TYPE_LEVEL_HIGH>,
1314 <GIC_SPI 283 IRQ_TYPE_LEVEL_HIGH>,
1315 <GIC_SPI 284 IRQ_TYPE_LEVEL_HIGH>,
1316 <GIC_SPI 293 IRQ_TYPE_LEVEL_HIGH>,
1317 <GIC_SPI 294 IRQ_TYPE_LEVEL_HIGH>,
1318 <GIC_SPI 295 IRQ_TYPE_LEVEL_HIGH>,
1319 <GIC_SPI 296 IRQ_TYPE_LEVEL_HIGH>,
1320 <GIC_SPI 297 IRQ_TYPE_LEVEL_HIGH>,
1321 <GIC_SPI 298 IRQ_TYPE_LEVEL_HIGH>;
1322 dma-channels = <12>;
1323 dma-channel-mask = <0x1e>;
1324 iommus = <&apps_smmu 0xb6 0>;
1325 status = "disabled";
1326 };
1327
1328 qupv3_id_0: geniqup@ac0000 {
1329 compatible = "qcom,geni-se-qup";
1330 reg = <0 0x00ac0000 0 0x2000>;
1331 ranges;
1332 clock-names = "m-ahb", "s-ahb";
1333 clocks = <&gcc GCC_QUPV3_WRAP_1_M_AHB_CLK>,
1334 <&gcc GCC_QUPV3_WRAP_1_S_AHB_CLK>;
1335 iommus = <&apps_smmu 0xa3 0>;
1336 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>;
1337 interconnect-names = "qup-core";
1338 #address-cells = <2>;
1339 #size-cells = <2>;
1340 status = "disabled";
1341
1342 i2c0: i2c@a80000 {
1343 compatible = "qcom,geni-i2c";
1344 reg = <0 0x00a80000 0 0x4000>;
1345 clock-names = "se";
1346 clocks = <&gcc GCC_QUPV3_WRAP1_S0_CLK>;
1347 pinctrl-names = "default";
1348 pinctrl-0 = <&qup_i2c0_data_clk>;
1349 interrupts = <GIC_SPI 353 IRQ_TYPE_LEVEL_HIGH>;
1350 #address-cells = <1>;
1351 #size-cells = <0>;
1352 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1353 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1354 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1355 interconnect-names = "qup-core", "qup-config", "qup-memory";
1356 dmas = <&gpi_dma1 0 0 QCOM_GPI_I2C>,
1357 <&gpi_dma1 1 0 QCOM_GPI_I2C>;
1358 dma-names = "tx", "rx";
1359 status = "disabled";
1360 };
1361
1362 spi0: spi@a80000 {
1363 compatible = "qcom,geni-spi";
1364 reg = <0 0x00a80000 0 0x4000>;
1365 clock-names = "se";
1366 clocks = <&gcc GCC_QUPV3_WRAP1_S0_CLK>;
1367 interrupts = <GIC_SPI 353 IRQ_TYPE_LEVEL_HIGH>;
1368 pinctrl-names = "default";
1369 pinctrl-0 = <&qup_spi0_data_clk>, <&qup_spi0_cs>;
1370 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1371 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1372 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1373 interconnect-names = "qup-core", "qup-config", "qup-memory";
1374 dmas = <&gpi_dma1 0 0 QCOM_GPI_SPI>,
1375 <&gpi_dma1 1 0 QCOM_GPI_SPI>;
1376 dma-names = "tx", "rx";
1377 #address-cells = <1>;
1378 #size-cells = <0>;
1379 status = "disabled";
1380 };
1381
1382 i2c1: i2c@a84000 {
1383 compatible = "qcom,geni-i2c";
1384 reg = <0 0x00a84000 0 0x4000>;
1385 clock-names = "se";
1386 clocks = <&gcc GCC_QUPV3_WRAP1_S1_CLK>;
1387 pinctrl-names = "default";
1388 pinctrl-0 = <&qup_i2c1_data_clk>;
1389 interrupts = <GIC_SPI 354 IRQ_TYPE_LEVEL_HIGH>;
1390 #address-cells = <1>;
1391 #size-cells = <0>;
1392 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1393 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1394 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1395 interconnect-names = "qup-core", "qup-config", "qup-memory";
1396 dmas = <&gpi_dma1 0 1 QCOM_GPI_I2C>,
1397 <&gpi_dma1 1 1 QCOM_GPI_I2C>;
1398 dma-names = "tx", "rx";
1399 status = "disabled";
1400 };
1401
1402 spi1: spi@a84000 {
1403 compatible = "qcom,geni-spi";
1404 reg = <0 0x00a84000 0 0x4000>;
1405 clock-names = "se";
1406 clocks = <&gcc GCC_QUPV3_WRAP1_S1_CLK>;
1407 interrupts = <GIC_SPI 354 IRQ_TYPE_LEVEL_HIGH>;
1408 pinctrl-names = "default";
1409 pinctrl-0 = <&qup_spi1_data_clk>, <&qup_spi1_cs>;
1410 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1411 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1412 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1413 interconnect-names = "qup-core", "qup-config", "qup-memory";
1414 dmas = <&gpi_dma1 0 1 QCOM_GPI_SPI>,
1415 <&gpi_dma1 1 1 QCOM_GPI_SPI>;
1416 dma-names = "tx", "rx";
1417 #address-cells = <1>;
1418 #size-cells = <0>;
1419 status = "disabled";
1420 };
1421
1422 i2c2: i2c@a88000 {
1423 compatible = "qcom,geni-i2c";
1424 reg = <0 0x00a88000 0 0x4000>;
1425 clock-names = "se";
1426 clocks = <&gcc GCC_QUPV3_WRAP1_S2_CLK>;
1427 pinctrl-names = "default";
1428 pinctrl-0 = <&qup_i2c2_data_clk>;
1429 interrupts = <GIC_SPI 355 IRQ_TYPE_LEVEL_HIGH>;
1430 #address-cells = <1>;
1431 #size-cells = <0>;
1432 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1433 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1434 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1435 interconnect-names = "qup-core", "qup-config", "qup-memory";
1436 dmas = <&gpi_dma1 0 2 QCOM_GPI_I2C>,
1437 <&gpi_dma1 1 2 QCOM_GPI_I2C>;
1438 dma-names = "tx", "rx";
1439 status = "disabled";
1440 };
1441
1442 spi2: spi@a88000 {
1443 compatible = "qcom,geni-spi";
1444 reg = <0 0x00a88000 0 0x4000>;
1445 clock-names = "se";
1446 clocks = <&gcc GCC_QUPV3_WRAP1_S2_CLK>;
1447 interrupts = <GIC_SPI 355 IRQ_TYPE_LEVEL_HIGH>;
1448 pinctrl-names = "default";
1449 pinctrl-0 = <&qup_spi2_data_clk>, <&qup_spi2_cs>;
1450 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1451 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1452 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1453 interconnect-names = "qup-core", "qup-config", "qup-memory";
1454 dmas = <&gpi_dma1 0 2 QCOM_GPI_SPI>,
1455 <&gpi_dma1 1 2 QCOM_GPI_SPI>;
1456 dma-names = "tx", "rx";
1457 #address-cells = <1>;
1458 #size-cells = <0>;
1459 status = "disabled";
1460 };
1461
1462 i2c3: i2c@a8c000 {
1463 compatible = "qcom,geni-i2c";
1464 reg = <0 0x00a8c000 0 0x4000>;
1465 clock-names = "se";
1466 clocks = <&gcc GCC_QUPV3_WRAP1_S3_CLK>;
1467 pinctrl-names = "default";
1468 pinctrl-0 = <&qup_i2c3_data_clk>;
1469 interrupts = <GIC_SPI 356 IRQ_TYPE_LEVEL_HIGH>;
1470 #address-cells = <1>;
1471 #size-cells = <0>;
1472 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1473 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1474 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1475 interconnect-names = "qup-core", "qup-config", "qup-memory";
1476 dmas = <&gpi_dma1 0 3 QCOM_GPI_I2C>,
1477 <&gpi_dma1 1 3 QCOM_GPI_I2C>;
1478 dma-names = "tx", "rx";
1479 status = "disabled";
1480 };
1481
1482 spi3: spi@a8c000 {
1483 compatible = "qcom,geni-spi";
1484 reg = <0 0x00a8c000 0 0x4000>;
1485 clock-names = "se";
1486 clocks = <&gcc GCC_QUPV3_WRAP1_S3_CLK>;
1487 interrupts = <GIC_SPI 356 IRQ_TYPE_LEVEL_HIGH>;
1488 pinctrl-names = "default";
1489 pinctrl-0 = <&qup_spi3_data_clk>, <&qup_spi3_cs>;
1490 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1491 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1492 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1493 interconnect-names = "qup-core", "qup-config", "qup-memory";
1494 dmas = <&gpi_dma1 0 3 QCOM_GPI_SPI>,
1495 <&gpi_dma1 1 3 QCOM_GPI_SPI>;
1496 dma-names = "tx", "rx";
1497 #address-cells = <1>;
1498 #size-cells = <0>;
1499 status = "disabled";
1500 };
1501
1502 i2c4: i2c@a90000 {
1503 compatible = "qcom,geni-i2c";
1504 reg = <0 0x00a90000 0 0x4000>;
1505 clock-names = "se";
1506 clocks = <&gcc GCC_QUPV3_WRAP1_S4_CLK>;
1507 pinctrl-names = "default";
1508 pinctrl-0 = <&qup_i2c4_data_clk>;
1509 interrupts = <GIC_SPI 357 IRQ_TYPE_LEVEL_HIGH>;
1510 #address-cells = <1>;
1511 #size-cells = <0>;
1512 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1513 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1514 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1515 interconnect-names = "qup-core", "qup-config", "qup-memory";
1516 dmas = <&gpi_dma1 0 4 QCOM_GPI_I2C>,
1517 <&gpi_dma1 1 4 QCOM_GPI_I2C>;
1518 dma-names = "tx", "rx";
1519 status = "disabled";
1520 };
1521
1522 spi4: spi@a90000 {
1523 compatible = "qcom,geni-spi";
1524 reg = <0 0x00a90000 0 0x4000>;
1525 clock-names = "se";
1526 clocks = <&gcc GCC_QUPV3_WRAP1_S4_CLK>;
1527 interrupts = <GIC_SPI 357 IRQ_TYPE_LEVEL_HIGH>;
1528 pinctrl-names = "default";
1529 pinctrl-0 = <&qup_spi4_data_clk>, <&qup_spi4_cs>;
1530 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1531 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1532 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1533 interconnect-names = "qup-core", "qup-config", "qup-memory";
1534 dmas = <&gpi_dma1 0 4 QCOM_GPI_SPI>,
1535 <&gpi_dma1 1 4 QCOM_GPI_SPI>;
1536 dma-names = "tx", "rx";
1537 #address-cells = <1>;
1538 #size-cells = <0>;
1539 status = "disabled";
1540 };
1541
1542 i2c5: i2c@a94000 {
1543 compatible = "qcom,geni-i2c";
1544 reg = <0 0x00a94000 0 0x4000>;
1545 clock-names = "se";
1546 clocks = <&gcc GCC_QUPV3_WRAP1_S5_CLK>;
1547 pinctrl-names = "default";
1548 pinctrl-0 = <&qup_i2c5_data_clk>;
1549 interrupts = <GIC_SPI 358 IRQ_TYPE_LEVEL_HIGH>;
1550 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1551 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1552 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1553 interconnect-names = "qup-core", "qup-config", "qup-memory";
1554 dmas = <&gpi_dma1 0 5 QCOM_GPI_I2C>,
1555 <&gpi_dma1 1 5 QCOM_GPI_I2C>;
1556 dma-names = "tx", "rx";
1557 #address-cells = <1>;
1558 #size-cells = <0>;
1559 status = "disabled";
1560 };
1561
1562 spi5: spi@a94000 {
1563 compatible = "qcom,geni-spi";
1564 reg = <0 0x00a94000 0 0x4000>;
1565 clock-names = "se";
1566 clocks = <&gcc GCC_QUPV3_WRAP1_S5_CLK>;
1567 interrupts = <GIC_SPI 358 IRQ_TYPE_LEVEL_HIGH>;
1568 pinctrl-names = "default";
1569 pinctrl-0 = <&qup_spi5_data_clk>, <&qup_spi5_cs>;
1570 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1571 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1572 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1573 interconnect-names = "qup-core", "qup-config", "qup-memory";
1574 dmas = <&gpi_dma1 0 5 QCOM_GPI_SPI>,
1575 <&gpi_dma1 1 5 QCOM_GPI_SPI>;
1576 dma-names = "tx", "rx";
1577 #address-cells = <1>;
1578 #size-cells = <0>;
1579 status = "disabled";
1580 };
1581
1582 i2c6: i2c@a98000 {
1583 compatible = "qcom,geni-i2c";
1584 reg = <0 0x00a98000 0 0x4000>;
1585 clock-names = "se";
1586 clocks = <&gcc GCC_QUPV3_WRAP1_S6_CLK>;
1587 pinctrl-names = "default";
1588 pinctrl-0 = <&qup_i2c6_data_clk>;
1589 interrupts = <GIC_SPI 363 IRQ_TYPE_LEVEL_HIGH>;
1590 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1591 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1592 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1593 interconnect-names = "qup-core", "qup-config", "qup-memory";
1594 dmas = <&gpi_dma1 0 6 QCOM_GPI_I2C>,
1595 <&gpi_dma1 1 6 QCOM_GPI_I2C>;
1596 dma-names = "tx", "rx";
1597 #address-cells = <1>;
1598 #size-cells = <0>;
1599 status = "disabled";
1600 };
1601
1602 spi6: spi@a98000 {
1603 compatible = "qcom,geni-spi";
1604 reg = <0 0x00a98000 0 0x4000>;
1605 clock-names = "se";
1606 clocks = <&gcc GCC_QUPV3_WRAP1_S6_CLK>;
1607 interrupts = <GIC_SPI 363 IRQ_TYPE_LEVEL_HIGH>;
1608 pinctrl-names = "default";
1609 pinctrl-0 = <&qup_spi6_data_clk>, <&qup_spi6_cs>;
1610 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1611 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>,
1612 <&aggre1_noc MASTER_QUP_1 0 &mc_virt SLAVE_EBI1 0>;
1613 interconnect-names = "qup-core", "qup-config", "qup-memory";
1614 dmas = <&gpi_dma1 0 6 QCOM_GPI_SPI>,
1615 <&gpi_dma1 1 6 QCOM_GPI_SPI>;
1616 dma-names = "tx", "rx";
1617 #address-cells = <1>;
1618 #size-cells = <0>;
1619 status = "disabled";
1620 };
1621
1622 uart7: serial@a9c000 {
1623 compatible = "qcom,geni-debug-uart";
1624 reg = <0 0x00a9c000 0 0x4000>;
1625 clock-names = "se";
1626 clocks = <&gcc GCC_QUPV3_WRAP1_S7_CLK>;
1627 pinctrl-names = "default";
1628 pinctrl-0 = <&qup_uart7_default>;
1629 interrupts = <GIC_SPI 579 IRQ_TYPE_LEVEL_HIGH>;
1630 interconnect-names = "qup-core", "qup-config";
1631 interconnects = <&clk_virt MASTER_QUP_CORE_1 0 &clk_virt SLAVE_QUP_CORE_1 0>,
1632 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_QUP_1 0>;
1633 status = "disabled";
1634 };
1635 };
1636
1637 cnoc_main: interconnect@1500000 {
1638 compatible = "qcom,sm8550-cnoc-main";
1639 reg = <0 0x01500000 0 0x13080>;
1640 #interconnect-cells = <2>;
1641 qcom,bcm-voters = <&apps_bcm_voter>;
1642 };
1643
1644 config_noc: interconnect@1600000 {
1645 compatible = "qcom,sm8550-config-noc";
1646 reg = <0 0x01600000 0 0x6200>;
1647 #interconnect-cells = <2>;
1648 qcom,bcm-voters = <&apps_bcm_voter>;
1649 };
1650
1651 system_noc: interconnect@1680000 {
1652 compatible = "qcom,sm8550-system-noc";
1653 reg = <0 0x01680000 0 0x1d080>;
1654 #interconnect-cells = <2>;
1655 qcom,bcm-voters = <&apps_bcm_voter>;
1656 };
1657
1658 pcie_noc: interconnect@16c0000 {
1659 compatible = "qcom,sm8550-pcie-anoc";
1660 reg = <0 0x016c0000 0 0x12200>;
1661 #interconnect-cells = <2>;
1662 clocks = <&gcc GCC_AGGRE_NOC_PCIE_AXI_CLK>,
1663 <&gcc GCC_CFG_NOC_PCIE_ANOC_AHB_CLK>;
1664 qcom,bcm-voters = <&apps_bcm_voter>;
1665 };
1666
1667 aggre1_noc: interconnect@16e0000 {
1668 compatible = "qcom,sm8550-aggre1-noc";
1669 reg = <0 0x016e0000 0 0x14400>;
1670 #interconnect-cells = <2>;
1671 clocks = <&gcc GCC_AGGRE_UFS_PHY_AXI_CLK>,
1672 <&gcc GCC_AGGRE_USB3_PRIM_AXI_CLK>;
1673 qcom,bcm-voters = <&apps_bcm_voter>;
1674 };
1675
1676 aggre2_noc: interconnect@1700000 {
1677 compatible = "qcom,sm8550-aggre2-noc";
1678 reg = <0 0x01700000 0 0x1e400>;
1679 #interconnect-cells = <2>;
1680 clocks = <&rpmhcc RPMH_IPA_CLK>;
1681 qcom,bcm-voters = <&apps_bcm_voter>;
1682 };
1683
1684 mmss_noc: interconnect@1780000 {
1685 compatible = "qcom,sm8550-mmss-noc";
1686 reg = <0 0x01780000 0 0x5b800>;
1687 #interconnect-cells = <2>;
1688 qcom,bcm-voters = <&apps_bcm_voter>;
1689 };
1690
Tom Rini93743d22024-04-01 09:08:13 -04001691 rng: rng@10c3000 {
1692 compatible = "qcom,sm8550-trng", "qcom,trng";
1693 reg = <0 0x010c3000 0 0x1000>;
1694 };
1695
1696 pcie0: pcie@1c00000 {
Tom Rini53633a82024-02-29 12:33:36 -05001697 device_type = "pci";
1698 compatible = "qcom,pcie-sm8550";
1699 reg = <0 0x01c00000 0 0x3000>,
1700 <0 0x60000000 0 0xf1d>,
1701 <0 0x60000f20 0 0xa8>,
1702 <0 0x60001000 0 0x1000>,
1703 <0 0x60100000 0 0x100000>;
1704 reg-names = "parf", "dbi", "elbi", "atu", "config";
1705 #address-cells = <3>;
1706 #size-cells = <2>;
1707 ranges = <0x01000000 0x0 0x00000000 0x0 0x60200000 0x0 0x100000>,
1708 <0x02000000 0x0 0x60300000 0x0 0x60300000 0x0 0x3d00000>;
1709 bus-range = <0x00 0xff>;
1710
1711 dma-coherent;
1712
1713 linux,pci-domain = <0>;
1714 num-lanes = <2>;
1715
1716 interrupts = <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>;
1717 interrupt-names = "msi";
1718
1719 #interrupt-cells = <1>;
1720 interrupt-map-mask = <0 0 0 0x7>;
1721 interrupt-map = <0 0 0 1 &intc 0 0 0 149 IRQ_TYPE_LEVEL_HIGH>, /* int_a */
1722 <0 0 0 2 &intc 0 0 0 150 IRQ_TYPE_LEVEL_HIGH>, /* int_b */
1723 <0 0 0 3 &intc 0 0 0 151 IRQ_TYPE_LEVEL_HIGH>, /* int_c */
1724 <0 0 0 4 &intc 0 0 0 152 IRQ_TYPE_LEVEL_HIGH>; /* int_d */
1725
1726 clocks = <&gcc GCC_PCIE_0_AUX_CLK>,
1727 <&gcc GCC_PCIE_0_CFG_AHB_CLK>,
1728 <&gcc GCC_PCIE_0_MSTR_AXI_CLK>,
1729 <&gcc GCC_PCIE_0_SLV_AXI_CLK>,
1730 <&gcc GCC_PCIE_0_SLV_Q2A_AXI_CLK>,
1731 <&gcc GCC_DDRSS_PCIE_SF_QTB_CLK>,
1732 <&gcc GCC_AGGRE_NOC_PCIE_AXI_CLK>;
1733 clock-names = "aux",
1734 "cfg",
1735 "bus_master",
1736 "bus_slave",
1737 "slave_q2a",
1738 "ddrss_sf_tbu",
1739 "noc_aggr";
1740
1741 interconnects = <&pcie_noc MASTER_PCIE_0 0 &mc_virt SLAVE_EBI1 0>,
1742 <&gem_noc MASTER_APPSS_PROC 0 &cnoc_main SLAVE_PCIE_0 0>;
1743 interconnect-names = "pcie-mem", "cpu-pcie";
1744
1745 iommu-map = <0x0 &apps_smmu 0x1400 0x1>,
1746 <0x100 &apps_smmu 0x1401 0x1>;
1747
1748 resets = <&gcc GCC_PCIE_0_BCR>;
1749 reset-names = "pci";
1750
1751 power-domains = <&gcc PCIE_0_GDSC>;
1752
1753 phys = <&pcie0_phy>;
1754 phy-names = "pciephy";
1755
1756 status = "disabled";
1757 };
1758
1759 pcie0_phy: phy@1c06000 {
1760 compatible = "qcom,sm8550-qmp-gen3x2-pcie-phy";
1761 reg = <0 0x01c06000 0 0x2000>;
1762
1763 clocks = <&gcc GCC_PCIE_0_AUX_CLK>,
1764 <&gcc GCC_PCIE_0_CFG_AHB_CLK>,
1765 <&tcsr TCSR_PCIE_0_CLKREF_EN>,
1766 <&gcc GCC_PCIE_0_PHY_RCHNG_CLK>,
1767 <&gcc GCC_PCIE_0_PIPE_CLK>;
1768 clock-names = "aux", "cfg_ahb", "ref", "rchng",
1769 "pipe";
1770
1771 resets = <&gcc GCC_PCIE_0_PHY_BCR>;
1772 reset-names = "phy";
1773
1774 assigned-clocks = <&gcc GCC_PCIE_0_PHY_RCHNG_CLK>;
1775 assigned-clock-rates = <100000000>;
1776
1777 power-domains = <&gcc PCIE_0_PHY_GDSC>;
1778
1779 #clock-cells = <0>;
1780 clock-output-names = "pcie0_pipe_clk";
1781
1782 #phy-cells = <0>;
1783
1784 status = "disabled";
1785 };
1786
Tom Rini93743d22024-04-01 09:08:13 -04001787 pcie1: pcie@1c08000 {
Tom Rini53633a82024-02-29 12:33:36 -05001788 device_type = "pci";
1789 compatible = "qcom,pcie-sm8550";
1790 reg = <0x0 0x01c08000 0x0 0x3000>,
1791 <0x0 0x40000000 0x0 0xf1d>,
1792 <0x0 0x40000f20 0x0 0xa8>,
1793 <0x0 0x40001000 0x0 0x1000>,
1794 <0x0 0x40100000 0x0 0x100000>;
1795 reg-names = "parf", "dbi", "elbi", "atu", "config";
1796 #address-cells = <3>;
1797 #size-cells = <2>;
1798 ranges = <0x01000000 0x0 0x00000000 0x0 0x40200000 0x0 0x100000>,
1799 <0x02000000 0x0 0x40300000 0x0 0x40300000 0x0 0x1fd00000>;
1800 bus-range = <0x00 0xff>;
1801
1802 dma-coherent;
1803
1804 linux,pci-domain = <1>;
1805 num-lanes = <2>;
1806
1807 interrupts = <GIC_SPI 307 IRQ_TYPE_LEVEL_HIGH>;
1808 interrupt-names = "msi";
1809
1810 #interrupt-cells = <1>;
1811 interrupt-map-mask = <0 0 0 0x7>;
1812 interrupt-map = <0 0 0 1 &intc 0 0 0 434 IRQ_TYPE_LEVEL_HIGH>, /* int_a */
1813 <0 0 0 2 &intc 0 0 0 435 IRQ_TYPE_LEVEL_HIGH>, /* int_b */
1814 <0 0 0 3 &intc 0 0 0 438 IRQ_TYPE_LEVEL_HIGH>, /* int_c */
1815 <0 0 0 4 &intc 0 0 0 439 IRQ_TYPE_LEVEL_HIGH>; /* int_d */
1816
1817 clocks = <&gcc GCC_PCIE_1_AUX_CLK>,
1818 <&gcc GCC_PCIE_1_CFG_AHB_CLK>,
1819 <&gcc GCC_PCIE_1_MSTR_AXI_CLK>,
1820 <&gcc GCC_PCIE_1_SLV_AXI_CLK>,
1821 <&gcc GCC_PCIE_1_SLV_Q2A_AXI_CLK>,
1822 <&gcc GCC_DDRSS_PCIE_SF_QTB_CLK>,
1823 <&gcc GCC_AGGRE_NOC_PCIE_AXI_CLK>,
1824 <&gcc GCC_CNOC_PCIE_SF_AXI_CLK>;
1825 clock-names = "aux",
1826 "cfg",
1827 "bus_master",
1828 "bus_slave",
1829 "slave_q2a",
1830 "ddrss_sf_tbu",
1831 "noc_aggr",
1832 "cnoc_sf_axi";
1833
1834 assigned-clocks = <&gcc GCC_PCIE_1_AUX_CLK>;
1835 assigned-clock-rates = <19200000>;
1836
1837 interconnects = <&pcie_noc MASTER_PCIE_1 0 &mc_virt SLAVE_EBI1 0>,
1838 <&gem_noc MASTER_APPSS_PROC 0 &cnoc_main SLAVE_PCIE_1 0>;
1839 interconnect-names = "pcie-mem", "cpu-pcie";
1840
1841 iommu-map = <0x0 &apps_smmu 0x1480 0x1>,
1842 <0x100 &apps_smmu 0x1481 0x1>;
1843
1844 resets = <&gcc GCC_PCIE_1_BCR>,
1845 <&gcc GCC_PCIE_1_LINK_DOWN_BCR>;
1846 reset-names = "pci", "link_down";
1847
1848 power-domains = <&gcc PCIE_1_GDSC>;
1849
1850 phys = <&pcie1_phy>;
1851 phy-names = "pciephy";
1852
1853 status = "disabled";
1854 };
1855
1856 pcie1_phy: phy@1c0e000 {
1857 compatible = "qcom,sm8550-qmp-gen4x2-pcie-phy";
1858 reg = <0x0 0x01c0e000 0x0 0x2000>;
1859
1860 clocks = <&gcc GCC_PCIE_1_PHY_AUX_CLK>,
1861 <&gcc GCC_PCIE_1_CFG_AHB_CLK>,
1862 <&tcsr TCSR_PCIE_1_CLKREF_EN>,
1863 <&gcc GCC_PCIE_1_PHY_RCHNG_CLK>,
1864 <&gcc GCC_PCIE_1_PIPE_CLK>;
1865 clock-names = "aux", "cfg_ahb", "ref", "rchng",
1866 "pipe";
1867
1868 resets = <&gcc GCC_PCIE_1_PHY_BCR>,
1869 <&gcc GCC_PCIE_1_NOCSR_COM_PHY_BCR>;
1870 reset-names = "phy", "phy_nocsr";
1871
1872 assigned-clocks = <&gcc GCC_PCIE_1_PHY_RCHNG_CLK>;
1873 assigned-clock-rates = <100000000>;
1874
1875 power-domains = <&gcc PCIE_1_PHY_GDSC>;
1876
1877 #clock-cells = <0>;
1878 clock-output-names = "pcie1_pipe_clk";
1879
1880 #phy-cells = <0>;
1881
1882 status = "disabled";
1883 };
1884
1885 cryptobam: dma-controller@1dc4000 {
1886 compatible = "qcom,bam-v1.7.4", "qcom,bam-v1.7.0";
1887 reg = <0x0 0x01dc4000 0x0 0x28000>;
1888 interrupts = <GIC_SPI 272 IRQ_TYPE_LEVEL_HIGH>;
1889 #dma-cells = <1>;
1890 qcom,ee = <0>;
1891 qcom,controlled-remotely;
1892 iommus = <&apps_smmu 0x480 0x0>,
1893 <&apps_smmu 0x481 0x0>;
1894 };
1895
1896 crypto: crypto@1dfa000 {
1897 compatible = "qcom,sm8550-qce", "qcom,sm8150-qce", "qcom,qce";
1898 reg = <0x0 0x01dfa000 0x0 0x6000>;
1899 dmas = <&cryptobam 4>, <&cryptobam 5>;
1900 dma-names = "rx", "tx";
1901 iommus = <&apps_smmu 0x480 0x0>,
1902 <&apps_smmu 0x481 0x0>;
1903 interconnects = <&aggre2_noc MASTER_CRYPTO 0 &mc_virt SLAVE_EBI1 0>;
1904 interconnect-names = "memory";
1905 };
1906
1907 ufs_mem_phy: phy@1d80000 {
1908 compatible = "qcom,sm8550-qmp-ufs-phy";
1909 reg = <0x0 0x01d80000 0x0 0x2000>;
1910 clocks = <&tcsr TCSR_UFS_CLKREF_EN>,
1911 <&gcc GCC_UFS_PHY_PHY_AUX_CLK>;
1912 clock-names = "ref", "ref_aux";
1913
1914 power-domains = <&gcc UFS_MEM_PHY_GDSC>;
1915
1916 resets = <&ufs_mem_hc 0>;
1917 reset-names = "ufsphy";
1918
1919 #clock-cells = <1>;
1920 #phy-cells = <0>;
1921
1922 status = "disabled";
1923 };
1924
1925 ufs_mem_hc: ufs@1d84000 {
1926 compatible = "qcom,sm8550-ufshc", "qcom,ufshc",
1927 "jedec,ufs-2.0";
1928 reg = <0x0 0x01d84000 0x0 0x3000>;
1929 interrupts = <GIC_SPI 265 IRQ_TYPE_LEVEL_HIGH>;
1930 phys = <&ufs_mem_phy>;
1931 phy-names = "ufsphy";
1932 lanes-per-direction = <2>;
1933 #reset-cells = <1>;
1934 resets = <&gcc GCC_UFS_PHY_BCR>;
1935 reset-names = "rst";
1936
1937 power-domains = <&gcc UFS_PHY_GDSC>;
1938 required-opps = <&rpmhpd_opp_nom>;
1939
1940 iommus = <&apps_smmu 0x60 0x0>;
1941 dma-coherent;
1942
1943 interconnects = <&aggre1_noc MASTER_UFS_MEM 0 &mc_virt SLAVE_EBI1 0>,
1944 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_UFS_MEM_CFG 0>;
1945
1946 interconnect-names = "ufs-ddr", "cpu-ufs";
1947 clock-names = "core_clk",
1948 "bus_aggr_clk",
1949 "iface_clk",
1950 "core_clk_unipro",
1951 "ref_clk",
1952 "tx_lane0_sync_clk",
1953 "rx_lane0_sync_clk",
1954 "rx_lane1_sync_clk";
1955 clocks = <&gcc GCC_UFS_PHY_AXI_CLK>,
1956 <&gcc GCC_AGGRE_UFS_PHY_AXI_CLK>,
1957 <&gcc GCC_UFS_PHY_AHB_CLK>,
1958 <&gcc GCC_UFS_PHY_UNIPRO_CORE_CLK>,
1959 <&tcsr TCSR_UFS_PAD_CLKREF_EN>,
1960 <&gcc GCC_UFS_PHY_TX_SYMBOL_0_CLK>,
1961 <&gcc GCC_UFS_PHY_RX_SYMBOL_0_CLK>,
1962 <&gcc GCC_UFS_PHY_RX_SYMBOL_1_CLK>;
1963 freq-table-hz =
1964 <75000000 300000000>,
1965 <0 0>,
1966 <0 0>,
1967 <75000000 300000000>,
1968 <100000000 403000000>,
1969 <0 0>,
1970 <0 0>,
1971 <0 0>;
1972 qcom,ice = <&ice>;
1973
1974 status = "disabled";
1975 };
1976
1977 ice: crypto@1d88000 {
1978 compatible = "qcom,sm8550-inline-crypto-engine",
1979 "qcom,inline-crypto-engine";
1980 reg = <0 0x01d88000 0 0x8000>;
1981 clocks = <&gcc GCC_UFS_PHY_ICE_CORE_CLK>;
1982 };
1983
1984 tcsr_mutex: hwlock@1f40000 {
1985 compatible = "qcom,tcsr-mutex";
1986 reg = <0 0x01f40000 0 0x20000>;
1987 #hwlock-cells = <1>;
1988 };
1989
1990 tcsr: clock-controller@1fc0000 {
1991 compatible = "qcom,sm8550-tcsr", "syscon";
1992 reg = <0 0x01fc0000 0 0x30000>;
1993 clocks = <&rpmhcc RPMH_CXO_CLK>;
1994 #clock-cells = <1>;
1995 #reset-cells = <1>;
1996 };
1997
Tom Rini93743d22024-04-01 09:08:13 -04001998 gpu: gpu@3d00000 {
1999 compatible = "qcom,adreno-43050a01", "qcom,adreno";
2000 reg = <0x0 0x03d00000 0x0 0x40000>,
2001 <0x0 0x03d9e000 0x0 0x1000>,
2002 <0x0 0x03d61000 0x0 0x800>;
2003 reg-names = "kgsl_3d0_reg_memory",
2004 "cx_mem",
2005 "cx_dbgc";
2006
2007 interrupts = <GIC_SPI 300 IRQ_TYPE_LEVEL_HIGH>;
2008
2009 iommus = <&adreno_smmu 0 0x0>,
2010 <&adreno_smmu 1 0x0>;
2011
2012 operating-points-v2 = <&gpu_opp_table>;
2013
2014 qcom,gmu = <&gmu>;
2015
2016 status = "disabled";
2017
2018 zap-shader {
2019 memory-region = <&gpu_micro_code_mem>;
2020 };
2021
2022 /* Speedbin needs more work on A740+, keep only lower freqs */
2023 gpu_opp_table: opp-table {
2024 compatible = "operating-points-v2";
2025
2026 opp-680000000 {
2027 opp-hz = /bits/ 64 <680000000>;
2028 opp-level = <RPMH_REGULATOR_LEVEL_SVS_L1>;
2029 };
2030
2031 opp-615000000 {
2032 opp-hz = /bits/ 64 <615000000>;
2033 opp-level = <RPMH_REGULATOR_LEVEL_SVS_L0>;
2034 };
2035
2036 opp-550000000 {
2037 opp-hz = /bits/ 64 <550000000>;
2038 opp-level = <RPMH_REGULATOR_LEVEL_SVS>;
2039 };
2040
2041 opp-475000000 {
2042 opp-hz = /bits/ 64 <475000000>;
2043 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_L1>;
2044 };
2045
2046 opp-401000000 {
2047 opp-hz = /bits/ 64 <401000000>;
2048 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS>;
2049 };
2050
2051 opp-348000000 {
2052 opp-hz = /bits/ 64 <348000000>;
2053 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_D0>;
2054 };
2055
2056 opp-295000000 {
2057 opp-hz = /bits/ 64 <295000000>;
2058 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_D1>;
2059 };
2060
2061 opp-220000000 {
2062 opp-hz = /bits/ 64 <220000000>;
2063 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_D2>;
2064 };
2065 };
2066 };
2067
2068 gmu: gmu@3d6a000 {
2069 compatible = "qcom,adreno-gmu-740.1", "qcom,adreno-gmu";
2070 reg = <0x0 0x03d6a000 0x0 0x35000>,
2071 <0x0 0x03d50000 0x0 0x10000>,
2072 <0x0 0x0b280000 0x0 0x10000>;
2073 reg-names = "gmu", "rscc", "gmu_pdc";
2074
2075 interrupts = <GIC_SPI 304 IRQ_TYPE_LEVEL_HIGH>,
2076 <GIC_SPI 305 IRQ_TYPE_LEVEL_HIGH>;
2077 interrupt-names = "hfi", "gmu";
2078
2079 clocks = <&gpucc GPU_CC_AHB_CLK>,
2080 <&gpucc GPU_CC_CX_GMU_CLK>,
2081 <&gpucc GPU_CC_CXO_CLK>,
2082 <&gcc GCC_DDRSS_GPU_AXI_CLK>,
2083 <&gcc GCC_GPU_MEMNOC_GFX_CLK>,
2084 <&gpucc GPU_CC_HUB_CX_INT_CLK>,
2085 <&gpucc GPU_CC_DEMET_CLK>;
2086 clock-names = "ahb",
2087 "gmu",
2088 "cxo",
2089 "axi",
2090 "memnoc",
2091 "hub",
2092 "demet";
2093
2094 power-domains = <&gpucc GPU_CC_CX_GDSC>,
2095 <&gpucc GPU_CC_GX_GDSC>;
2096 power-domain-names = "cx",
2097 "gx";
2098
2099 iommus = <&adreno_smmu 5 0x0>;
2100
2101 qcom,qmp = <&aoss_qmp>;
2102
2103 operating-points-v2 = <&gmu_opp_table>;
2104
2105 gmu_opp_table: opp-table {
2106 compatible = "operating-points-v2";
2107
2108 opp-500000000 {
2109 opp-hz = /bits/ 64 <500000000>;
2110 opp-level = <RPMH_REGULATOR_LEVEL_SVS>;
2111 };
2112
2113 opp-200000000 {
2114 opp-hz = /bits/ 64 <200000000>;
2115 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS>;
2116 };
2117 };
2118 };
2119
Tom Rini53633a82024-02-29 12:33:36 -05002120 gpucc: clock-controller@3d90000 {
2121 compatible = "qcom,sm8550-gpucc";
2122 reg = <0 0x03d90000 0 0xa000>;
2123 clocks = <&bi_tcxo_div2>,
2124 <&gcc GCC_GPU_GPLL0_CLK_SRC>,
2125 <&gcc GCC_GPU_GPLL0_DIV_CLK_SRC>;
2126 #clock-cells = <1>;
2127 #reset-cells = <1>;
2128 #power-domain-cells = <1>;
2129 };
2130
Tom Rini93743d22024-04-01 09:08:13 -04002131 adreno_smmu: iommu@3da0000 {
2132 compatible = "qcom,sm8550-smmu-500", "qcom,adreno-smmu",
2133 "qcom,smmu-500", "arm,mmu-500";
2134 reg = <0x0 0x03da0000 0x0 0x40000>;
2135 #iommu-cells = <2>;
2136 #global-interrupts = <1>;
2137 interrupts = <GIC_SPI 673 IRQ_TYPE_LEVEL_HIGH>,
2138 <GIC_SPI 677 IRQ_TYPE_LEVEL_HIGH>,
2139 <GIC_SPI 678 IRQ_TYPE_LEVEL_HIGH>,
2140 <GIC_SPI 679 IRQ_TYPE_LEVEL_HIGH>,
2141 <GIC_SPI 680 IRQ_TYPE_LEVEL_HIGH>,
2142 <GIC_SPI 681 IRQ_TYPE_LEVEL_HIGH>,
2143 <GIC_SPI 682 IRQ_TYPE_LEVEL_HIGH>,
2144 <GIC_SPI 683 IRQ_TYPE_LEVEL_HIGH>,
2145 <GIC_SPI 684 IRQ_TYPE_LEVEL_HIGH>,
2146 <GIC_SPI 685 IRQ_TYPE_LEVEL_HIGH>,
2147 <GIC_SPI 686 IRQ_TYPE_LEVEL_HIGH>,
2148 <GIC_SPI 687 IRQ_TYPE_LEVEL_HIGH>,
2149 <GIC_SPI 422 IRQ_TYPE_LEVEL_HIGH>,
2150 <GIC_SPI 476 IRQ_TYPE_LEVEL_HIGH>,
2151 <GIC_SPI 574 IRQ_TYPE_LEVEL_HIGH>,
2152 <GIC_SPI 575 IRQ_TYPE_LEVEL_HIGH>,
2153 <GIC_SPI 576 IRQ_TYPE_LEVEL_HIGH>,
2154 <GIC_SPI 577 IRQ_TYPE_LEVEL_HIGH>,
2155 <GIC_SPI 659 IRQ_TYPE_LEVEL_HIGH>,
2156 <GIC_SPI 661 IRQ_TYPE_LEVEL_HIGH>,
2157 <GIC_SPI 664 IRQ_TYPE_LEVEL_HIGH>,
2158 <GIC_SPI 665 IRQ_TYPE_LEVEL_HIGH>,
2159 <GIC_SPI 666 IRQ_TYPE_LEVEL_HIGH>,
2160 <GIC_SPI 668 IRQ_TYPE_LEVEL_HIGH>,
2161 <GIC_SPI 669 IRQ_TYPE_LEVEL_HIGH>,
2162 <GIC_SPI 699 IRQ_TYPE_LEVEL_HIGH>;
2163 clocks = <&gpucc GPU_CC_HLOS1_VOTE_GPU_SMMU_CLK>,
2164 <&gcc GCC_GPU_MEMNOC_GFX_CLK>,
2165 <&gcc GCC_GPU_SNOC_DVM_GFX_CLK>,
2166 <&gpucc GPU_CC_AHB_CLK>;
2167 clock-names = "hlos",
2168 "bus",
2169 "iface",
2170 "ahb";
2171 power-domains = <&gpucc GPU_CC_CX_GDSC>;
2172 dma-coherent;
2173 };
2174
2175 ipa: ipa@3f40000 {
2176 compatible = "qcom,sm8550-ipa";
2177
2178 iommus = <&apps_smmu 0x4a0 0x0>,
2179 <&apps_smmu 0x4a2 0x0>;
2180 reg = <0 0x3f40000 0 0x10000>,
2181 <0 0x3f50000 0 0x5000>,
2182 <0 0x3e04000 0 0xfc000>;
2183 reg-names = "ipa-reg",
2184 "ipa-shared",
2185 "gsi";
2186
2187 interrupts-extended = <&intc GIC_SPI 654 IRQ_TYPE_EDGE_RISING>,
2188 <&intc GIC_SPI 432 IRQ_TYPE_LEVEL_HIGH>,
2189 <&ipa_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
2190 <&ipa_smp2p_in 1 IRQ_TYPE_EDGE_RISING>;
2191 interrupt-names = "ipa",
2192 "gsi",
2193 "ipa-clock-query",
2194 "ipa-setup-ready";
2195
2196 clocks = <&rpmhcc RPMH_IPA_CLK>;
2197 clock-names = "core";
2198
2199 interconnects = <&aggre2_noc MASTER_IPA 0 &mc_virt SLAVE_EBI1 0>,
2200 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_IPA_CFG 0>;
2201 interconnect-names = "memory",
2202 "config";
2203
2204 qcom,qmp = <&aoss_qmp>;
2205
2206 qcom,smem-states = <&ipa_smp2p_out 0>,
2207 <&ipa_smp2p_out 1>;
2208 qcom,smem-state-names = "ipa-clock-enabled-valid",
2209 "ipa-clock-enabled";
2210
2211 status = "disabled";
2212 };
2213
Tom Rini53633a82024-02-29 12:33:36 -05002214 remoteproc_mpss: remoteproc@4080000 {
2215 compatible = "qcom,sm8550-mpss-pas";
2216 reg = <0x0 0x04080000 0x0 0x4040>;
2217
2218 interrupts-extended = <&intc GIC_SPI 264 IRQ_TYPE_EDGE_RISING>,
2219 <&smp2p_modem_in 0 IRQ_TYPE_EDGE_RISING>,
2220 <&smp2p_modem_in 1 IRQ_TYPE_EDGE_RISING>,
2221 <&smp2p_modem_in 2 IRQ_TYPE_EDGE_RISING>,
2222 <&smp2p_modem_in 3 IRQ_TYPE_EDGE_RISING>,
2223 <&smp2p_modem_in 7 IRQ_TYPE_EDGE_RISING>;
2224 interrupt-names = "wdog", "fatal", "ready", "handover",
2225 "stop-ack", "shutdown-ack";
2226
2227 clocks = <&rpmhcc RPMH_CXO_CLK>;
2228 clock-names = "xo";
2229
2230 power-domains = <&rpmhpd RPMHPD_CX>,
2231 <&rpmhpd RPMHPD_MSS>;
2232 power-domain-names = "cx", "mss";
2233
2234 interconnects = <&mc_virt MASTER_LLCC 0 &mc_virt SLAVE_EBI1 0>;
2235
2236 memory-region = <&mpss_mem>, <&q6_mpss_dtb_mem>, <&mpss_dsm_mem>;
2237
2238 qcom,qmp = <&aoss_qmp>;
2239
2240 qcom,smem-states = <&smp2p_modem_out 0>;
2241 qcom,smem-state-names = "stop";
2242
2243 status = "disabled";
2244
2245 glink-edge {
2246 interrupts-extended = <&ipcc IPCC_CLIENT_MPSS
2247 IPCC_MPROC_SIGNAL_GLINK_QMP
2248 IRQ_TYPE_EDGE_RISING>;
2249 mboxes = <&ipcc IPCC_CLIENT_MPSS
2250 IPCC_MPROC_SIGNAL_GLINK_QMP>;
2251 label = "mpss";
2252 qcom,remote-pid = <1>;
2253 };
2254 };
2255
2256 lpass_wsa2macro: codec@6aa0000 {
2257 compatible = "qcom,sm8550-lpass-wsa-macro";
2258 reg = <0 0x06aa0000 0 0x1000>;
2259 clocks = <&q6prmcc LPASS_CLK_ID_WSA2_CORE_TX_MCLK LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2260 <&q6prmcc LPASS_HW_MACRO_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2261 <&q6prmcc LPASS_HW_DCODEC_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2262 <&lpass_vamacro>;
2263 clock-names = "mclk", "macro", "dcodec", "fsgen";
Tom Rini53633a82024-02-29 12:33:36 -05002264
2265 #clock-cells = <0>;
2266 clock-output-names = "wsa2-mclk";
Tom Rini53633a82024-02-29 12:33:36 -05002267 #sound-dai-cells = <1>;
2268 };
2269
Tom Rini93743d22024-04-01 09:08:13 -04002270 swr3: soundwire@6ab0000 {
Tom Rini53633a82024-02-29 12:33:36 -05002271 compatible = "qcom,soundwire-v2.0.0";
2272 reg = <0 0x06ab0000 0 0x10000>;
2273 interrupts = <GIC_SPI 171 IRQ_TYPE_LEVEL_HIGH>;
2274 clocks = <&lpass_wsa2macro>;
2275 clock-names = "iface";
2276 label = "WSA2";
2277
Tom Rini93743d22024-04-01 09:08:13 -04002278 pinctrl-0 = <&wsa2_swr_active>;
2279 pinctrl-names = "default";
2280
Tom Rini53633a82024-02-29 12:33:36 -05002281 qcom,din-ports = <4>;
2282 qcom,dout-ports = <9>;
2283
2284 qcom,ports-sinterval = /bits/ 16 <0x07 0x1f 0x3f 0x07 0x1f 0x3f 0x18f 0xff 0xff 0x0f 0x0f 0xff 0x31f>;
2285 qcom,ports-offset1 = /bits/ 8 <0x01 0x03 0x05 0x02 0x04 0x15 0x00 0xff 0xff 0x06 0x0d 0xff 0x00>;
2286 qcom,ports-offset2 = /bits/ 8 <0xff 0x07 0x1f 0xff 0x07 0x1f 0xff 0xff 0xff 0xff 0xff 0xff 0xff>;
2287 qcom,ports-hstart = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0x08 0xff 0xff 0xff 0xff 0xff 0x0f>;
2288 qcom,ports-hstop = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0x08 0xff 0xff 0xff 0xff 0xff 0x0f>;
2289 qcom,ports-word-length = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0x08 0xff 0xff 0xff 0xff 0xff 0x18>;
2290 qcom,ports-block-pack-mode = /bits/ 8 <0x00 0x01 0x01 0x00 0x01 0x01 0x00 0x00 0x00 0x01 0x01 0x00 0x00>;
2291 qcom,ports-block-group-count = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff>;
2292 qcom,ports-lane-control = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff>;
2293
2294 #address-cells = <2>;
2295 #size-cells = <0>;
2296 #sound-dai-cells = <1>;
2297 status = "disabled";
2298 };
2299
2300 lpass_rxmacro: codec@6ac0000 {
2301 compatible = "qcom,sm8550-lpass-rx-macro";
2302 reg = <0 0x06ac0000 0 0x1000>;
2303 clocks = <&q6prmcc LPASS_CLK_ID_RX_CORE_TX_MCLK LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2304 <&q6prmcc LPASS_HW_MACRO_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2305 <&q6prmcc LPASS_HW_DCODEC_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2306 <&lpass_vamacro>;
2307 clock-names = "mclk", "macro", "dcodec", "fsgen";
2308
Tom Rini53633a82024-02-29 12:33:36 -05002309 #clock-cells = <0>;
2310 clock-output-names = "mclk";
Tom Rini53633a82024-02-29 12:33:36 -05002311 #sound-dai-cells = <1>;
2312 };
2313
Tom Rini93743d22024-04-01 09:08:13 -04002314 swr1: soundwire@6ad0000 {
Tom Rini53633a82024-02-29 12:33:36 -05002315 compatible = "qcom,soundwire-v2.0.0";
2316 reg = <0 0x06ad0000 0 0x10000>;
2317 interrupts = <GIC_SPI 155 IRQ_TYPE_LEVEL_HIGH>;
2318 clocks = <&lpass_rxmacro>;
2319 clock-names = "iface";
2320 label = "RX";
2321
Tom Rini93743d22024-04-01 09:08:13 -04002322 pinctrl-0 = <&rx_swr_active>;
2323 pinctrl-names = "default";
2324
2325 qcom,din-ports = <1>;
2326 qcom,dout-ports = <11>;
Tom Rini53633a82024-02-29 12:33:36 -05002327
Tom Rini93743d22024-04-01 09:08:13 -04002328 qcom,ports-sinterval = /bits/ 16 <0x03 0x3f 0x1f 0x07 0x00 0x18f 0xff 0xff 0xff 0xff 0xff 0xff>;
2329 qcom,ports-offset1 = /bits/ 8 <0x00 0x00 0x0b 0x01 0x00 0x00 0xff 0xff 0xff 0xff 0xff 0xff>;
2330 qcom,ports-offset2 = /bits/ 8 <0x00 0x00 0x0b 0x00 0x00 0x00 0xff 0xff 0xff 0xff 0xff 0xff>;
2331 qcom,ports-hstart = /bits/ 8 <0xff 0x03 0xff 0xff 0xff 0x08 0xff 0xff 0xff 0xff 0xff 0xff>;
2332 qcom,ports-hstop = /bits/ 8 <0xff 0x06 0xff 0xff 0xff 0x08 0xff 0xff 0xff 0xff 0xff 0xff>;
2333 qcom,ports-word-length = /bits/ 8 <0x01 0x07 0x04 0xff 0xff 0x0f 0xff 0xff 0xff 0xff 0xff 0xff>;
2334 qcom,ports-block-pack-mode = /bits/ 8 <0xff 0x00 0x01 0xff 0xff 0x00 0xff 0xff 0xff 0xff 0xff 0xff>;
2335 qcom,ports-block-group-count = /bits/ 8 <0xff 0xff 0xff 0xff 0x00 0x00 0xff 0xff 0xff 0xff 0xff 0xff>;
2336 qcom,ports-lane-control = /bits/ 8 <0x01 0x00 0x00 0x00 0x00 0x00 0xff 0xff 0xff 0xff 0xff 0xff>;
Tom Rini53633a82024-02-29 12:33:36 -05002337
2338 #address-cells = <2>;
2339 #size-cells = <0>;
2340 #sound-dai-cells = <1>;
2341 status = "disabled";
2342 };
2343
2344 lpass_txmacro: codec@6ae0000 {
2345 compatible = "qcom,sm8550-lpass-tx-macro";
2346 reg = <0 0x06ae0000 0 0x1000>;
2347 clocks = <&q6prmcc LPASS_CLK_ID_TX_CORE_MCLK LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2348 <&q6prmcc LPASS_HW_MACRO_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2349 <&q6prmcc LPASS_HW_DCODEC_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2350 <&lpass_vamacro>;
2351 clock-names = "mclk", "macro", "dcodec", "fsgen";
Tom Rini53633a82024-02-29 12:33:36 -05002352
2353 #clock-cells = <0>;
2354 clock-output-names = "mclk";
Tom Rini53633a82024-02-29 12:33:36 -05002355 #sound-dai-cells = <1>;
2356 };
2357
2358 lpass_wsamacro: codec@6b00000 {
2359 compatible = "qcom,sm8550-lpass-wsa-macro";
2360 reg = <0 0x06b00000 0 0x1000>;
2361 clocks = <&q6prmcc LPASS_CLK_ID_WSA_CORE_TX_MCLK LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2362 <&q6prmcc LPASS_HW_MACRO_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2363 <&q6prmcc LPASS_HW_DCODEC_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2364 <&lpass_vamacro>;
2365 clock-names = "mclk", "macro", "dcodec", "fsgen";
2366
Tom Rini53633a82024-02-29 12:33:36 -05002367 #clock-cells = <0>;
2368 clock-output-names = "mclk";
Tom Rini53633a82024-02-29 12:33:36 -05002369 #sound-dai-cells = <1>;
2370 };
2371
Tom Rini93743d22024-04-01 09:08:13 -04002372 swr0: soundwire@6b10000 {
Tom Rini53633a82024-02-29 12:33:36 -05002373 compatible = "qcom,soundwire-v2.0.0";
2374 reg = <0 0x06b10000 0 0x10000>;
2375 interrupts = <GIC_SPI 170 IRQ_TYPE_LEVEL_HIGH>;
2376 clocks = <&lpass_wsamacro>;
2377 clock-names = "iface";
2378 label = "WSA";
2379
Tom Rini93743d22024-04-01 09:08:13 -04002380 pinctrl-0 = <&wsa_swr_active>;
2381 pinctrl-names = "default";
2382
Tom Rini53633a82024-02-29 12:33:36 -05002383 qcom,din-ports = <4>;
2384 qcom,dout-ports = <9>;
2385
2386 qcom,ports-sinterval = /bits/ 16 <0x07 0x1f 0x3f 0x07 0x1f 0x3f 0x18f 0xff 0xff 0x0f 0x0f 0xff 0x31f>;
2387 qcom,ports-offset1 = /bits/ 8 <0x01 0x03 0x05 0x02 0x04 0x15 0x00 0xff 0xff 0x06 0x0d 0xff 0x00>;
2388 qcom,ports-offset2 = /bits/ 8 <0xff 0x07 0x1f 0xff 0x07 0x1f 0xff 0xff 0xff 0xff 0xff 0xff 0xff>;
2389 qcom,ports-hstart = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0x08 0xff 0xff 0xff 0xff 0xff 0x0f>;
2390 qcom,ports-hstop = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0x08 0xff 0xff 0xff 0xff 0xff 0x0f>;
2391 qcom,ports-word-length = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0x08 0xff 0xff 0xff 0xff 0xff 0x18>;
2392 qcom,ports-block-pack-mode = /bits/ 8 <0x00 0x01 0x01 0x00 0x01 0x01 0x00 0x00 0x00 0x01 0x01 0x00 0x00>;
2393 qcom,ports-block-group-count = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff>;
2394 qcom,ports-lane-control = /bits/ 8 <0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff 0xff>;
2395
2396 #address-cells = <2>;
2397 #size-cells = <0>;
2398 #sound-dai-cells = <1>;
2399 status = "disabled";
2400 };
2401
Tom Rini93743d22024-04-01 09:08:13 -04002402 swr2: soundwire@6d30000 {
Tom Rini53633a82024-02-29 12:33:36 -05002403 compatible = "qcom,soundwire-v2.0.0";
2404 reg = <0 0x06d30000 0 0x10000>;
2405 interrupts = <GIC_SPI 496 IRQ_TYPE_LEVEL_HIGH>,
2406 <GIC_SPI 520 IRQ_TYPE_LEVEL_HIGH>;
2407 interrupt-names = "core", "wakeup";
Tom Rini93743d22024-04-01 09:08:13 -04002408 clocks = <&lpass_txmacro>;
Tom Rini53633a82024-02-29 12:33:36 -05002409 clock-names = "iface";
2410 label = "TX";
2411
Tom Rini93743d22024-04-01 09:08:13 -04002412 pinctrl-0 = <&tx_swr_active>;
2413 pinctrl-names = "default";
2414
Tom Rini53633a82024-02-29 12:33:36 -05002415 qcom,din-ports = <4>;
2416 qcom,dout-ports = <0>;
2417 qcom,ports-sinterval-low = /bits/ 8 <0x01 0x01 0x03 0x03>;
2418 qcom,ports-offset1 = /bits/ 8 <0x00 0x00 0x01 0x01>;
2419 qcom,ports-offset2 = /bits/ 8 <0x00 0x00 0x00 0x00>;
2420 qcom,ports-hstart = /bits/ 8 <0xff 0xff 0xff 0xff>;
2421 qcom,ports-hstop = /bits/ 8 <0xff 0xff 0xff 0xff>;
2422 qcom,ports-word-length = /bits/ 8 <0xff 0xff 0xff 0xff>;
2423 qcom,ports-block-pack-mode = /bits/ 8 <0xff 0xff 0xff 0xff>;
2424 qcom,ports-block-group-count = /bits/ 8 <0xff 0xff 0xff 0xff>;
2425 qcom,ports-lane-control = /bits/ 8 <0x01 0x02 0x00 0x00>;
2426
2427 #address-cells = <2>;
2428 #size-cells = <0>;
2429 #sound-dai-cells = <1>;
2430 status = "disabled";
2431 };
2432
2433 lpass_vamacro: codec@6d44000 {
2434 compatible = "qcom,sm8550-lpass-va-macro";
2435 reg = <0 0x06d44000 0 0x1000>;
2436 clocks = <&q6prmcc LPASS_CLK_ID_TX_CORE_MCLK LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2437 <&q6prmcc LPASS_HW_MACRO_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2438 <&q6prmcc LPASS_HW_DCODEC_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>;
2439 clock-names = "mclk", "macro", "dcodec";
2440
Tom Rini53633a82024-02-29 12:33:36 -05002441 #clock-cells = <0>;
2442 clock-output-names = "fsgen";
2443 #sound-dai-cells = <1>;
2444 };
2445
2446 lpass_tlmm: pinctrl@6e80000 {
2447 compatible = "qcom,sm8550-lpass-lpi-pinctrl";
2448 reg = <0 0x06e80000 0 0x20000>,
2449 <0 0x07250000 0 0x10000>;
2450 gpio-controller;
2451 #gpio-cells = <2>;
2452 gpio-ranges = <&lpass_tlmm 0 0 23>;
2453
2454 clocks = <&q6prmcc LPASS_HW_MACRO_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>,
2455 <&q6prmcc LPASS_HW_DCODEC_VOTE LPASS_CLK_ATTRIBUTE_COUPLE_NO>;
2456 clock-names = "core", "audio";
2457
2458 tx_swr_active: tx-swr-active-state {
2459 clk-pins {
2460 pins = "gpio0";
2461 function = "swr_tx_clk";
2462 drive-strength = <2>;
2463 slew-rate = <1>;
2464 bias-disable;
2465 };
2466
2467 data-pins {
2468 pins = "gpio1", "gpio2", "gpio14";
2469 function = "swr_tx_data";
2470 drive-strength = <2>;
2471 slew-rate = <1>;
2472 bias-bus-hold;
2473 };
2474 };
2475
2476 rx_swr_active: rx-swr-active-state {
2477 clk-pins {
2478 pins = "gpio3";
2479 function = "swr_rx_clk";
2480 drive-strength = <2>;
2481 slew-rate = <1>;
2482 bias-disable;
2483 };
2484
2485 data-pins {
2486 pins = "gpio4", "gpio5";
2487 function = "swr_rx_data";
2488 drive-strength = <2>;
2489 slew-rate = <1>;
2490 bias-bus-hold;
2491 };
2492 };
2493
2494 dmic01_default: dmic01-default-state {
2495 clk-pins {
2496 pins = "gpio6";
2497 function = "dmic1_clk";
2498 drive-strength = <8>;
2499 output-high;
2500 };
2501
2502 data-pins {
2503 pins = "gpio7";
2504 function = "dmic1_data";
2505 drive-strength = <8>;
2506 input-enable;
2507 };
2508 };
2509
2510 dmic02_default: dmic02-default-state {
2511 clk-pins {
2512 pins = "gpio8";
2513 function = "dmic2_clk";
2514 drive-strength = <8>;
2515 output-high;
2516 };
2517
2518 data-pins {
2519 pins = "gpio9";
2520 function = "dmic2_data";
2521 drive-strength = <8>;
2522 input-enable;
2523 };
2524 };
2525
2526 wsa_swr_active: wsa-swr-active-state {
2527 clk-pins {
2528 pins = "gpio10";
2529 function = "wsa_swr_clk";
2530 drive-strength = <2>;
2531 slew-rate = <1>;
2532 bias-disable;
2533 };
2534
2535 data-pins {
2536 pins = "gpio11";
2537 function = "wsa_swr_data";
2538 drive-strength = <2>;
2539 slew-rate = <1>;
2540 bias-bus-hold;
2541 };
2542 };
2543
2544 wsa2_swr_active: wsa2-swr-active-state {
2545 clk-pins {
2546 pins = "gpio15";
2547 function = "wsa2_swr_clk";
2548 drive-strength = <2>;
2549 slew-rate = <1>;
2550 bias-disable;
2551 };
2552
2553 data-pins {
2554 pins = "gpio16";
2555 function = "wsa2_swr_data";
2556 drive-strength = <2>;
2557 slew-rate = <1>;
2558 bias-bus-hold;
2559 };
2560 };
2561 };
2562
2563 lpass_lpiaon_noc: interconnect@7400000 {
2564 compatible = "qcom,sm8550-lpass-lpiaon-noc";
2565 reg = <0 0x07400000 0 0x19080>;
2566 #interconnect-cells = <2>;
2567 qcom,bcm-voters = <&apps_bcm_voter>;
2568 };
2569
2570 lpass_lpicx_noc: interconnect@7430000 {
2571 compatible = "qcom,sm8550-lpass-lpicx-noc";
2572 reg = <0 0x07430000 0 0x3a200>;
2573 #interconnect-cells = <2>;
2574 qcom,bcm-voters = <&apps_bcm_voter>;
2575 };
2576
2577 lpass_ag_noc: interconnect@7e40000 {
2578 compatible = "qcom,sm8550-lpass-ag-noc";
2579 reg = <0 0x07e40000 0 0xe080>;
2580 #interconnect-cells = <2>;
2581 qcom,bcm-voters = <&apps_bcm_voter>;
2582 };
2583
2584 sdhc_2: mmc@8804000 {
2585 compatible = "qcom,sm8550-sdhci", "qcom,sdhci-msm-v5";
2586 reg = <0 0x08804000 0 0x1000>;
2587
2588 interrupts = <GIC_SPI 207 IRQ_TYPE_LEVEL_HIGH>,
2589 <GIC_SPI 223 IRQ_TYPE_LEVEL_HIGH>;
2590 interrupt-names = "hc_irq", "pwr_irq";
2591
2592 clocks = <&gcc GCC_SDCC2_AHB_CLK>,
2593 <&gcc GCC_SDCC2_APPS_CLK>,
2594 <&rpmhcc RPMH_CXO_CLK>;
2595 clock-names = "iface", "core", "xo";
2596 iommus = <&apps_smmu 0x540 0>;
2597 qcom,dll-config = <0x0007642c>;
2598 qcom,ddr-config = <0x80040868>;
2599 power-domains = <&rpmhpd RPMHPD_CX>;
2600 operating-points-v2 = <&sdhc2_opp_table>;
2601
2602 interconnects = <&aggre2_noc MASTER_SDCC_2 0 &mc_virt SLAVE_EBI1 0>,
2603 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_SDCC_2 0>;
2604 interconnect-names = "sdhc-ddr", "cpu-sdhc";
2605 bus-width = <4>;
2606 dma-coherent;
2607
2608 /* Forbid SDR104/SDR50 - broken hw! */
2609 sdhci-caps-mask = <0x3 0>;
2610
2611 status = "disabled";
2612
2613 sdhc2_opp_table: opp-table {
2614 compatible = "operating-points-v2";
2615
2616 opp-19200000 {
2617 opp-hz = /bits/ 64 <19200000>;
2618 required-opps = <&rpmhpd_opp_min_svs>;
2619 };
2620
2621 opp-50000000 {
2622 opp-hz = /bits/ 64 <50000000>;
2623 required-opps = <&rpmhpd_opp_low_svs>;
2624 };
2625
2626 opp-100000000 {
2627 opp-hz = /bits/ 64 <100000000>;
2628 required-opps = <&rpmhpd_opp_svs>;
2629 };
2630
2631 opp-202000000 {
2632 opp-hz = /bits/ 64 <202000000>;
2633 required-opps = <&rpmhpd_opp_svs_l1>;
2634 };
2635 };
2636 };
2637
2638 videocc: clock-controller@aaf0000 {
2639 compatible = "qcom,sm8550-videocc";
2640 reg = <0 0x0aaf0000 0 0x10000>;
2641 clocks = <&bi_tcxo_div2>,
2642 <&gcc GCC_VIDEO_AHB_CLK>;
2643 power-domains = <&rpmhpd RPMHPD_MMCX>;
2644 required-opps = <&rpmhpd_opp_low_svs>;
2645 #clock-cells = <1>;
2646 #reset-cells = <1>;
2647 #power-domain-cells = <1>;
2648 };
2649
2650 camcc: clock-controller@ade0000 {
2651 compatible = "qcom,sm8550-camcc";
2652 reg = <0 0x0ade0000 0 0x20000>;
2653 clocks = <&gcc GCC_CAMERA_AHB_CLK>,
2654 <&bi_tcxo_div2>,
2655 <&bi_tcxo_ao_div2>,
2656 <&sleep_clk>;
2657 power-domains = <&rpmhpd SM8550_MMCX>;
2658 required-opps = <&rpmhpd_opp_low_svs>;
2659 #clock-cells = <1>;
2660 #reset-cells = <1>;
2661 #power-domain-cells = <1>;
2662 };
2663
2664 mdss: display-subsystem@ae00000 {
2665 compatible = "qcom,sm8550-mdss";
2666 reg = <0 0x0ae00000 0 0x1000>;
2667 reg-names = "mdss";
2668
2669 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
2670 interrupt-controller;
2671 #interrupt-cells = <1>;
2672
2673 clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>,
2674 <&gcc GCC_DISP_AHB_CLK>,
2675 <&gcc GCC_DISP_HF_AXI_CLK>,
2676 <&dispcc DISP_CC_MDSS_MDP_CLK>;
2677
2678 resets = <&dispcc DISP_CC_MDSS_CORE_BCR>;
2679
2680 power-domains = <&dispcc MDSS_GDSC>;
2681
2682 interconnects = <&mmss_noc MASTER_MDP 0 &gem_noc SLAVE_LLCC 0>,
2683 <&mc_virt MASTER_LLCC 0 &mc_virt SLAVE_EBI1 0>;
2684 interconnect-names = "mdp0-mem", "mdp1-mem";
2685
2686 iommus = <&apps_smmu 0x1c00 0x2>;
2687
2688 #address-cells = <2>;
2689 #size-cells = <2>;
2690 ranges;
2691
2692 status = "disabled";
2693
2694 mdss_mdp: display-controller@ae01000 {
2695 compatible = "qcom,sm8550-dpu";
2696 reg = <0 0x0ae01000 0 0x8f000>,
2697 <0 0x0aeb0000 0 0x2008>;
2698 reg-names = "mdp", "vbif";
2699
2700 interrupt-parent = <&mdss>;
2701 interrupts = <0>;
2702
2703 clocks = <&gcc GCC_DISP_AHB_CLK>,
2704 <&gcc GCC_DISP_HF_AXI_CLK>,
2705 <&dispcc DISP_CC_MDSS_AHB_CLK>,
2706 <&dispcc DISP_CC_MDSS_MDP_LUT_CLK>,
2707 <&dispcc DISP_CC_MDSS_MDP_CLK>,
2708 <&dispcc DISP_CC_MDSS_VSYNC_CLK>;
2709 clock-names = "bus",
2710 "nrt_bus",
2711 "iface",
2712 "lut",
2713 "core",
2714 "vsync";
2715
2716 power-domains = <&rpmhpd RPMHPD_MMCX>;
2717
2718 assigned-clocks = <&dispcc DISP_CC_MDSS_VSYNC_CLK>;
2719 assigned-clock-rates = <19200000>;
2720
2721 operating-points-v2 = <&mdp_opp_table>;
2722
2723 ports {
2724 #address-cells = <1>;
2725 #size-cells = <0>;
2726
2727 port@0 {
2728 reg = <0>;
2729 dpu_intf1_out: endpoint {
2730 remote-endpoint = <&mdss_dsi0_in>;
2731 };
2732 };
2733
2734 port@1 {
2735 reg = <1>;
2736 dpu_intf2_out: endpoint {
2737 remote-endpoint = <&mdss_dsi1_in>;
2738 };
2739 };
2740
2741 port@2 {
2742 reg = <2>;
2743 dpu_intf0_out: endpoint {
2744 remote-endpoint = <&mdss_dp0_in>;
2745 };
2746 };
2747 };
2748
2749 mdp_opp_table: opp-table {
2750 compatible = "operating-points-v2";
2751
2752 opp-200000000 {
2753 opp-hz = /bits/ 64 <200000000>;
2754 required-opps = <&rpmhpd_opp_low_svs>;
2755 };
2756
2757 opp-325000000 {
2758 opp-hz = /bits/ 64 <325000000>;
2759 required-opps = <&rpmhpd_opp_svs>;
2760 };
2761
2762 opp-375000000 {
2763 opp-hz = /bits/ 64 <375000000>;
2764 required-opps = <&rpmhpd_opp_svs_l1>;
2765 };
2766
2767 opp-514000000 {
2768 opp-hz = /bits/ 64 <514000000>;
2769 required-opps = <&rpmhpd_opp_nom>;
2770 };
2771 };
2772 };
2773
2774 mdss_dp0: displayport-controller@ae90000 {
2775 compatible = "qcom,sm8550-dp", "qcom,sm8350-dp";
2776 reg = <0 0xae90000 0 0x200>,
2777 <0 0xae90200 0 0x200>,
2778 <0 0xae90400 0 0xc00>,
2779 <0 0xae91000 0 0x400>,
2780 <0 0xae91400 0 0x400>;
2781 interrupt-parent = <&mdss>;
2782 interrupts = <12>;
2783 clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>,
2784 <&dispcc DISP_CC_MDSS_DPTX0_AUX_CLK>,
2785 <&dispcc DISP_CC_MDSS_DPTX0_LINK_CLK>,
2786 <&dispcc DISP_CC_MDSS_DPTX0_LINK_INTF_CLK>,
2787 <&dispcc DISP_CC_MDSS_DPTX0_PIXEL0_CLK>;
2788 clock-names = "core_iface",
2789 "core_aux",
2790 "ctrl_link",
2791 "ctrl_link_iface",
2792 "stream_pixel";
2793
2794 assigned-clocks = <&dispcc DISP_CC_MDSS_DPTX0_LINK_CLK_SRC>,
2795 <&dispcc DISP_CC_MDSS_DPTX0_PIXEL0_CLK_SRC>;
2796 assigned-clock-parents = <&usb_dp_qmpphy QMP_USB43DP_DP_LINK_CLK>,
2797 <&usb_dp_qmpphy QMP_USB43DP_DP_VCO_DIV_CLK>;
2798
2799 phys = <&usb_dp_qmpphy QMP_USB43DP_DP_PHY>;
2800 phy-names = "dp";
2801
2802 #sound-dai-cells = <0>;
2803
2804 operating-points-v2 = <&dp_opp_table>;
2805 power-domains = <&rpmhpd RPMHPD_MMCX>;
2806
2807 status = "disabled";
2808
2809 ports {
2810 #address-cells = <1>;
2811 #size-cells = <0>;
2812
2813 port@0 {
2814 reg = <0>;
2815 mdss_dp0_in: endpoint {
2816 remote-endpoint = <&dpu_intf0_out>;
2817 };
2818 };
2819
2820 port@1 {
2821 reg = <1>;
2822 mdss_dp0_out: endpoint {
2823 };
2824 };
2825 };
2826
2827 dp_opp_table: opp-table {
2828 compatible = "operating-points-v2";
2829
2830 opp-162000000 {
2831 opp-hz = /bits/ 64 <162000000>;
2832 required-opps = <&rpmhpd_opp_low_svs_d1>;
2833 };
2834
2835 opp-270000000 {
2836 opp-hz = /bits/ 64 <270000000>;
2837 required-opps = <&rpmhpd_opp_low_svs>;
2838 };
2839
2840 opp-540000000 {
2841 opp-hz = /bits/ 64 <540000000>;
2842 required-opps = <&rpmhpd_opp_svs_l1>;
2843 };
2844
2845 opp-810000000 {
2846 opp-hz = /bits/ 64 <810000000>;
2847 required-opps = <&rpmhpd_opp_nom>;
2848 };
2849 };
2850 };
2851
2852 mdss_dsi0: dsi@ae94000 {
2853 compatible = "qcom,sm8550-dsi-ctrl", "qcom,mdss-dsi-ctrl";
2854 reg = <0 0x0ae94000 0 0x400>;
2855 reg-names = "dsi_ctrl";
2856
2857 interrupt-parent = <&mdss>;
2858 interrupts = <4>;
2859
2860 clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK>,
2861 <&dispcc DISP_CC_MDSS_BYTE0_INTF_CLK>,
2862 <&dispcc DISP_CC_MDSS_PCLK0_CLK>,
2863 <&dispcc DISP_CC_MDSS_ESC0_CLK>,
2864 <&dispcc DISP_CC_MDSS_AHB_CLK>,
2865 <&gcc GCC_DISP_HF_AXI_CLK>;
2866 clock-names = "byte",
2867 "byte_intf",
2868 "pixel",
2869 "core",
2870 "iface",
2871 "bus";
2872
2873 power-domains = <&rpmhpd RPMHPD_MMCX>;
2874
2875 assigned-clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK_SRC>,
2876 <&dispcc DISP_CC_MDSS_PCLK0_CLK_SRC>;
2877 assigned-clock-parents = <&mdss_dsi0_phy 0>,
2878 <&mdss_dsi0_phy 1>;
2879
2880 operating-points-v2 = <&mdss_dsi_opp_table>;
2881
2882 phys = <&mdss_dsi0_phy>;
2883 phy-names = "dsi";
2884
2885 #address-cells = <1>;
2886 #size-cells = <0>;
2887
2888 status = "disabled";
2889
2890 ports {
2891 #address-cells = <1>;
2892 #size-cells = <0>;
2893
2894 port@0 {
2895 reg = <0>;
2896 mdss_dsi0_in: endpoint {
2897 remote-endpoint = <&dpu_intf1_out>;
2898 };
2899 };
2900
2901 port@1 {
2902 reg = <1>;
2903 mdss_dsi0_out: endpoint {
2904 };
2905 };
2906 };
2907
2908 mdss_dsi_opp_table: opp-table {
2909 compatible = "operating-points-v2";
2910
2911 opp-187500000 {
2912 opp-hz = /bits/ 64 <187500000>;
2913 required-opps = <&rpmhpd_opp_low_svs>;
2914 };
2915
2916 opp-300000000 {
2917 opp-hz = /bits/ 64 <300000000>;
2918 required-opps = <&rpmhpd_opp_svs>;
2919 };
2920
2921 opp-358000000 {
2922 opp-hz = /bits/ 64 <358000000>;
2923 required-opps = <&rpmhpd_opp_svs_l1>;
2924 };
2925 };
2926 };
2927
2928 mdss_dsi0_phy: phy@ae95000 {
2929 compatible = "qcom,sm8550-dsi-phy-4nm";
2930 reg = <0 0x0ae95000 0 0x200>,
2931 <0 0x0ae95200 0 0x280>,
2932 <0 0x0ae95500 0 0x400>;
2933 reg-names = "dsi_phy",
2934 "dsi_phy_lane",
2935 "dsi_pll";
2936
2937 clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>,
2938 <&rpmhcc RPMH_CXO_CLK>;
2939 clock-names = "iface", "ref";
2940
2941 #clock-cells = <1>;
2942 #phy-cells = <0>;
2943
2944 status = "disabled";
2945 };
2946
2947 mdss_dsi1: dsi@ae96000 {
2948 compatible = "qcom,sm8550-dsi-ctrl", "qcom,mdss-dsi-ctrl";
2949 reg = <0 0x0ae96000 0 0x400>;
2950 reg-names = "dsi_ctrl";
2951
2952 interrupt-parent = <&mdss>;
2953 interrupts = <5>;
2954
2955 clocks = <&dispcc DISP_CC_MDSS_BYTE1_CLK>,
2956 <&dispcc DISP_CC_MDSS_BYTE1_INTF_CLK>,
2957 <&dispcc DISP_CC_MDSS_PCLK1_CLK>,
2958 <&dispcc DISP_CC_MDSS_ESC1_CLK>,
2959 <&dispcc DISP_CC_MDSS_AHB_CLK>,
2960 <&gcc GCC_DISP_HF_AXI_CLK>;
2961 clock-names = "byte",
2962 "byte_intf",
2963 "pixel",
2964 "core",
2965 "iface",
2966 "bus";
2967
2968 power-domains = <&rpmhpd RPMHPD_MMCX>;
2969
2970 assigned-clocks = <&dispcc DISP_CC_MDSS_BYTE1_CLK_SRC>,
2971 <&dispcc DISP_CC_MDSS_PCLK1_CLK_SRC>;
2972 assigned-clock-parents = <&mdss_dsi1_phy 0>,
2973 <&mdss_dsi1_phy 1>;
2974
2975 operating-points-v2 = <&mdss_dsi_opp_table>;
2976
2977 phys = <&mdss_dsi1_phy>;
2978 phy-names = "dsi";
2979
2980 #address-cells = <1>;
2981 #size-cells = <0>;
2982
2983 status = "disabled";
2984
2985 ports {
2986 #address-cells = <1>;
2987 #size-cells = <0>;
2988
2989 port@0 {
2990 reg = <0>;
2991 mdss_dsi1_in: endpoint {
2992 remote-endpoint = <&dpu_intf2_out>;
2993 };
2994 };
2995
2996 port@1 {
2997 reg = <1>;
2998 mdss_dsi1_out: endpoint {
2999 };
3000 };
3001 };
3002 };
3003
3004 mdss_dsi1_phy: phy@ae97000 {
3005 compatible = "qcom,sm8550-dsi-phy-4nm";
3006 reg = <0 0x0ae97000 0 0x200>,
3007 <0 0x0ae97200 0 0x280>,
3008 <0 0x0ae97500 0 0x400>;
3009 reg-names = "dsi_phy",
3010 "dsi_phy_lane",
3011 "dsi_pll";
3012
3013 clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>,
3014 <&rpmhcc RPMH_CXO_CLK>;
3015 clock-names = "iface", "ref";
3016
3017 #clock-cells = <1>;
3018 #phy-cells = <0>;
3019
3020 status = "disabled";
3021 };
3022 };
3023
3024 dispcc: clock-controller@af00000 {
3025 compatible = "qcom,sm8550-dispcc";
3026 reg = <0 0x0af00000 0 0x20000>;
3027 clocks = <&bi_tcxo_div2>,
3028 <&bi_tcxo_ao_div2>,
3029 <&gcc GCC_DISP_AHB_CLK>,
3030 <&sleep_clk>,
3031 <&mdss_dsi0_phy 0>,
3032 <&mdss_dsi0_phy 1>,
3033 <&mdss_dsi1_phy 0>,
3034 <&mdss_dsi1_phy 1>,
3035 <&usb_dp_qmpphy QMP_USB43DP_DP_LINK_CLK>,
3036 <&usb_dp_qmpphy QMP_USB43DP_DP_VCO_DIV_CLK>,
3037 <0>, /* dp1 */
3038 <0>,
3039 <0>, /* dp2 */
3040 <0>,
3041 <0>, /* dp3 */
3042 <0>;
3043 power-domains = <&rpmhpd RPMHPD_MMCX>;
3044 required-opps = <&rpmhpd_opp_low_svs>;
3045 #clock-cells = <1>;
3046 #reset-cells = <1>;
3047 #power-domain-cells = <1>;
3048 };
3049
3050 usb_1_hsphy: phy@88e3000 {
3051 compatible = "qcom,sm8550-snps-eusb2-phy";
3052 reg = <0x0 0x088e3000 0x0 0x154>;
3053 #phy-cells = <0>;
3054
3055 clocks = <&tcsr TCSR_USB2_CLKREF_EN>;
3056 clock-names = "ref";
3057
3058 resets = <&gcc GCC_QUSB2PHY_PRIM_BCR>;
3059
3060 status = "disabled";
3061 };
3062
3063 usb_dp_qmpphy: phy@88e8000 {
3064 compatible = "qcom,sm8550-qmp-usb3-dp-phy";
3065 reg = <0x0 0x088e8000 0x0 0x3000>;
3066
3067 clocks = <&gcc GCC_USB3_PRIM_PHY_AUX_CLK>,
3068 <&rpmhcc RPMH_CXO_CLK>,
3069 <&gcc GCC_USB3_PRIM_PHY_COM_AUX_CLK>,
3070 <&gcc GCC_USB3_PRIM_PHY_PIPE_CLK>;
3071 clock-names = "aux", "ref", "com_aux", "usb3_pipe";
3072
3073 power-domains = <&gcc USB3_PHY_GDSC>;
3074
3075 resets = <&gcc GCC_USB3_PHY_PRIM_BCR>,
3076 <&gcc GCC_USB3_DP_PHY_PRIM_BCR>;
3077 reset-names = "phy", "common";
3078
3079 #clock-cells = <1>;
3080 #phy-cells = <1>;
3081
3082 status = "disabled";
3083
3084 ports {
3085 #address-cells = <1>;
3086 #size-cells = <0>;
3087
3088 port@0 {
3089 reg = <0>;
3090
3091 usb_dp_qmpphy_out: endpoint {
3092 };
3093 };
3094
3095 port@1 {
3096 reg = <1>;
3097
3098 usb_dp_qmpphy_usb_ss_in: endpoint {
3099 };
3100 };
3101
3102 port@2 {
3103 reg = <2>;
3104
3105 usb_dp_qmpphy_dp_in: endpoint {
3106 };
3107 };
3108 };
3109 };
3110
3111 usb_1: usb@a6f8800 {
3112 compatible = "qcom,sm8550-dwc3", "qcom,dwc3";
3113 reg = <0x0 0x0a6f8800 0x0 0x400>;
3114 #address-cells = <2>;
3115 #size-cells = <2>;
3116 ranges;
3117
3118 clocks = <&gcc GCC_CFG_NOC_USB3_PRIM_AXI_CLK>,
3119 <&gcc GCC_USB30_PRIM_MASTER_CLK>,
3120 <&gcc GCC_AGGRE_USB3_PRIM_AXI_CLK>,
3121 <&gcc GCC_USB30_PRIM_SLEEP_CLK>,
3122 <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>,
3123 <&tcsr TCSR_USB3_CLKREF_EN>;
3124 clock-names = "cfg_noc",
3125 "core",
3126 "iface",
3127 "sleep",
3128 "mock_utmi",
3129 "xo";
3130
3131 assigned-clocks = <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>,
3132 <&gcc GCC_USB30_PRIM_MASTER_CLK>;
3133 assigned-clock-rates = <19200000>, <200000000>;
3134
3135 interrupts-extended = <&intc GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>,
3136 <&pdc 17 IRQ_TYPE_LEVEL_HIGH>,
Tom Rini93743d22024-04-01 09:08:13 -04003137 <&pdc 15 IRQ_TYPE_EDGE_BOTH>,
3138 <&pdc 14 IRQ_TYPE_EDGE_BOTH>;
Tom Rini53633a82024-02-29 12:33:36 -05003139 interrupt-names = "hs_phy_irq",
3140 "ss_phy_irq",
3141 "dm_hs_phy_irq",
3142 "dp_hs_phy_irq";
3143
3144 power-domains = <&gcc USB30_PRIM_GDSC>;
3145 required-opps = <&rpmhpd_opp_nom>;
3146
3147 resets = <&gcc GCC_USB30_PRIM_BCR>;
3148
3149 interconnects = <&aggre1_noc MASTER_USB3_0 0 &mc_virt SLAVE_EBI1 0>,
3150 <&gem_noc MASTER_APPSS_PROC 0 &config_noc SLAVE_USB3_0 0>;
3151 interconnect-names = "usb-ddr", "apps-usb";
3152
3153 status = "disabled";
3154
3155 usb_1_dwc3: usb@a600000 {
3156 compatible = "snps,dwc3";
3157 reg = <0x0 0x0a600000 0x0 0xcd00>;
3158 interrupts = <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>;
3159 iommus = <&apps_smmu 0x40 0x0>;
3160 snps,dis_u2_susphy_quirk;
3161 snps,dis_enblslpm_quirk;
3162 snps,usb3_lpm_capable;
3163 phys = <&usb_1_hsphy>,
3164 <&usb_dp_qmpphy QMP_USB43DP_USB3_PHY>;
3165 phy-names = "usb2-phy", "usb3-phy";
3166
3167 ports {
3168 #address-cells = <1>;
3169 #size-cells = <0>;
3170
3171 port@0 {
3172 reg = <0>;
3173
3174 usb_1_dwc3_hs: endpoint {
3175 };
3176 };
3177
3178 port@1 {
3179 reg = <1>;
3180
3181 usb_1_dwc3_ss: endpoint {
3182 };
3183 };
3184 };
3185 };
3186 };
3187
3188 pdc: interrupt-controller@b220000 {
3189 compatible = "qcom,sm8550-pdc", "qcom,pdc";
3190 reg = <0 0x0b220000 0 0x30000>, <0 0x174000f0 0 0x64>;
3191 qcom,pdc-ranges = <0 480 94>, <94 609 31>,
3192 <125 63 1>, <126 716 12>,
3193 <138 251 5>;
3194 #interrupt-cells = <2>;
3195 interrupt-parent = <&intc>;
3196 interrupt-controller;
3197 };
3198
3199 tsens0: thermal-sensor@c271000 {
3200 compatible = "qcom,sm8550-tsens", "qcom,tsens-v2";
3201 reg = <0 0x0c271000 0 0x1000>, /* TM */
3202 <0 0x0c222000 0 0x1000>; /* SROT */
3203 #qcom,sensors = <16>;
3204 interrupts = <GIC_SPI 506 IRQ_TYPE_LEVEL_HIGH>,
3205 <GIC_SPI 640 IRQ_TYPE_LEVEL_HIGH>;
3206 interrupt-names = "uplow", "critical";
3207 #thermal-sensor-cells = <1>;
3208 };
3209
3210 tsens1: thermal-sensor@c272000 {
3211 compatible = "qcom,sm8550-tsens", "qcom,tsens-v2";
3212 reg = <0 0x0c272000 0 0x1000>, /* TM */
3213 <0 0x0c223000 0 0x1000>; /* SROT */
3214 #qcom,sensors = <16>;
3215 interrupts = <GIC_SPI 507 IRQ_TYPE_LEVEL_HIGH>,
3216 <GIC_SPI 641 IRQ_TYPE_LEVEL_HIGH>;
3217 interrupt-names = "uplow", "critical";
3218 #thermal-sensor-cells = <1>;
3219 };
3220
3221 tsens2: thermal-sensor@c273000 {
3222 compatible = "qcom,sm8550-tsens", "qcom,tsens-v2";
3223 reg = <0 0x0c273000 0 0x1000>, /* TM */
3224 <0 0x0c224000 0 0x1000>; /* SROT */
3225 #qcom,sensors = <16>;
3226 interrupts = <GIC_SPI 508 IRQ_TYPE_LEVEL_HIGH>,
3227 <GIC_SPI 642 IRQ_TYPE_LEVEL_HIGH>;
3228 interrupt-names = "uplow", "critical";
3229 #thermal-sensor-cells = <1>;
3230 };
3231
3232 aoss_qmp: power-management@c300000 {
3233 compatible = "qcom,sm8550-aoss-qmp", "qcom,aoss-qmp";
3234 reg = <0 0x0c300000 0 0x400>;
3235 interrupt-parent = <&ipcc>;
3236 interrupts-extended = <&ipcc IPCC_CLIENT_AOP IPCC_MPROC_SIGNAL_GLINK_QMP
3237 IRQ_TYPE_EDGE_RISING>;
3238 mboxes = <&ipcc IPCC_CLIENT_AOP IPCC_MPROC_SIGNAL_GLINK_QMP>;
3239
3240 #clock-cells = <0>;
3241 };
3242
3243 sram@c3f0000 {
3244 compatible = "qcom,rpmh-stats";
3245 reg = <0 0x0c3f0000 0 0x400>;
3246 };
3247
3248 spmi_bus: spmi@c400000 {
3249 compatible = "qcom,spmi-pmic-arb";
3250 reg = <0 0x0c400000 0 0x3000>,
3251 <0 0x0c500000 0 0x4000000>,
3252 <0 0x0c440000 0 0x80000>,
3253 <0 0x0c4c0000 0 0x20000>,
3254 <0 0x0c42d000 0 0x4000>;
3255 reg-names = "core", "chnls", "obsrvr", "intr", "cnfg";
3256 interrupt-names = "periph_irq";
3257 interrupts-extended = <&pdc 1 IRQ_TYPE_LEVEL_HIGH>;
3258 qcom,ee = <0>;
3259 qcom,channel = <0>;
3260 qcom,bus-id = <0>;
3261 #address-cells = <2>;
3262 #size-cells = <0>;
3263 interrupt-controller;
3264 #interrupt-cells = <4>;
3265 };
3266
3267 tlmm: pinctrl@f100000 {
3268 compatible = "qcom,sm8550-tlmm";
3269 reg = <0 0x0f100000 0 0x300000>;
3270 interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>;
3271 gpio-controller;
3272 #gpio-cells = <2>;
3273 interrupt-controller;
3274 #interrupt-cells = <2>;
3275 gpio-ranges = <&tlmm 0 0 211>;
3276 wakeup-parent = <&pdc>;
3277
3278 hub_i2c0_data_clk: hub-i2c0-data-clk-state {
3279 /* SDA, SCL */
3280 pins = "gpio16", "gpio17";
3281 function = "i2chub0_se0";
3282 drive-strength = <2>;
3283 bias-pull-up;
3284 };
3285
3286 hub_i2c1_data_clk: hub-i2c1-data-clk-state {
3287 /* SDA, SCL */
3288 pins = "gpio18", "gpio19";
3289 function = "i2chub0_se1";
3290 drive-strength = <2>;
3291 bias-pull-up;
3292 };
3293
3294 hub_i2c2_data_clk: hub-i2c2-data-clk-state {
3295 /* SDA, SCL */
3296 pins = "gpio20", "gpio21";
3297 function = "i2chub0_se2";
3298 drive-strength = <2>;
3299 bias-pull-up;
3300 };
3301
3302 hub_i2c3_data_clk: hub-i2c3-data-clk-state {
3303 /* SDA, SCL */
3304 pins = "gpio22", "gpio23";
3305 function = "i2chub0_se3";
3306 drive-strength = <2>;
3307 bias-pull-up;
3308 };
3309
3310 hub_i2c4_data_clk: hub-i2c4-data-clk-state {
3311 /* SDA, SCL */
3312 pins = "gpio4", "gpio5";
3313 function = "i2chub0_se4";
3314 drive-strength = <2>;
3315 bias-pull-up;
3316 };
3317
3318 hub_i2c5_data_clk: hub-i2c5-data-clk-state {
3319 /* SDA, SCL */
3320 pins = "gpio6", "gpio7";
3321 function = "i2chub0_se5";
3322 drive-strength = <2>;
3323 bias-pull-up;
3324 };
3325
3326 hub_i2c6_data_clk: hub-i2c6-data-clk-state {
3327 /* SDA, SCL */
3328 pins = "gpio8", "gpio9";
3329 function = "i2chub0_se6";
3330 drive-strength = <2>;
3331 bias-pull-up;
3332 };
3333
3334 hub_i2c7_data_clk: hub-i2c7-data-clk-state {
3335 /* SDA, SCL */
3336 pins = "gpio10", "gpio11";
3337 function = "i2chub0_se7";
3338 drive-strength = <2>;
3339 bias-pull-up;
3340 };
3341
3342 hub_i2c8_data_clk: hub-i2c8-data-clk-state {
3343 /* SDA, SCL */
3344 pins = "gpio206", "gpio207";
3345 function = "i2chub0_se8";
3346 drive-strength = <2>;
3347 bias-pull-up;
3348 };
3349
3350 hub_i2c9_data_clk: hub-i2c9-data-clk-state {
3351 /* SDA, SCL */
3352 pins = "gpio84", "gpio85";
3353 function = "i2chub0_se9";
3354 drive-strength = <2>;
3355 bias-pull-up;
3356 };
3357
3358 pcie0_default_state: pcie0-default-state {
3359 perst-pins {
3360 pins = "gpio94";
3361 function = "gpio";
3362 drive-strength = <2>;
3363 bias-pull-down;
3364 };
3365
3366 clkreq-pins {
3367 pins = "gpio95";
3368 function = "pcie0_clk_req_n";
3369 drive-strength = <2>;
3370 bias-pull-up;
3371 };
3372
3373 wake-pins {
3374 pins = "gpio96";
3375 function = "gpio";
3376 drive-strength = <2>;
3377 bias-pull-up;
3378 };
3379 };
3380
3381 pcie1_default_state: pcie1-default-state {
3382 perst-pins {
3383 pins = "gpio97";
3384 function = "gpio";
3385 drive-strength = <2>;
3386 bias-pull-down;
3387 };
3388
3389 clkreq-pins {
3390 pins = "gpio98";
3391 function = "pcie1_clk_req_n";
3392 drive-strength = <2>;
3393 bias-pull-up;
3394 };
3395
3396 wake-pins {
3397 pins = "gpio99";
3398 function = "gpio";
3399 drive-strength = <2>;
3400 bias-pull-up;
3401 };
3402 };
3403
3404 qup_i2c0_data_clk: qup-i2c0-data-clk-state {
3405 /* SDA, SCL */
3406 pins = "gpio28", "gpio29";
3407 function = "qup1_se0";
3408 drive-strength = <2>;
3409 bias-pull-up = <2200>;
3410 };
3411
3412 qup_i2c1_data_clk: qup-i2c1-data-clk-state {
3413 /* SDA, SCL */
3414 pins = "gpio32", "gpio33";
3415 function = "qup1_se1";
3416 drive-strength = <2>;
3417 bias-pull-up = <2200>;
3418 };
3419
3420 qup_i2c2_data_clk: qup-i2c2-data-clk-state {
3421 /* SDA, SCL */
3422 pins = "gpio36", "gpio37";
3423 function = "qup1_se2";
3424 drive-strength = <2>;
3425 bias-pull-up = <2200>;
3426 };
3427
3428 qup_i2c3_data_clk: qup-i2c3-data-clk-state {
3429 /* SDA, SCL */
3430 pins = "gpio40", "gpio41";
3431 function = "qup1_se3";
3432 drive-strength = <2>;
3433 bias-pull-up = <2200>;
3434 };
3435
3436 qup_i2c4_data_clk: qup-i2c4-data-clk-state {
3437 /* SDA, SCL */
3438 pins = "gpio44", "gpio45";
3439 function = "qup1_se4";
3440 drive-strength = <2>;
3441 bias-pull-up = <2200>;
3442 };
3443
3444 qup_i2c5_data_clk: qup-i2c5-data-clk-state {
3445 /* SDA, SCL */
3446 pins = "gpio52", "gpio53";
3447 function = "qup1_se5";
3448 drive-strength = <2>;
3449 bias-pull-up = <2200>;
3450 };
3451
3452 qup_i2c6_data_clk: qup-i2c6-data-clk-state {
3453 /* SDA, SCL */
3454 pins = "gpio48", "gpio49";
3455 function = "qup1_se6";
3456 drive-strength = <2>;
3457 bias-pull-up = <2200>;
3458 };
3459
3460 qup_i2c8_data_clk: qup-i2c8-data-clk-state {
3461 scl-pins {
3462 pins = "gpio57";
3463 function = "qup2_se0_l1_mira";
3464 drive-strength = <2>;
3465 bias-pull-up = <2200>;
3466 };
3467
3468 sda-pins {
3469 pins = "gpio56";
3470 function = "qup2_se0_l0_mira";
3471 drive-strength = <2>;
3472 bias-pull-up = <2200>;
3473 };
3474 };
3475
3476 qup_i2c9_data_clk: qup-i2c9-data-clk-state {
3477 /* SDA, SCL */
3478 pins = "gpio60", "gpio61";
3479 function = "qup2_se1";
3480 drive-strength = <2>;
3481 bias-pull-up = <2200>;
3482 };
3483
3484 qup_i2c10_data_clk: qup-i2c10-data-clk-state {
3485 /* SDA, SCL */
3486 pins = "gpio64", "gpio65";
3487 function = "qup2_se2";
3488 drive-strength = <2>;
3489 bias-pull-up = <2200>;
3490 };
3491
3492 qup_i2c11_data_clk: qup-i2c11-data-clk-state {
3493 /* SDA, SCL */
3494 pins = "gpio68", "gpio69";
3495 function = "qup2_se3";
3496 drive-strength = <2>;
3497 bias-pull-up = <2200>;
3498 };
3499
3500 qup_i2c12_data_clk: qup-i2c12-data-clk-state {
3501 /* SDA, SCL */
3502 pins = "gpio2", "gpio3";
3503 function = "qup2_se4";
3504 drive-strength = <2>;
3505 bias-pull-up = <2200>;
3506 };
3507
3508 qup_i2c13_data_clk: qup-i2c13-data-clk-state {
3509 /* SDA, SCL */
3510 pins = "gpio80", "gpio81";
3511 function = "qup2_se5";
3512 drive-strength = <2>;
3513 bias-pull-up = <2200>;
3514 };
3515
3516 qup_i2c15_data_clk: qup-i2c15-data-clk-state {
3517 /* SDA, SCL */
3518 pins = "gpio72", "gpio106";
3519 function = "qup2_se7";
3520 drive-strength = <2>;
3521 bias-pull-up = <2200>;
3522 };
3523
3524 qup_spi0_cs: qup-spi0-cs-state {
3525 pins = "gpio31";
3526 function = "qup1_se0";
3527 drive-strength = <6>;
3528 bias-disable;
3529 };
3530
3531 qup_spi0_data_clk: qup-spi0-data-clk-state {
3532 /* MISO, MOSI, CLK */
3533 pins = "gpio28", "gpio29", "gpio30";
3534 function = "qup1_se0";
3535 drive-strength = <6>;
3536 bias-disable;
3537 };
3538
3539 qup_spi1_cs: qup-spi1-cs-state {
3540 pins = "gpio35";
3541 function = "qup1_se1";
3542 drive-strength = <6>;
3543 bias-disable;
3544 };
3545
3546 qup_spi1_data_clk: qup-spi1-data-clk-state {
3547 /* MISO, MOSI, CLK */
3548 pins = "gpio32", "gpio33", "gpio34";
3549 function = "qup1_se1";
3550 drive-strength = <6>;
3551 bias-disable;
3552 };
3553
3554 qup_spi2_cs: qup-spi2-cs-state {
3555 pins = "gpio39";
3556 function = "qup1_se2";
3557 drive-strength = <6>;
3558 bias-disable;
3559 };
3560
3561 qup_spi2_data_clk: qup-spi2-data-clk-state {
3562 /* MISO, MOSI, CLK */
3563 pins = "gpio36", "gpio37", "gpio38";
3564 function = "qup1_se2";
3565 drive-strength = <6>;
3566 bias-disable;
3567 };
3568
3569 qup_spi3_cs: qup-spi3-cs-state {
3570 pins = "gpio43";
3571 function = "qup1_se3";
3572 drive-strength = <6>;
3573 bias-disable;
3574 };
3575
3576 qup_spi3_data_clk: qup-spi3-data-clk-state {
3577 /* MISO, MOSI, CLK */
3578 pins = "gpio40", "gpio41", "gpio42";
3579 function = "qup1_se3";
3580 drive-strength = <6>;
3581 bias-disable;
3582 };
3583
3584 qup_spi4_cs: qup-spi4-cs-state {
3585 pins = "gpio47";
3586 function = "qup1_se4";
3587 drive-strength = <6>;
3588 bias-disable;
3589 };
3590
3591 qup_spi4_data_clk: qup-spi4-data-clk-state {
3592 /* MISO, MOSI, CLK */
3593 pins = "gpio44", "gpio45", "gpio46";
3594 function = "qup1_se4";
3595 drive-strength = <6>;
3596 bias-disable;
3597 };
3598
3599 qup_spi5_cs: qup-spi5-cs-state {
3600 pins = "gpio55";
3601 function = "qup1_se5";
3602 drive-strength = <6>;
3603 bias-disable;
3604 };
3605
3606 qup_spi5_data_clk: qup-spi5-data-clk-state {
3607 /* MISO, MOSI, CLK */
3608 pins = "gpio52", "gpio53", "gpio54";
3609 function = "qup1_se5";
3610 drive-strength = <6>;
3611 bias-disable;
3612 };
3613
3614 qup_spi6_cs: qup-spi6-cs-state {
3615 pins = "gpio51";
3616 function = "qup1_se6";
3617 drive-strength = <6>;
3618 bias-disable;
3619 };
3620
3621 qup_spi6_data_clk: qup-spi6-data-clk-state {
3622 /* MISO, MOSI, CLK */
3623 pins = "gpio48", "gpio49", "gpio50";
3624 function = "qup1_se6";
3625 drive-strength = <6>;
3626 bias-disable;
3627 };
3628
3629 qup_spi8_cs: qup-spi8-cs-state {
3630 pins = "gpio59";
3631 function = "qup2_se0_l3_mira";
3632 drive-strength = <6>;
3633 bias-disable;
3634 };
3635
3636 qup_spi8_data_clk: qup-spi8-data-clk-state {
3637 /* MISO, MOSI, CLK */
3638 pins = "gpio56", "gpio57", "gpio58";
3639 function = "qup2_se0_l2_mira";
3640 drive-strength = <6>;
3641 bias-disable;
3642 };
3643
3644 qup_spi9_cs: qup-spi9-cs-state {
3645 pins = "gpio63";
3646 function = "qup2_se1";
3647 drive-strength = <6>;
3648 bias-disable;
3649 };
3650
3651 qup_spi9_data_clk: qup-spi9-data-clk-state {
3652 /* MISO, MOSI, CLK */
3653 pins = "gpio60", "gpio61", "gpio62";
3654 function = "qup2_se1";
3655 drive-strength = <6>;
3656 bias-disable;
3657 };
3658
3659 qup_spi10_cs: qup-spi10-cs-state {
3660 pins = "gpio67";
3661 function = "qup2_se2";
3662 drive-strength = <6>;
3663 bias-disable;
3664 };
3665
3666 qup_spi10_data_clk: qup-spi10-data-clk-state {
3667 /* MISO, MOSI, CLK */
3668 pins = "gpio64", "gpio65", "gpio66";
3669 function = "qup2_se2";
3670 drive-strength = <6>;
3671 bias-disable;
3672 };
3673
3674 qup_spi11_cs: qup-spi11-cs-state {
3675 pins = "gpio71";
3676 function = "qup2_se3";
3677 drive-strength = <6>;
3678 bias-disable;
3679 };
3680
3681 qup_spi11_data_clk: qup-spi11-data-clk-state {
3682 /* MISO, MOSI, CLK */
3683 pins = "gpio68", "gpio69", "gpio70";
3684 function = "qup2_se3";
3685 drive-strength = <6>;
3686 bias-disable;
3687 };
3688
3689 qup_spi12_cs: qup-spi12-cs-state {
3690 pins = "gpio119";
3691 function = "qup2_se4";
3692 drive-strength = <6>;
3693 bias-disable;
3694 };
3695
3696 qup_spi12_data_clk: qup-spi12-data-clk-state {
3697 /* MISO, MOSI, CLK */
3698 pins = "gpio2", "gpio3", "gpio118";
3699 function = "qup2_se4";
3700 drive-strength = <6>;
3701 bias-disable;
3702 };
3703
3704 qup_spi13_cs: qup-spi13-cs-state {
3705 pins = "gpio83";
3706 function = "qup2_se5";
3707 drive-strength = <6>;
3708 bias-disable;
3709 };
3710
3711 qup_spi13_data_clk: qup-spi13-data-clk-state {
3712 /* MISO, MOSI, CLK */
3713 pins = "gpio80", "gpio81", "gpio82";
3714 function = "qup2_se5";
3715 drive-strength = <6>;
3716 bias-disable;
3717 };
3718
3719 qup_spi15_cs: qup-spi15-cs-state {
3720 pins = "gpio75";
3721 function = "qup2_se7";
3722 drive-strength = <6>;
3723 bias-disable;
3724 };
3725
3726 qup_spi15_data_clk: qup-spi15-data-clk-state {
3727 /* MISO, MOSI, CLK */
3728 pins = "gpio72", "gpio106", "gpio74";
3729 function = "qup2_se7";
3730 drive-strength = <6>;
3731 bias-disable;
3732 };
3733
3734 qup_uart7_default: qup-uart7-default-state {
3735 /* TX, RX */
3736 pins = "gpio26", "gpio27";
3737 function = "qup1_se7";
3738 drive-strength = <2>;
3739 bias-disable;
3740 };
3741
3742 qup_uart14_default: qup-uart14-default-state {
3743 /* TX, RX */
3744 pins = "gpio78", "gpio79";
3745 function = "qup2_se6";
3746 drive-strength = <2>;
3747 bias-pull-up;
3748 };
3749
3750 qup_uart14_cts_rts: qup-uart14-cts-rts-state {
3751 /* CTS, RTS */
3752 pins = "gpio76", "gpio77";
3753 function = "qup2_se6";
3754 drive-strength = <2>;
3755 bias-pull-down;
3756 };
3757
3758 sdc2_sleep: sdc2-sleep-state {
3759 clk-pins {
3760 pins = "sdc2_clk";
3761 bias-disable;
3762 drive-strength = <2>;
3763 };
3764
3765 cmd-pins {
3766 pins = "sdc2_cmd";
3767 bias-pull-up;
3768 drive-strength = <2>;
3769 };
3770
3771 data-pins {
3772 pins = "sdc2_data";
3773 bias-pull-up;
3774 drive-strength = <2>;
3775 };
3776 };
3777
3778 sdc2_default: sdc2-default-state {
3779 clk-pins {
3780 pins = "sdc2_clk";
3781 bias-disable;
3782 drive-strength = <16>;
3783 };
3784
3785 cmd-pins {
3786 pins = "sdc2_cmd";
3787 bias-pull-up;
3788 drive-strength = <10>;
3789 };
3790
3791 data-pins {
3792 pins = "sdc2_data";
3793 bias-pull-up;
3794 drive-strength = <10>;
3795 };
3796 };
3797 };
3798
3799 apps_smmu: iommu@15000000 {
3800 compatible = "qcom,sm8550-smmu-500", "qcom,smmu-500", "arm,mmu-500";
3801 reg = <0 0x15000000 0 0x100000>;
3802 #iommu-cells = <2>;
3803 #global-interrupts = <1>;
3804 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>,
3805 <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>,
3806 <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>,
3807 <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>,
3808 <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>,
3809 <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>,
3810 <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>,
3811 <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>,
3812 <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>,
3813 <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>,
3814 <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>,
3815 <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>,
3816 <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>,
3817 <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>,
3818 <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>,
3819 <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>,
3820 <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>,
3821 <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>,
3822 <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>,
3823 <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>,
3824 <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>,
3825 <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>,
3826 <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>,
3827 <GIC_SPI 181 IRQ_TYPE_LEVEL_HIGH>,
3828 <GIC_SPI 182 IRQ_TYPE_LEVEL_HIGH>,
3829 <GIC_SPI 183 IRQ_TYPE_LEVEL_HIGH>,
3830 <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>,
3831 <GIC_SPI 185 IRQ_TYPE_LEVEL_HIGH>,
3832 <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH>,
3833 <GIC_SPI 187 IRQ_TYPE_LEVEL_HIGH>,
3834 <GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>,
3835 <GIC_SPI 189 IRQ_TYPE_LEVEL_HIGH>,
3836 <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>,
3837 <GIC_SPI 191 IRQ_TYPE_LEVEL_HIGH>,
3838 <GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>,
3839 <GIC_SPI 315 IRQ_TYPE_LEVEL_HIGH>,
3840 <GIC_SPI 316 IRQ_TYPE_LEVEL_HIGH>,
3841 <GIC_SPI 317 IRQ_TYPE_LEVEL_HIGH>,
3842 <GIC_SPI 318 IRQ_TYPE_LEVEL_HIGH>,
3843 <GIC_SPI 319 IRQ_TYPE_LEVEL_HIGH>,
3844 <GIC_SPI 320 IRQ_TYPE_LEVEL_HIGH>,
3845 <GIC_SPI 321 IRQ_TYPE_LEVEL_HIGH>,
3846 <GIC_SPI 322 IRQ_TYPE_LEVEL_HIGH>,
3847 <GIC_SPI 323 IRQ_TYPE_LEVEL_HIGH>,
3848 <GIC_SPI 324 IRQ_TYPE_LEVEL_HIGH>,
3849 <GIC_SPI 325 IRQ_TYPE_LEVEL_HIGH>,
3850 <GIC_SPI 326 IRQ_TYPE_LEVEL_HIGH>,
3851 <GIC_SPI 327 IRQ_TYPE_LEVEL_HIGH>,
3852 <GIC_SPI 328 IRQ_TYPE_LEVEL_HIGH>,
3853 <GIC_SPI 329 IRQ_TYPE_LEVEL_HIGH>,
3854 <GIC_SPI 330 IRQ_TYPE_LEVEL_HIGH>,
3855 <GIC_SPI 331 IRQ_TYPE_LEVEL_HIGH>,
3856 <GIC_SPI 332 IRQ_TYPE_LEVEL_HIGH>,
3857 <GIC_SPI 333 IRQ_TYPE_LEVEL_HIGH>,
3858 <GIC_SPI 334 IRQ_TYPE_LEVEL_HIGH>,
3859 <GIC_SPI 335 IRQ_TYPE_LEVEL_HIGH>,
3860 <GIC_SPI 336 IRQ_TYPE_LEVEL_HIGH>,
3861 <GIC_SPI 337 IRQ_TYPE_LEVEL_HIGH>,
3862 <GIC_SPI 338 IRQ_TYPE_LEVEL_HIGH>,
3863 <GIC_SPI 339 IRQ_TYPE_LEVEL_HIGH>,
3864 <GIC_SPI 340 IRQ_TYPE_LEVEL_HIGH>,
3865 <GIC_SPI 341 IRQ_TYPE_LEVEL_HIGH>,
3866 <GIC_SPI 342 IRQ_TYPE_LEVEL_HIGH>,
3867 <GIC_SPI 343 IRQ_TYPE_LEVEL_HIGH>,
3868 <GIC_SPI 344 IRQ_TYPE_LEVEL_HIGH>,
3869 <GIC_SPI 345 IRQ_TYPE_LEVEL_HIGH>,
3870 <GIC_SPI 395 IRQ_TYPE_LEVEL_HIGH>,
3871 <GIC_SPI 396 IRQ_TYPE_LEVEL_HIGH>,
3872 <GIC_SPI 397 IRQ_TYPE_LEVEL_HIGH>,
3873 <GIC_SPI 398 IRQ_TYPE_LEVEL_HIGH>,
3874 <GIC_SPI 399 IRQ_TYPE_LEVEL_HIGH>,
3875 <GIC_SPI 400 IRQ_TYPE_LEVEL_HIGH>,
3876 <GIC_SPI 401 IRQ_TYPE_LEVEL_HIGH>,
3877 <GIC_SPI 402 IRQ_TYPE_LEVEL_HIGH>,
3878 <GIC_SPI 403 IRQ_TYPE_LEVEL_HIGH>,
3879 <GIC_SPI 404 IRQ_TYPE_LEVEL_HIGH>,
3880 <GIC_SPI 405 IRQ_TYPE_LEVEL_HIGH>,
3881 <GIC_SPI 406 IRQ_TYPE_LEVEL_HIGH>,
3882 <GIC_SPI 407 IRQ_TYPE_LEVEL_HIGH>,
3883 <GIC_SPI 408 IRQ_TYPE_LEVEL_HIGH>,
3884 <GIC_SPI 409 IRQ_TYPE_LEVEL_HIGH>,
3885 <GIC_SPI 418 IRQ_TYPE_LEVEL_HIGH>,
3886 <GIC_SPI 419 IRQ_TYPE_LEVEL_HIGH>,
3887 <GIC_SPI 412 IRQ_TYPE_LEVEL_HIGH>,
3888 <GIC_SPI 421 IRQ_TYPE_LEVEL_HIGH>,
3889 <GIC_SPI 706 IRQ_TYPE_LEVEL_HIGH>,
3890 <GIC_SPI 423 IRQ_TYPE_LEVEL_HIGH>,
3891 <GIC_SPI 424 IRQ_TYPE_LEVEL_HIGH>,
3892 <GIC_SPI 425 IRQ_TYPE_LEVEL_HIGH>,
3893 <GIC_SPI 689 IRQ_TYPE_LEVEL_HIGH>,
3894 <GIC_SPI 690 IRQ_TYPE_LEVEL_HIGH>,
3895 <GIC_SPI 691 IRQ_TYPE_LEVEL_HIGH>,
3896 <GIC_SPI 692 IRQ_TYPE_LEVEL_HIGH>,
3897 <GIC_SPI 693 IRQ_TYPE_LEVEL_HIGH>,
3898 <GIC_SPI 694 IRQ_TYPE_LEVEL_HIGH>,
3899 <GIC_SPI 695 IRQ_TYPE_LEVEL_HIGH>,
3900 <GIC_SPI 696 IRQ_TYPE_LEVEL_HIGH>;
3901 };
3902
3903 intc: interrupt-controller@17100000 {
3904 compatible = "arm,gic-v3";
3905 reg = <0 0x17100000 0 0x10000>, /* GICD */
3906 <0 0x17180000 0 0x200000>; /* GICR * 8 */
3907 ranges;
3908 #interrupt-cells = <3>;
3909 interrupt-controller;
3910 #redistributor-regions = <1>;
3911 redistributor-stride = <0 0x40000>;
3912 interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_LOW>;
3913 #address-cells = <2>;
3914 #size-cells = <2>;
3915
3916 gic_its: msi-controller@17140000 {
3917 compatible = "arm,gic-v3-its";
3918 reg = <0 0x17140000 0 0x20000>;
3919 msi-controller;
3920 #msi-cells = <1>;
3921 };
3922 };
3923
3924 timer@17420000 {
3925 compatible = "arm,armv7-timer-mem";
3926 reg = <0 0x17420000 0 0x1000>;
3927 ranges = <0 0 0 0x20000000>;
3928 #address-cells = <1>;
3929 #size-cells = <1>;
3930
3931 frame@17421000 {
3932 reg = <0x17421000 0x1000>,
3933 <0x17422000 0x1000>;
3934 frame-number = <0>;
3935 interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>,
3936 <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
3937 };
3938
3939 frame@17423000 {
3940 reg = <0x17423000 0x1000>;
3941 frame-number = <1>;
3942 interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
3943 status = "disabled";
3944 };
3945
3946 frame@17425000 {
3947 reg = <0x17425000 0x1000>;
3948 frame-number = <2>;
3949 interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
3950 status = "disabled";
3951 };
3952
3953 frame@17427000 {
3954 reg = <0x17427000 0x1000>;
3955 frame-number = <3>;
3956 interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
3957 status = "disabled";
3958 };
3959
3960 frame@17429000 {
3961 reg = <0x17429000 0x1000>;
3962 frame-number = <4>;
3963 interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
3964 status = "disabled";
3965 };
3966
3967 frame@1742b000 {
3968 reg = <0x1742b000 0x1000>;
3969 frame-number = <5>;
3970 interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
3971 status = "disabled";
3972 };
3973
3974 frame@1742d000 {
3975 reg = <0x1742d000 0x1000>;
3976 frame-number = <6>;
3977 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
3978 status = "disabled";
3979 };
3980 };
3981
3982 apps_rsc: rsc@17a00000 {
3983 label = "apps_rsc";
3984 compatible = "qcom,rpmh-rsc";
3985 reg = <0 0x17a00000 0 0x10000>,
3986 <0 0x17a10000 0 0x10000>,
3987 <0 0x17a20000 0 0x10000>,
3988 <0 0x17a30000 0 0x10000>;
3989 reg-names = "drv-0", "drv-1", "drv-2", "drv-3";
3990 interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>,
3991 <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>,
3992 <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
3993 qcom,tcs-offset = <0xd00>;
3994 qcom,drv-id = <2>;
3995 qcom,tcs-config = <ACTIVE_TCS 3>, <SLEEP_TCS 2>,
3996 <WAKE_TCS 2>, <CONTROL_TCS 0>;
3997 power-domains = <&CLUSTER_PD>;
3998
3999 apps_bcm_voter: bcm-voter {
4000 compatible = "qcom,bcm-voter";
4001 };
4002
4003 rpmhcc: clock-controller {
4004 compatible = "qcom,sm8550-rpmh-clk";
4005 #clock-cells = <1>;
4006 clock-names = "xo";
4007 clocks = <&xo_board>;
4008 };
4009
4010 rpmhpd: power-controller {
4011 compatible = "qcom,sm8550-rpmhpd";
4012 #power-domain-cells = <1>;
4013 operating-points-v2 = <&rpmhpd_opp_table>;
4014
4015 rpmhpd_opp_table: opp-table {
4016 compatible = "operating-points-v2";
4017
4018 rpmhpd_opp_ret: opp-16 {
4019 opp-level = <RPMH_REGULATOR_LEVEL_RETENTION>;
4020 };
4021
4022 rpmhpd_opp_min_svs: opp-48 {
4023 opp-level = <RPMH_REGULATOR_LEVEL_MIN_SVS>;
4024 };
4025
4026 rpmhpd_opp_low_svs_d2: opp-52 {
4027 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_D2>;
4028 };
4029
4030 rpmhpd_opp_low_svs_d1: opp-56 {
4031 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_D1>;
4032 };
4033
4034 rpmhpd_opp_low_svs_d0: opp-60 {
4035 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_D0>;
4036 };
4037
4038 rpmhpd_opp_low_svs: opp-64 {
4039 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS>;
4040 };
4041
4042 rpmhpd_opp_low_svs_l1: opp-80 {
4043 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS_L1>;
4044 };
4045
4046 rpmhpd_opp_svs: opp-128 {
4047 opp-level = <RPMH_REGULATOR_LEVEL_SVS>;
4048 };
4049
4050 rpmhpd_opp_svs_l0: opp-144 {
4051 opp-level = <RPMH_REGULATOR_LEVEL_SVS_L0>;
4052 };
4053
4054 rpmhpd_opp_svs_l1: opp-192 {
4055 opp-level = <RPMH_REGULATOR_LEVEL_SVS_L1>;
4056 };
4057
4058 rpmhpd_opp_nom: opp-256 {
4059 opp-level = <RPMH_REGULATOR_LEVEL_NOM>;
4060 };
4061
4062 rpmhpd_opp_nom_l1: opp-320 {
4063 opp-level = <RPMH_REGULATOR_LEVEL_NOM_L1>;
4064 };
4065
4066 rpmhpd_opp_nom_l2: opp-336 {
4067 opp-level = <RPMH_REGULATOR_LEVEL_NOM_L2>;
4068 };
4069
4070 rpmhpd_opp_turbo: opp-384 {
4071 opp-level = <RPMH_REGULATOR_LEVEL_TURBO>;
4072 };
4073
4074 rpmhpd_opp_turbo_l1: opp-416 {
4075 opp-level = <RPMH_REGULATOR_LEVEL_TURBO_L1>;
4076 };
4077 };
4078 };
4079 };
4080
4081 cpufreq_hw: cpufreq@17d91000 {
4082 compatible = "qcom,sm8550-cpufreq-epss", "qcom,cpufreq-epss";
4083 reg = <0 0x17d91000 0 0x1000>,
4084 <0 0x17d92000 0 0x1000>,
4085 <0 0x17d93000 0 0x1000>;
4086 reg-names = "freq-domain0", "freq-domain1", "freq-domain2";
4087 clocks = <&bi_tcxo_div2>, <&gcc GCC_GPLL0>;
4088 clock-names = "xo", "alternate";
4089 interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>,
4090 <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>,
4091 <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
4092 interrupt-names = "dcvsh-irq-0", "dcvsh-irq-1", "dcvsh-irq-2";
4093 #freq-domain-cells = <1>;
4094 #clock-cells = <1>;
4095 };
4096
4097 pmu@24091000 {
4098 compatible = "qcom,sm8550-llcc-bwmon", "qcom,sc7280-llcc-bwmon";
4099 reg = <0 0x24091000 0 0x1000>;
4100 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>;
4101 interconnects = <&mc_virt MASTER_LLCC 3 &mc_virt SLAVE_EBI1 3>;
4102
4103 operating-points-v2 = <&llcc_bwmon_opp_table>;
4104
4105 llcc_bwmon_opp_table: opp-table {
4106 compatible = "operating-points-v2";
4107
4108 opp-0 {
4109 opp-peak-kBps = <2086000>;
4110 };
4111
4112 opp-1 {
4113 opp-peak-kBps = <2929000>;
4114 };
4115
4116 opp-2 {
4117 opp-peak-kBps = <5931000>;
4118 };
4119
4120 opp-3 {
4121 opp-peak-kBps = <6515000>;
4122 };
4123
4124 opp-4 {
4125 opp-peak-kBps = <7980000>;
4126 };
4127
4128 opp-5 {
4129 opp-peak-kBps = <10437000>;
4130 };
4131
4132 opp-6 {
4133 opp-peak-kBps = <12157000>;
4134 };
4135
4136 opp-7 {
4137 opp-peak-kBps = <14060000>;
4138 };
4139
4140 opp-8 {
4141 opp-peak-kBps = <16113000>;
4142 };
4143 };
4144 };
4145
4146 pmu@240b6400 {
4147 compatible = "qcom,sm8550-cpu-bwmon", "qcom,sdm845-bwmon";
4148 reg = <0 0x240b6400 0 0x600>;
4149 interrupts = <GIC_SPI 581 IRQ_TYPE_LEVEL_HIGH>;
4150 interconnects = <&gem_noc MASTER_APPSS_PROC 3 &gem_noc SLAVE_LLCC 3>;
4151
4152 operating-points-v2 = <&cpu_bwmon_opp_table>;
4153
4154 cpu_bwmon_opp_table: opp-table {
4155 compatible = "operating-points-v2";
4156
4157 opp-0 {
4158 opp-peak-kBps = <4577000>;
4159 };
4160
4161 opp-1 {
4162 opp-peak-kBps = <7110000>;
4163 };
4164
4165 opp-2 {
4166 opp-peak-kBps = <9155000>;
4167 };
4168
4169 opp-3 {
4170 opp-peak-kBps = <12298000>;
4171 };
4172
4173 opp-4 {
4174 opp-peak-kBps = <14236000>;
4175 };
4176
4177 opp-5 {
4178 opp-peak-kBps = <16265000>;
4179 };
4180 };
4181 };
4182
4183 gem_noc: interconnect@24100000 {
4184 compatible = "qcom,sm8550-gem-noc";
4185 reg = <0 0x24100000 0 0xbb800>;
4186 #interconnect-cells = <2>;
4187 qcom,bcm-voters = <&apps_bcm_voter>;
4188 };
4189
4190 system-cache-controller@25000000 {
4191 compatible = "qcom,sm8550-llcc";
4192 reg = <0 0x25000000 0 0x200000>,
4193 <0 0x25200000 0 0x200000>,
4194 <0 0x25400000 0 0x200000>,
4195 <0 0x25600000 0 0x200000>,
4196 <0 0x25800000 0 0x200000>;
4197 reg-names = "llcc0_base",
4198 "llcc1_base",
4199 "llcc2_base",
4200 "llcc3_base",
4201 "llcc_broadcast_base";
4202 interrupts = <GIC_SPI 266 IRQ_TYPE_LEVEL_HIGH>;
4203 };
4204
4205 remoteproc_adsp: remoteproc@30000000 {
4206 compatible = "qcom,sm8550-adsp-pas";
4207 reg = <0x0 0x30000000 0x0 0x100>;
4208
4209 interrupts-extended = <&pdc 6 IRQ_TYPE_EDGE_RISING>,
4210 <&smp2p_adsp_in 0 IRQ_TYPE_EDGE_RISING>,
4211 <&smp2p_adsp_in 1 IRQ_TYPE_EDGE_RISING>,
4212 <&smp2p_adsp_in 2 IRQ_TYPE_EDGE_RISING>,
4213 <&smp2p_adsp_in 3 IRQ_TYPE_EDGE_RISING>;
4214 interrupt-names = "wdog", "fatal", "ready",
4215 "handover", "stop-ack";
4216
4217 clocks = <&rpmhcc RPMH_CXO_CLK>;
4218 clock-names = "xo";
4219
4220 power-domains = <&rpmhpd RPMHPD_LCX>,
4221 <&rpmhpd RPMHPD_LMX>;
4222 power-domain-names = "lcx", "lmx";
4223
4224 interconnects = <&lpass_lpicx_noc MASTER_LPASS_PROC 0 &mc_virt SLAVE_EBI1 0>;
4225
4226 memory-region = <&adspslpi_mem>, <&q6_adsp_dtb_mem>;
4227
4228 qcom,qmp = <&aoss_qmp>;
4229
4230 qcom,smem-states = <&smp2p_adsp_out 0>;
4231 qcom,smem-state-names = "stop";
4232
4233 status = "disabled";
4234
4235 remoteproc_adsp_glink: glink-edge {
4236 interrupts-extended = <&ipcc IPCC_CLIENT_LPASS
4237 IPCC_MPROC_SIGNAL_GLINK_QMP
4238 IRQ_TYPE_EDGE_RISING>;
4239 mboxes = <&ipcc IPCC_CLIENT_LPASS
4240 IPCC_MPROC_SIGNAL_GLINK_QMP>;
4241
4242 label = "lpass";
4243 qcom,remote-pid = <2>;
4244
4245 fastrpc {
4246 compatible = "qcom,fastrpc";
4247 qcom,glink-channels = "fastrpcglink-apps-dsp";
4248 label = "adsp";
4249 #address-cells = <1>;
4250 #size-cells = <0>;
4251
4252 compute-cb@3 {
4253 compatible = "qcom,fastrpc-compute-cb";
4254 reg = <3>;
4255 iommus = <&apps_smmu 0x1003 0x80>,
4256 <&apps_smmu 0x1063 0x0>;
4257 };
4258
4259 compute-cb@4 {
4260 compatible = "qcom,fastrpc-compute-cb";
4261 reg = <4>;
4262 iommus = <&apps_smmu 0x1004 0x80>,
4263 <&apps_smmu 0x1064 0x0>;
4264 };
4265
4266 compute-cb@5 {
4267 compatible = "qcom,fastrpc-compute-cb";
4268 reg = <5>;
4269 iommus = <&apps_smmu 0x1005 0x80>,
4270 <&apps_smmu 0x1065 0x0>;
4271 };
4272
4273 compute-cb@6 {
4274 compatible = "qcom,fastrpc-compute-cb";
4275 reg = <6>;
4276 iommus = <&apps_smmu 0x1006 0x80>,
4277 <&apps_smmu 0x1066 0x0>;
4278 };
4279
4280 compute-cb@7 {
4281 compatible = "qcom,fastrpc-compute-cb";
4282 reg = <7>;
4283 iommus = <&apps_smmu 0x1007 0x80>,
4284 <&apps_smmu 0x1067 0x0>;
4285 };
4286 };
4287
4288 gpr {
4289 compatible = "qcom,gpr";
4290 qcom,glink-channels = "adsp_apps";
4291 qcom,domain = <GPR_DOMAIN_ID_ADSP>;
4292 qcom,intents = <512 20>;
4293 #address-cells = <1>;
4294 #size-cells = <0>;
4295
4296 q6apm: service@1 {
4297 compatible = "qcom,q6apm";
4298 reg = <GPR_APM_MODULE_IID>;
4299 #sound-dai-cells = <0>;
4300 qcom,protection-domain = "avs/audio",
4301 "msm/adsp/audio_pd";
4302
4303 q6apmdai: dais {
4304 compatible = "qcom,q6apm-dais";
4305 iommus = <&apps_smmu 0x1001 0x80>,
4306 <&apps_smmu 0x1061 0x0>;
4307 };
4308
4309 q6apmbedai: bedais {
4310 compatible = "qcom,q6apm-lpass-dais";
4311 #sound-dai-cells = <1>;
4312 };
4313 };
4314
4315 q6prm: service@2 {
4316 compatible = "qcom,q6prm";
4317 reg = <GPR_PRM_MODULE_IID>;
4318 qcom,protection-domain = "avs/audio",
4319 "msm/adsp/audio_pd";
4320
4321 q6prmcc: clock-controller {
4322 compatible = "qcom,q6prm-lpass-clocks";
4323 #clock-cells = <2>;
4324 };
4325 };
4326 };
4327 };
4328 };
4329
4330 nsp_noc: interconnect@320c0000 {
4331 compatible = "qcom,sm8550-nsp-noc";
4332 reg = <0 0x320c0000 0 0xe080>;
4333 #interconnect-cells = <2>;
4334 qcom,bcm-voters = <&apps_bcm_voter>;
4335 };
4336
4337 remoteproc_cdsp: remoteproc@32300000 {
4338 compatible = "qcom,sm8550-cdsp-pas";
4339 reg = <0x0 0x32300000 0x0 0x1400000>;
4340
4341 interrupts-extended = <&intc GIC_SPI 578 IRQ_TYPE_EDGE_RISING>,
4342 <&smp2p_cdsp_in 0 IRQ_TYPE_EDGE_RISING>,
4343 <&smp2p_cdsp_in 1 IRQ_TYPE_EDGE_RISING>,
4344 <&smp2p_cdsp_in 2 IRQ_TYPE_EDGE_RISING>,
4345 <&smp2p_cdsp_in 3 IRQ_TYPE_EDGE_RISING>;
4346 interrupt-names = "wdog", "fatal", "ready",
4347 "handover", "stop-ack";
4348
4349 clocks = <&rpmhcc RPMH_CXO_CLK>;
4350 clock-names = "xo";
4351
4352 power-domains = <&rpmhpd RPMHPD_CX>,
4353 <&rpmhpd RPMHPD_MXC>,
4354 <&rpmhpd RPMHPD_NSP>;
4355 power-domain-names = "cx", "mxc", "nsp";
4356
4357 interconnects = <&nsp_noc MASTER_CDSP_PROC 0 &mc_virt SLAVE_EBI1 0>;
4358
4359 memory-region = <&cdsp_mem>, <&q6_cdsp_dtb_mem>;
4360
4361 qcom,qmp = <&aoss_qmp>;
4362
4363 qcom,smem-states = <&smp2p_cdsp_out 0>;
4364 qcom,smem-state-names = "stop";
4365
4366 status = "disabled";
4367
4368 glink-edge {
4369 interrupts-extended = <&ipcc IPCC_CLIENT_CDSP
4370 IPCC_MPROC_SIGNAL_GLINK_QMP
4371 IRQ_TYPE_EDGE_RISING>;
4372 mboxes = <&ipcc IPCC_CLIENT_CDSP
4373 IPCC_MPROC_SIGNAL_GLINK_QMP>;
4374
4375 label = "cdsp";
4376 qcom,remote-pid = <5>;
4377
4378 fastrpc {
4379 compatible = "qcom,fastrpc";
4380 qcom,glink-channels = "fastrpcglink-apps-dsp";
4381 label = "cdsp";
4382 #address-cells = <1>;
4383 #size-cells = <0>;
4384
4385 compute-cb@1 {
4386 compatible = "qcom,fastrpc-compute-cb";
4387 reg = <1>;
4388 iommus = <&apps_smmu 0x1961 0x0>,
4389 <&apps_smmu 0x0c01 0x20>,
4390 <&apps_smmu 0x19c1 0x10>;
4391 };
4392
4393 compute-cb@2 {
4394 compatible = "qcom,fastrpc-compute-cb";
4395 reg = <2>;
4396 iommus = <&apps_smmu 0x1962 0x0>,
4397 <&apps_smmu 0x0c02 0x20>,
4398 <&apps_smmu 0x19c2 0x10>;
4399 };
4400
4401 compute-cb@3 {
4402 compatible = "qcom,fastrpc-compute-cb";
4403 reg = <3>;
4404 iommus = <&apps_smmu 0x1963 0x0>,
4405 <&apps_smmu 0x0c03 0x20>,
4406 <&apps_smmu 0x19c3 0x10>;
4407 };
4408
4409 compute-cb@4 {
4410 compatible = "qcom,fastrpc-compute-cb";
4411 reg = <4>;
4412 iommus = <&apps_smmu 0x1964 0x0>,
4413 <&apps_smmu 0x0c04 0x20>,
4414 <&apps_smmu 0x19c4 0x10>;
4415 };
4416
4417 compute-cb@5 {
4418 compatible = "qcom,fastrpc-compute-cb";
4419 reg = <5>;
4420 iommus = <&apps_smmu 0x1965 0x0>,
4421 <&apps_smmu 0x0c05 0x20>,
4422 <&apps_smmu 0x19c5 0x10>;
4423 };
4424
4425 compute-cb@6 {
4426 compatible = "qcom,fastrpc-compute-cb";
4427 reg = <6>;
4428 iommus = <&apps_smmu 0x1966 0x0>,
4429 <&apps_smmu 0x0c06 0x20>,
4430 <&apps_smmu 0x19c6 0x10>;
4431 };
4432
4433 compute-cb@7 {
4434 compatible = "qcom,fastrpc-compute-cb";
4435 reg = <7>;
4436 iommus = <&apps_smmu 0x1967 0x0>,
4437 <&apps_smmu 0x0c07 0x20>,
4438 <&apps_smmu 0x19c7 0x10>;
4439 };
4440
4441 compute-cb@8 {
4442 compatible = "qcom,fastrpc-compute-cb";
4443 reg = <8>;
4444 iommus = <&apps_smmu 0x1968 0x0>,
4445 <&apps_smmu 0x0c08 0x20>,
4446 <&apps_smmu 0x19c8 0x10>;
4447 };
4448
4449 /* note: secure cb9 in downstream */
4450 };
4451 };
4452 };
4453 };
4454
4455 thermal-zones {
4456 aoss0-thermal {
4457 polling-delay-passive = <0>;
4458 polling-delay = <0>;
4459 thermal-sensors = <&tsens0 0>;
4460
4461 trips {
4462 thermal-engine-config {
4463 temperature = <125000>;
4464 hysteresis = <1000>;
4465 type = "passive";
4466 };
4467
4468 reset-mon-config {
4469 temperature = <115000>;
4470 hysteresis = <5000>;
4471 type = "passive";
4472 };
4473 };
4474 };
4475
4476 cpuss0-thermal {
4477 polling-delay-passive = <0>;
4478 polling-delay = <0>;
4479 thermal-sensors = <&tsens0 1>;
4480
4481 trips {
4482 thermal-engine-config {
4483 temperature = <125000>;
4484 hysteresis = <1000>;
4485 type = "passive";
4486 };
4487
4488 reset-mon-config {
4489 temperature = <115000>;
4490 hysteresis = <5000>;
4491 type = "passive";
4492 };
4493 };
4494 };
4495
4496 cpuss1-thermal {
4497 polling-delay-passive = <0>;
4498 polling-delay = <0>;
4499 thermal-sensors = <&tsens0 2>;
4500
4501 trips {
4502 thermal-engine-config {
4503 temperature = <125000>;
4504 hysteresis = <1000>;
4505 type = "passive";
4506 };
4507
4508 reset-mon-config {
4509 temperature = <115000>;
4510 hysteresis = <5000>;
4511 type = "passive";
4512 };
4513 };
4514 };
4515
4516 cpuss2-thermal {
4517 polling-delay-passive = <0>;
4518 polling-delay = <0>;
4519 thermal-sensors = <&tsens0 3>;
4520
4521 trips {
4522 thermal-engine-config {
4523 temperature = <125000>;
4524 hysteresis = <1000>;
4525 type = "passive";
4526 };
4527
4528 reset-mon-config {
4529 temperature = <115000>;
4530 hysteresis = <5000>;
4531 type = "passive";
4532 };
4533 };
4534 };
4535
4536 cpuss3-thermal {
4537 polling-delay-passive = <0>;
4538 polling-delay = <0>;
4539 thermal-sensors = <&tsens0 4>;
4540
4541 trips {
4542 thermal-engine-config {
4543 temperature = <125000>;
4544 hysteresis = <1000>;
4545 type = "passive";
4546 };
4547
4548 reset-mon-config {
4549 temperature = <115000>;
4550 hysteresis = <5000>;
4551 type = "passive";
4552 };
4553 };
4554 };
4555
4556 cpu3-top-thermal {
4557 polling-delay-passive = <0>;
4558 polling-delay = <0>;
4559 thermal-sensors = <&tsens0 5>;
4560
4561 trips {
4562 cpu3_top_alert0: trip-point0 {
4563 temperature = <90000>;
4564 hysteresis = <2000>;
4565 type = "passive";
4566 };
4567
4568 cpu3_top_alert1: trip-point1 {
4569 temperature = <95000>;
4570 hysteresis = <2000>;
4571 type = "passive";
4572 };
4573
4574 cpu3_top_crit: cpu-critical {
4575 temperature = <110000>;
4576 hysteresis = <1000>;
4577 type = "critical";
4578 };
4579 };
4580 };
4581
4582 cpu3-bottom-thermal {
4583 polling-delay-passive = <0>;
4584 polling-delay = <0>;
4585 thermal-sensors = <&tsens0 6>;
4586
4587 trips {
4588 cpu3_bottom_alert0: trip-point0 {
4589 temperature = <90000>;
4590 hysteresis = <2000>;
4591 type = "passive";
4592 };
4593
4594 cpu3_bottom_alert1: trip-point1 {
4595 temperature = <95000>;
4596 hysteresis = <2000>;
4597 type = "passive";
4598 };
4599
4600 cpu3_bottom_crit: cpu-critical {
4601 temperature = <110000>;
4602 hysteresis = <1000>;
4603 type = "critical";
4604 };
4605 };
4606 };
4607
4608 cpu4-top-thermal {
4609 polling-delay-passive = <0>;
4610 polling-delay = <0>;
4611 thermal-sensors = <&tsens0 7>;
4612
4613 trips {
4614 cpu4_top_alert0: trip-point0 {
4615 temperature = <90000>;
4616 hysteresis = <2000>;
4617 type = "passive";
4618 };
4619
4620 cpu4_top_alert1: trip-point1 {
4621 temperature = <95000>;
4622 hysteresis = <2000>;
4623 type = "passive";
4624 };
4625
4626 cpu4_top_crit: cpu-critical {
4627 temperature = <110000>;
4628 hysteresis = <1000>;
4629 type = "critical";
4630 };
4631 };
4632 };
4633
4634 cpu4-bottom-thermal {
4635 polling-delay-passive = <0>;
4636 polling-delay = <0>;
4637 thermal-sensors = <&tsens0 8>;
4638
4639 trips {
4640 cpu4_bottom_alert0: trip-point0 {
4641 temperature = <90000>;
4642 hysteresis = <2000>;
4643 type = "passive";
4644 };
4645
4646 cpu4_bottom_alert1: trip-point1 {
4647 temperature = <95000>;
4648 hysteresis = <2000>;
4649 type = "passive";
4650 };
4651
4652 cpu4_bottom_crit: cpu-critical {
4653 temperature = <110000>;
4654 hysteresis = <1000>;
4655 type = "critical";
4656 };
4657 };
4658 };
4659
4660 cpu5-top-thermal {
4661 polling-delay-passive = <0>;
4662 polling-delay = <0>;
4663 thermal-sensors = <&tsens0 9>;
4664
4665 trips {
4666 cpu5_top_alert0: trip-point0 {
4667 temperature = <90000>;
4668 hysteresis = <2000>;
4669 type = "passive";
4670 };
4671
4672 cpu5_top_alert1: trip-point1 {
4673 temperature = <95000>;
4674 hysteresis = <2000>;
4675 type = "passive";
4676 };
4677
4678 cpu5_top_crit: cpu-critical {
4679 temperature = <110000>;
4680 hysteresis = <1000>;
4681 type = "critical";
4682 };
4683 };
4684 };
4685
4686 cpu5-bottom-thermal {
4687 polling-delay-passive = <0>;
4688 polling-delay = <0>;
4689 thermal-sensors = <&tsens0 10>;
4690
4691 trips {
4692 cpu5_bottom_alert0: trip-point0 {
4693 temperature = <90000>;
4694 hysteresis = <2000>;
4695 type = "passive";
4696 };
4697
4698 cpu5_bottom_alert1: trip-point1 {
4699 temperature = <95000>;
4700 hysteresis = <2000>;
4701 type = "passive";
4702 };
4703
4704 cpu5_bottom_crit: cpu-critical {
4705 temperature = <110000>;
4706 hysteresis = <1000>;
4707 type = "critical";
4708 };
4709 };
4710 };
4711
4712 cpu6-top-thermal {
4713 polling-delay-passive = <0>;
4714 polling-delay = <0>;
4715 thermal-sensors = <&tsens0 11>;
4716
4717 trips {
4718 cpu6_top_alert0: trip-point0 {
4719 temperature = <90000>;
4720 hysteresis = <2000>;
4721 type = "passive";
4722 };
4723
4724 cpu6_top_alert1: trip-point1 {
4725 temperature = <95000>;
4726 hysteresis = <2000>;
4727 type = "passive";
4728 };
4729
4730 cpu6_top_crit: cpu-critical {
4731 temperature = <110000>;
4732 hysteresis = <1000>;
4733 type = "critical";
4734 };
4735 };
4736 };
4737
4738 cpu6-bottom-thermal {
4739 polling-delay-passive = <0>;
4740 polling-delay = <0>;
4741 thermal-sensors = <&tsens0 12>;
4742
4743 trips {
4744 cpu6_bottom_alert0: trip-point0 {
4745 temperature = <90000>;
4746 hysteresis = <2000>;
4747 type = "passive";
4748 };
4749
4750 cpu6_bottom_alert1: trip-point1 {
4751 temperature = <95000>;
4752 hysteresis = <2000>;
4753 type = "passive";
4754 };
4755
4756 cpu6_bottom_crit: cpu-critical {
4757 temperature = <110000>;
4758 hysteresis = <1000>;
4759 type = "critical";
4760 };
4761 };
4762 };
4763
4764 cpu7-top-thermal {
4765 polling-delay-passive = <0>;
4766 polling-delay = <0>;
4767 thermal-sensors = <&tsens0 13>;
4768
4769 trips {
4770 cpu7_top_alert0: trip-point0 {
4771 temperature = <90000>;
4772 hysteresis = <2000>;
4773 type = "passive";
4774 };
4775
4776 cpu7_top_alert1: trip-point1 {
4777 temperature = <95000>;
4778 hysteresis = <2000>;
4779 type = "passive";
4780 };
4781
4782 cpu7_top_crit: cpu-critical {
4783 temperature = <110000>;
4784 hysteresis = <1000>;
4785 type = "critical";
4786 };
4787 };
4788 };
4789
4790 cpu7-middle-thermal {
4791 polling-delay-passive = <0>;
4792 polling-delay = <0>;
4793 thermal-sensors = <&tsens0 14>;
4794
4795 trips {
4796 cpu7_middle_alert0: trip-point0 {
4797 temperature = <90000>;
4798 hysteresis = <2000>;
4799 type = "passive";
4800 };
4801
4802 cpu7_middle_alert1: trip-point1 {
4803 temperature = <95000>;
4804 hysteresis = <2000>;
4805 type = "passive";
4806 };
4807
4808 cpu7_middle_crit: cpu-critical {
4809 temperature = <110000>;
4810 hysteresis = <1000>;
4811 type = "critical";
4812 };
4813 };
4814 };
4815
4816 cpu7-bottom-thermal {
4817 polling-delay-passive = <0>;
4818 polling-delay = <0>;
4819 thermal-sensors = <&tsens0 15>;
4820
4821 trips {
4822 cpu7_bottom_alert0: trip-point0 {
4823 temperature = <90000>;
4824 hysteresis = <2000>;
4825 type = "passive";
4826 };
4827
4828 cpu7_bottom_alert1: trip-point1 {
4829 temperature = <95000>;
4830 hysteresis = <2000>;
4831 type = "passive";
4832 };
4833
4834 cpu7_bottom_crit: cpu-critical {
4835 temperature = <110000>;
4836 hysteresis = <1000>;
4837 type = "critical";
4838 };
4839 };
4840 };
4841
4842 aoss1-thermal {
4843 polling-delay-passive = <0>;
4844 polling-delay = <0>;
4845 thermal-sensors = <&tsens1 0>;
4846
4847 trips {
4848 thermal-engine-config {
4849 temperature = <125000>;
4850 hysteresis = <1000>;
4851 type = "passive";
4852 };
4853
4854 reset-mon-config {
4855 temperature = <115000>;
4856 hysteresis = <5000>;
4857 type = "passive";
4858 };
4859 };
4860 };
4861
4862 cpu0-thermal {
4863 polling-delay-passive = <0>;
4864 polling-delay = <0>;
4865 thermal-sensors = <&tsens1 1>;
4866
4867 trips {
4868 cpu0_alert0: trip-point0 {
4869 temperature = <90000>;
4870 hysteresis = <2000>;
4871 type = "passive";
4872 };
4873
4874 cpu0_alert1: trip-point1 {
4875 temperature = <95000>;
4876 hysteresis = <2000>;
4877 type = "passive";
4878 };
4879
4880 cpu0_crit: cpu-critical {
4881 temperature = <110000>;
4882 hysteresis = <1000>;
4883 type = "critical";
4884 };
4885 };
4886 };
4887
4888 cpu1-thermal {
4889 polling-delay-passive = <0>;
4890 polling-delay = <0>;
4891 thermal-sensors = <&tsens1 2>;
4892
4893 trips {
4894 cpu1_alert0: trip-point0 {
4895 temperature = <90000>;
4896 hysteresis = <2000>;
4897 type = "passive";
4898 };
4899
4900 cpu1_alert1: trip-point1 {
4901 temperature = <95000>;
4902 hysteresis = <2000>;
4903 type = "passive";
4904 };
4905
4906 cpu1_crit: cpu-critical {
4907 temperature = <110000>;
4908 hysteresis = <1000>;
4909 type = "critical";
4910 };
4911 };
4912 };
4913
4914 cpu2-thermal {
4915 polling-delay-passive = <0>;
4916 polling-delay = <0>;
4917 thermal-sensors = <&tsens1 3>;
4918
4919 trips {
4920 cpu2_alert0: trip-point0 {
4921 temperature = <90000>;
4922 hysteresis = <2000>;
4923 type = "passive";
4924 };
4925
4926 cpu2_alert1: trip-point1 {
4927 temperature = <95000>;
4928 hysteresis = <2000>;
4929 type = "passive";
4930 };
4931
4932 cpu2_crit: cpu-critical {
4933 temperature = <110000>;
4934 hysteresis = <1000>;
4935 type = "critical";
4936 };
4937 };
4938 };
4939
4940 cdsp0-thermal {
4941 polling-delay-passive = <10>;
4942 polling-delay = <0>;
4943 thermal-sensors = <&tsens2 4>;
4944
4945 trips {
4946 thermal-engine-config {
4947 temperature = <125000>;
4948 hysteresis = <1000>;
4949 type = "passive";
4950 };
4951
4952 thermal-hal-config {
4953 temperature = <125000>;
4954 hysteresis = <1000>;
4955 type = "passive";
4956 };
4957
4958 reset-mon-config {
4959 temperature = <115000>;
4960 hysteresis = <5000>;
4961 type = "passive";
4962 };
4963
4964 cdsp0_junction_config: junction-config {
4965 temperature = <95000>;
4966 hysteresis = <5000>;
4967 type = "passive";
4968 };
4969 };
4970 };
4971
4972 cdsp1-thermal {
4973 polling-delay-passive = <10>;
4974 polling-delay = <0>;
4975 thermal-sensors = <&tsens2 5>;
4976
4977 trips {
4978 thermal-engine-config {
4979 temperature = <125000>;
4980 hysteresis = <1000>;
4981 type = "passive";
4982 };
4983
4984 thermal-hal-config {
4985 temperature = <125000>;
4986 hysteresis = <1000>;
4987 type = "passive";
4988 };
4989
4990 reset-mon-config {
4991 temperature = <115000>;
4992 hysteresis = <5000>;
4993 type = "passive";
4994 };
4995
4996 cdsp1_junction_config: junction-config {
4997 temperature = <95000>;
4998 hysteresis = <5000>;
4999 type = "passive";
5000 };
5001 };
5002 };
5003
5004 cdsp2-thermal {
5005 polling-delay-passive = <10>;
5006 polling-delay = <0>;
5007 thermal-sensors = <&tsens2 6>;
5008
5009 trips {
5010 thermal-engine-config {
5011 temperature = <125000>;
5012 hysteresis = <1000>;
5013 type = "passive";
5014 };
5015
5016 thermal-hal-config {
5017 temperature = <125000>;
5018 hysteresis = <1000>;
5019 type = "passive";
5020 };
5021
5022 reset-mon-config {
5023 temperature = <115000>;
5024 hysteresis = <5000>;
5025 type = "passive";
5026 };
5027
5028 cdsp2_junction_config: junction-config {
5029 temperature = <95000>;
5030 hysteresis = <5000>;
5031 type = "passive";
5032 };
5033 };
5034 };
5035
5036 cdsp3-thermal {
5037 polling-delay-passive = <10>;
5038 polling-delay = <0>;
5039 thermal-sensors = <&tsens2 7>;
5040
5041 trips {
5042 thermal-engine-config {
5043 temperature = <125000>;
5044 hysteresis = <1000>;
5045 type = "passive";
5046 };
5047
5048 thermal-hal-config {
5049 temperature = <125000>;
5050 hysteresis = <1000>;
5051 type = "passive";
5052 };
5053
5054 reset-mon-config {
5055 temperature = <115000>;
5056 hysteresis = <5000>;
5057 type = "passive";
5058 };
5059
5060 cdsp3_junction_config: junction-config {
5061 temperature = <95000>;
5062 hysteresis = <5000>;
5063 type = "passive";
5064 };
5065 };
5066 };
5067
5068 video-thermal {
5069 polling-delay-passive = <0>;
5070 polling-delay = <0>;
5071 thermal-sensors = <&tsens1 8>;
5072
5073 trips {
5074 thermal-engine-config {
5075 temperature = <125000>;
5076 hysteresis = <1000>;
5077 type = "passive";
5078 };
5079
5080 reset-mon-config {
5081 temperature = <115000>;
5082 hysteresis = <5000>;
5083 type = "passive";
5084 };
5085 };
5086 };
5087
5088 mem-thermal {
5089 polling-delay-passive = <10>;
5090 polling-delay = <0>;
5091 thermal-sensors = <&tsens1 9>;
5092
5093 trips {
5094 thermal-engine-config {
5095 temperature = <125000>;
5096 hysteresis = <1000>;
5097 type = "passive";
5098 };
5099
5100 ddr_config0: ddr0-config {
5101 temperature = <90000>;
5102 hysteresis = <5000>;
5103 type = "passive";
5104 };
5105
5106 reset-mon-config {
5107 temperature = <115000>;
5108 hysteresis = <5000>;
5109 type = "passive";
5110 };
5111 };
5112 };
5113
5114 modem0-thermal {
5115 polling-delay-passive = <0>;
5116 polling-delay = <0>;
5117 thermal-sensors = <&tsens1 10>;
5118
5119 trips {
5120 thermal-engine-config {
5121 temperature = <125000>;
5122 hysteresis = <1000>;
5123 type = "passive";
5124 };
5125
5126 mdmss0_config0: mdmss0-config0 {
5127 temperature = <102000>;
5128 hysteresis = <3000>;
5129 type = "passive";
5130 };
5131
5132 mdmss0_config1: mdmss0-config1 {
5133 temperature = <105000>;
5134 hysteresis = <3000>;
5135 type = "passive";
5136 };
5137
5138 reset-mon-config {
5139 temperature = <115000>;
5140 hysteresis = <5000>;
5141 type = "passive";
5142 };
5143 };
5144 };
5145
5146 modem1-thermal {
5147 polling-delay-passive = <0>;
5148 polling-delay = <0>;
5149 thermal-sensors = <&tsens1 11>;
5150
5151 trips {
5152 thermal-engine-config {
5153 temperature = <125000>;
5154 hysteresis = <1000>;
5155 type = "passive";
5156 };
5157
5158 mdmss1_config0: mdmss1-config0 {
5159 temperature = <102000>;
5160 hysteresis = <3000>;
5161 type = "passive";
5162 };
5163
5164 mdmss1_config1: mdmss1-config1 {
5165 temperature = <105000>;
5166 hysteresis = <3000>;
5167 type = "passive";
5168 };
5169
5170 reset-mon-config {
5171 temperature = <115000>;
5172 hysteresis = <5000>;
5173 type = "passive";
5174 };
5175 };
5176 };
5177
5178 modem2-thermal {
5179 polling-delay-passive = <0>;
5180 polling-delay = <0>;
5181 thermal-sensors = <&tsens1 12>;
5182
5183 trips {
5184 thermal-engine-config {
5185 temperature = <125000>;
5186 hysteresis = <1000>;
5187 type = "passive";
5188 };
5189
5190 mdmss2_config0: mdmss2-config0 {
5191 temperature = <102000>;
5192 hysteresis = <3000>;
5193 type = "passive";
5194 };
5195
5196 mdmss2_config1: mdmss2-config1 {
5197 temperature = <105000>;
5198 hysteresis = <3000>;
5199 type = "passive";
5200 };
5201
5202 reset-mon-config {
5203 temperature = <115000>;
5204 hysteresis = <5000>;
5205 type = "passive";
5206 };
5207 };
5208 };
5209
5210 modem3-thermal {
5211 polling-delay-passive = <0>;
5212 polling-delay = <0>;
5213 thermal-sensors = <&tsens1 13>;
5214
5215 trips {
5216 thermal-engine-config {
5217 temperature = <125000>;
5218 hysteresis = <1000>;
5219 type = "passive";
5220 };
5221
5222 mdmss3_config0: mdmss3-config0 {
5223 temperature = <102000>;
5224 hysteresis = <3000>;
5225 type = "passive";
5226 };
5227
5228 mdmss3_config1: mdmss3-config1 {
5229 temperature = <105000>;
5230 hysteresis = <3000>;
5231 type = "passive";
5232 };
5233
5234 reset-mon-config {
5235 temperature = <115000>;
5236 hysteresis = <5000>;
5237 type = "passive";
5238 };
5239 };
5240 };
5241
5242 camera0-thermal {
5243 polling-delay-passive = <0>;
5244 polling-delay = <0>;
5245 thermal-sensors = <&tsens1 14>;
5246
5247 trips {
5248 thermal-engine-config {
5249 temperature = <125000>;
5250 hysteresis = <1000>;
5251 type = "passive";
5252 };
5253
5254 reset-mon-config {
5255 temperature = <115000>;
5256 hysteresis = <5000>;
5257 type = "passive";
5258 };
5259 };
5260 };
5261
5262 camera1-thermal {
5263 polling-delay-passive = <0>;
5264 polling-delay = <0>;
5265 thermal-sensors = <&tsens1 15>;
5266
5267 trips {
5268 thermal-engine-config {
5269 temperature = <125000>;
5270 hysteresis = <1000>;
5271 type = "passive";
5272 };
5273
5274 reset-mon-config {
5275 temperature = <115000>;
5276 hysteresis = <5000>;
5277 type = "passive";
5278 };
5279 };
5280 };
5281
5282 aoss2-thermal {
5283 polling-delay-passive = <0>;
5284 polling-delay = <0>;
5285 thermal-sensors = <&tsens2 0>;
5286
5287 trips {
5288 thermal-engine-config {
5289 temperature = <125000>;
5290 hysteresis = <1000>;
5291 type = "passive";
5292 };
5293
5294 reset-mon-config {
5295 temperature = <115000>;
5296 hysteresis = <5000>;
5297 type = "passive";
5298 };
5299 };
5300 };
5301
5302 gpuss-0-thermal {
5303 polling-delay-passive = <10>;
5304 polling-delay = <0>;
5305 thermal-sensors = <&tsens2 1>;
5306
5307 trips {
5308 thermal-engine-config {
5309 temperature = <125000>;
5310 hysteresis = <1000>;
5311 type = "passive";
5312 };
5313
5314 thermal-hal-config {
5315 temperature = <125000>;
5316 hysteresis = <1000>;
5317 type = "passive";
5318 };
5319
5320 reset-mon-config {
5321 temperature = <115000>;
5322 hysteresis = <5000>;
5323 type = "passive";
5324 };
5325
5326 gpu0_junction_config: junction-config {
5327 temperature = <95000>;
5328 hysteresis = <5000>;
5329 type = "passive";
5330 };
5331 };
5332 };
5333
5334 gpuss-1-thermal {
5335 polling-delay-passive = <10>;
5336 polling-delay = <0>;
5337 thermal-sensors = <&tsens2 2>;
5338
5339 trips {
5340 thermal-engine-config {
5341 temperature = <125000>;
5342 hysteresis = <1000>;
5343 type = "passive";
5344 };
5345
5346 thermal-hal-config {
5347 temperature = <125000>;
5348 hysteresis = <1000>;
5349 type = "passive";
5350 };
5351
5352 reset-mon-config {
5353 temperature = <115000>;
5354 hysteresis = <5000>;
5355 type = "passive";
5356 };
5357
5358 gpu1_junction_config: junction-config {
5359 temperature = <95000>;
5360 hysteresis = <5000>;
5361 type = "passive";
5362 };
5363 };
5364 };
5365
5366 gpuss-2-thermal {
5367 polling-delay-passive = <10>;
5368 polling-delay = <0>;
5369 thermal-sensors = <&tsens2 3>;
5370
5371 trips {
5372 thermal-engine-config {
5373 temperature = <125000>;
5374 hysteresis = <1000>;
5375 type = "passive";
5376 };
5377
5378 thermal-hal-config {
5379 temperature = <125000>;
5380 hysteresis = <1000>;
5381 type = "passive";
5382 };
5383
5384 reset-mon-config {
5385 temperature = <115000>;
5386 hysteresis = <5000>;
5387 type = "passive";
5388 };
5389
5390 gpu2_junction_config: junction-config {
5391 temperature = <95000>;
5392 hysteresis = <5000>;
5393 type = "passive";
5394 };
5395 };
5396 };
5397
5398 gpuss-3-thermal {
5399 polling-delay-passive = <10>;
5400 polling-delay = <0>;
5401 thermal-sensors = <&tsens2 4>;
5402
5403 trips {
5404 thermal-engine-config {
5405 temperature = <125000>;
5406 hysteresis = <1000>;
5407 type = "passive";
5408 };
5409
5410 thermal-hal-config {
5411 temperature = <125000>;
5412 hysteresis = <1000>;
5413 type = "passive";
5414 };
5415
5416 reset-mon-config {
5417 temperature = <115000>;
5418 hysteresis = <5000>;
5419 type = "passive";
5420 };
5421
5422 gpu3_junction_config: junction-config {
5423 temperature = <95000>;
5424 hysteresis = <5000>;
5425 type = "passive";
5426 };
5427 };
5428 };
5429
5430 gpuss-4-thermal {
5431 polling-delay-passive = <10>;
5432 polling-delay = <0>;
5433 thermal-sensors = <&tsens2 5>;
5434
5435 trips {
5436 thermal-engine-config {
5437 temperature = <125000>;
5438 hysteresis = <1000>;
5439 type = "passive";
5440 };
5441
5442 thermal-hal-config {
5443 temperature = <125000>;
5444 hysteresis = <1000>;
5445 type = "passive";
5446 };
5447
5448 reset-mon-config {
5449 temperature = <115000>;
5450 hysteresis = <5000>;
5451 type = "passive";
5452 };
5453
5454 gpu4_junction_config: junction-config {
5455 temperature = <95000>;
5456 hysteresis = <5000>;
5457 type = "passive";
5458 };
5459 };
5460 };
5461
5462 gpuss-5-thermal {
5463 polling-delay-passive = <10>;
5464 polling-delay = <0>;
5465 thermal-sensors = <&tsens2 6>;
5466
5467 trips {
5468 thermal-engine-config {
5469 temperature = <125000>;
5470 hysteresis = <1000>;
5471 type = "passive";
5472 };
5473
5474 thermal-hal-config {
5475 temperature = <125000>;
5476 hysteresis = <1000>;
5477 type = "passive";
5478 };
5479
5480 reset-mon-config {
5481 temperature = <115000>;
5482 hysteresis = <5000>;
5483 type = "passive";
5484 };
5485
5486 gpu5_junction_config: junction-config {
5487 temperature = <95000>;
5488 hysteresis = <5000>;
5489 type = "passive";
5490 };
5491 };
5492 };
5493
5494 gpuss-6-thermal {
5495 polling-delay-passive = <10>;
5496 polling-delay = <0>;
5497 thermal-sensors = <&tsens2 7>;
5498
5499 trips {
5500 thermal-engine-config {
5501 temperature = <125000>;
5502 hysteresis = <1000>;
5503 type = "passive";
5504 };
5505
5506 thermal-hal-config {
5507 temperature = <125000>;
5508 hysteresis = <1000>;
5509 type = "passive";
5510 };
5511
5512 reset-mon-config {
5513 temperature = <115000>;
5514 hysteresis = <5000>;
5515 type = "passive";
5516 };
5517
5518 gpu6_junction_config: junction-config {
5519 temperature = <95000>;
5520 hysteresis = <5000>;
5521 type = "passive";
5522 };
5523 };
5524 };
5525
5526 gpuss-7-thermal {
5527 polling-delay-passive = <10>;
5528 polling-delay = <0>;
5529 thermal-sensors = <&tsens2 8>;
5530
5531 trips {
5532 thermal-engine-config {
5533 temperature = <125000>;
5534 hysteresis = <1000>;
5535 type = "passive";
5536 };
5537
5538 thermal-hal-config {
5539 temperature = <125000>;
5540 hysteresis = <1000>;
5541 type = "passive";
5542 };
5543
5544 reset-mon-config {
5545 temperature = <115000>;
5546 hysteresis = <5000>;
5547 type = "passive";
5548 };
5549
5550 gpu7_junction_config: junction-config {
5551 temperature = <95000>;
5552 hysteresis = <5000>;
5553 type = "passive";
5554 };
5555 };
5556 };
5557 };
5558
5559 timer {
5560 compatible = "arm,armv8-timer";
5561 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
5562 <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
5563 <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>,
5564 <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_LOW)>;
5565 };
5566};