Lines Matching +full:thermal +full:- +full:idle

1 // SPDX-License-Identifier: GPL-2.0
4 #include <dt-bindings/interrupt-controller/arm-gic.h>
5 #include <dt-bindings/clock/qcom,gcc-msm8998.h>
6 #include <dt-bindings/clock/qcom,gpucc-msm8998.h>
7 #include <dt-bindings/clock/qcom,mmcc-msm8998.h>
8 #include <dt-bindings/clock/qcom,rpmcc.h>
9 #include <dt-bindings/power/qcom-rpmpd.h>
10 #include <dt-bindings/gpio/gpio.h>
13 interrupt-parent = <&intc>;
15 qcom,msm-id = <292 0x0>;
17 #address-cells = <2>;
18 #size-cells = <2>;
28 reserved-memory {
29 #address-cells = <2>;
30 #size-cells = <2>;
35 no-map;
40 no-map;
43 smem_mem: smem-mem@86000000 {
45 no-map;
50 no-map;
54 compatible = "qcom,rmtfs-mem";
56 no-map;
58 qcom,client-id = <1>;
64 no-map;
69 no-map;
74 no-map;
79 no-map;
84 no-map;
89 no-map;
94 no-map;
99 no-map;
104 no-map;
109 no-map;
112 mdata_mem: mpss-metadata {
113 alloc-ranges = <0x0 0xa0000000 0x0 0x20000000>;
115 no-map;
120 xo: xo-board {
121 compatible = "fixed-clock";
122 #clock-cells = <0>;
123 clock-frequency = <19200000>;
124 clock-output-names = "xo_board";
127 sleep_clk: sleep-clk {
128 compatible = "fixed-clock";
129 #clock-cells = <0>;
130 clock-frequency = <32764>;
135 #address-cells = <2>;
136 #size-cells = <0>;
142 enable-method = "psci";
143 capacity-dmips-mhz = <1024>;
144 cpu-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
145 next-level-cache = <&L2_0>;
146 L2_0: l2-cache {
148 cache-level = <2>;
149 cache-unified;
157 enable-method = "psci";
158 capacity-dmips-mhz = <1024>;
159 cpu-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
160 next-level-cache = <&L2_0>;
167 enable-method = "psci";
168 capacity-dmips-mhz = <1024>;
169 cpu-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
170 next-level-cache = <&L2_0>;
177 enable-method = "psci";
178 capacity-dmips-mhz = <1024>;
179 cpu-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
180 next-level-cache = <&L2_0>;
187 enable-method = "psci";
188 capacity-dmips-mhz = <1536>;
189 cpu-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
190 next-level-cache = <&L2_1>;
191 L2_1: l2-cache {
193 cache-level = <2>;
194 cache-unified;
202 enable-method = "psci";
203 capacity-dmips-mhz = <1536>;
204 cpu-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
205 next-level-cache = <&L2_1>;
212 enable-method = "psci";
213 capacity-dmips-mhz = <1536>;
214 cpu-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
215 next-level-cache = <&L2_1>;
222 enable-method = "psci";
223 capacity-dmips-mhz = <1536>;
224 cpu-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
225 next-level-cache = <&L2_1>;
228 cpu-map {
266 idle-states {
267 entry-method = "psci";
269 LITTLE_CPU_SLEEP_0: cpu-sleep-0-0 {
270 compatible = "arm,idle-state";
271 idle-state-name = "little-retention";
273 arm,psci-suspend-param = <0x00000002>;
274 entry-latency-us = <81>;
275 exit-latency-us = <86>;
276 min-residency-us = <504>;
279 LITTLE_CPU_SLEEP_1: cpu-sleep-0-1 {
280 compatible = "arm,idle-state";
281 idle-state-name = "little-power-collapse";
283 arm,psci-suspend-param = <0x40000003>;
284 entry-latency-us = <814>;
285 exit-latency-us = <4562>;
286 min-residency-us = <9183>;
287 local-timer-stop;
290 BIG_CPU_SLEEP_0: cpu-sleep-1-0 {
291 compatible = "arm,idle-state";
292 idle-state-name = "big-retention";
294 arm,psci-suspend-param = <0x00000002>;
295 entry-latency-us = <79>;
296 exit-latency-us = <82>;
297 min-residency-us = <1302>;
300 BIG_CPU_SLEEP_1: cpu-sleep-1-1 {
301 compatible = "arm,idle-state";
302 idle-state-name = "big-power-collapse";
304 arm,psci-suspend-param = <0x40000003>;
305 entry-latency-us = <724>;
306 exit-latency-us = <2027>;
307 min-residency-us = <9419>;
308 local-timer-stop;
315 compatible = "qcom,scm-msm8998", "qcom,scm";
319 dsi_opp_table: opp-table-dsi {
320 compatible = "operating-points-v2";
322 opp-131250000 {
323 opp-hz = /bits/ 64 <131250000>;
324 required-opps = <&rpmpd_opp_low_svs>;
327 opp-210000000 {
328 opp-hz = /bits/ 64 <210000000>;
329 required-opps = <&rpmpd_opp_svs>;
332 opp-312500000 {
333 opp-hz = /bits/ 64 <312500000>;
334 required-opps = <&rpmpd_opp_nom>;
339 compatible = "arm,psci-1.0";
344 compatible = "qcom,msm8998-rpm-proc", "qcom,rpm-proc";
346 glink-edge {
347 compatible = "qcom,glink-rpm";
350 qcom,rpm-msg-ram = <&rpm_msg_ram>;
353 rpm_requests: rpm-requests {
354 compatible = "qcom,rpm-msm8998";
355 qcom,glink-channels = "rpm_requests";
357 rpmcc: clock-controller {
358 compatible = "qcom,rpmcc-msm8998", "qcom,rpmcc";
360 clock-names = "xo";
361 #clock-cells = <1>;
364 rpmpd: power-controller {
365 compatible = "qcom,msm8998-rpmpd";
366 #power-domain-cells = <1>;
367 operating-points-v2 = <&rpmpd_opp_table>;
369 rpmpd_opp_table: opp-table {
370 compatible = "operating-points-v2";
373 opp-level = <RPM_SMD_LEVEL_RETENTION>;
377 opp-level = <RPM_SMD_LEVEL_RETENTION_PLUS>;
381 opp-level = <RPM_SMD_LEVEL_MIN_SVS>;
385 opp-level = <RPM_SMD_LEVEL_LOW_SVS>;
389 opp-level = <RPM_SMD_LEVEL_SVS>;
393 opp-level = <RPM_SMD_LEVEL_SVS_PLUS>;
397 opp-level = <RPM_SMD_LEVEL_NOM>;
401 opp-level = <RPM_SMD_LEVEL_NOM_PLUS>;
405 opp-level = <RPM_SMD_LEVEL_TURBO>;
409 opp-level = <RPM_SMD_LEVEL_BINNING>;
419 memory-region = <&smem_mem>;
423 smp2p-lpass {
431 qcom,local-pid = <0>;
432 qcom,remote-pid = <2>;
434 adsp_smp2p_out: master-kernel {
435 qcom,entry-name = "master-kernel";
436 #qcom,smem-state-cells = <1>;
439 adsp_smp2p_in: slave-kernel {
440 qcom,entry-name = "slave-kernel";
442 interrupt-controller;
443 #interrupt-cells = <2>;
447 smp2p-mpss {
452 qcom,local-pid = <0>;
453 qcom,remote-pid = <1>;
455 modem_smp2p_out: master-kernel {
456 qcom,entry-name = "master-kernel";
457 #qcom,smem-state-cells = <1>;
460 modem_smp2p_in: slave-kernel {
461 qcom,entry-name = "slave-kernel";
462 interrupt-controller;
463 #interrupt-cells = <2>;
467 smp2p-slpi {
472 qcom,local-pid = <0>;
473 qcom,remote-pid = <3>;
475 slpi_smp2p_out: master-kernel {
476 qcom,entry-name = "master-kernel";
477 #qcom,smem-state-cells = <1>;
480 slpi_smp2p_in: slave-kernel {
481 qcom,entry-name = "slave-kernel";
482 interrupt-controller;
483 #interrupt-cells = <2>;
487 thermal-zones {
488 cpu0-thermal {
489 polling-delay-passive = <250>;
490 polling-delay = <1000>;
492 thermal-sensors = <&tsens0 1>;
495 cpu0_alert0: trip-point0 {
501 cpu0_crit: cpu-crit {
509 cpu1-thermal {
510 polling-delay-passive = <250>;
511 polling-delay = <1000>;
513 thermal-sensors = <&tsens0 2>;
516 cpu1_alert0: trip-point0 {
522 cpu1_crit: cpu-crit {
530 cpu2-thermal {
531 polling-delay-passive = <250>;
532 polling-delay = <1000>;
534 thermal-sensors = <&tsens0 3>;
537 cpu2_alert0: trip-point0 {
543 cpu2_crit: cpu-crit {
551 cpu3-thermal {
552 polling-delay-passive = <250>;
553 polling-delay = <1000>;
555 thermal-sensors = <&tsens0 4>;
558 cpu3_alert0: trip-point0 {
564 cpu3_crit: cpu-crit {
572 cpu4-thermal {
573 polling-delay-passive = <250>;
574 polling-delay = <1000>;
576 thermal-sensors = <&tsens0 7>;
579 cpu4_alert0: trip-point0 {
585 cpu4_crit: cpu-crit {
593 cpu5-thermal {
594 polling-delay-passive = <250>;
595 polling-delay = <1000>;
597 thermal-sensors = <&tsens0 8>;
600 cpu5_alert0: trip-point0 {
606 cpu5_crit: cpu-crit {
614 cpu6-thermal {
615 polling-delay-passive = <250>;
616 polling-delay = <1000>;
618 thermal-sensors = <&tsens0 9>;
621 cpu6_alert0: trip-point0 {
627 cpu6_crit: cpu-crit {
635 cpu7-thermal {
636 polling-delay-passive = <250>;
637 polling-delay = <1000>;
639 thermal-sensors = <&tsens0 10>;
642 cpu7_alert0: trip-point0 {
648 cpu7_crit: cpu-crit {
656 gpu-bottom-thermal {
657 polling-delay-passive = <250>;
658 polling-delay = <1000>;
660 thermal-sensors = <&tsens0 12>;
663 gpu1_alert0: trip-point0 {
671 gpu-top-thermal {
672 polling-delay-passive = <250>;
673 polling-delay = <1000>;
675 thermal-sensors = <&tsens0 13>;
678 gpu2_alert0: trip-point0 {
686 clust0-mhm-thermal {
687 polling-delay-passive = <250>;
688 polling-delay = <1000>;
690 thermal-sensors = <&tsens0 5>;
693 cluster0_mhm_alert0: trip-point0 {
701 clust1-mhm-thermal {
702 polling-delay-passive = <250>;
703 polling-delay = <1000>;
705 thermal-sensors = <&tsens0 6>;
708 cluster1_mhm_alert0: trip-point0 {
716 cluster1-l2-thermal {
717 polling-delay-passive = <250>;
718 polling-delay = <1000>;
720 thermal-sensors = <&tsens0 11>;
723 cluster1_l2_alert0: trip-point0 {
731 modem-thermal {
732 polling-delay-passive = <250>;
733 polling-delay = <1000>;
735 thermal-sensors = <&tsens1 1>;
738 modem_alert0: trip-point0 {
746 mem-thermal {
747 polling-delay-passive = <250>;
748 polling-delay = <1000>;
750 thermal-sensors = <&tsens1 2>;
753 mem_alert0: trip-point0 {
761 wlan-thermal {
762 polling-delay-passive = <250>;
763 polling-delay = <1000>;
765 thermal-sensors = <&tsens1 3>;
768 wlan_alert0: trip-point0 {
776 q6-dsp-thermal {
777 polling-delay-passive = <250>;
778 polling-delay = <1000>;
780 thermal-sensors = <&tsens1 4>;
783 q6_dsp_alert0: trip-point0 {
791 camera-thermal {
792 polling-delay-passive = <250>;
793 polling-delay = <1000>;
795 thermal-sensors = <&tsens1 5>;
798 camera_alert0: trip-point0 {
806 multimedia-thermal {
807 polling-delay-passive = <250>;
808 polling-delay = <1000>;
810 thermal-sensors = <&tsens1 6>;
813 multimedia_alert0: trip-point0 {
823 compatible = "arm,armv8-timer";
831 #address-cells = <1>;
832 #size-cells = <1>;
834 compatible = "simple-bus";
836 gcc: clock-controller@100000 {
837 compatible = "qcom,gcc-msm8998";
838 #clock-cells = <1>;
839 #reset-cells = <1>;
840 #power-domain-cells = <1>;
843 clock-names = "xo", "sleep_clk";
848 * reside as read-only for the HLOS. If the HLOS tried to enable or disable
850 * enabled but unused during boot-up), the device will most likely decide
853 * as protected. The board dts (or a user-supplied dts) can override the
857 protected-clocks = <AGGRE2_SNOC_NORTH_AXI>,
863 compatible = "qcom,rpm-msg-ram";
868 compatible = "qcom,msm8998-qfprom", "qcom,qfprom";
870 #address-cells = <1>;
871 #size-cells = <1>;
873 qusb2_hstx_trim: hstx-trim@23a {
879 tsens0: thermal@10ab000 {
880 compatible = "qcom,msm8998-tsens", "qcom,tsens-v2";
886 interrupt-names = "uplow", "critical";
887 #thermal-sensor-cells = <1>;
890 tsens1: thermal@10ae000 {
891 compatible = "qcom,msm8998-tsens", "qcom,tsens-v2";
897 interrupt-names = "uplow", "critical";
898 #thermal-sensor-cells = <1>;
902 compatible = "qcom,msm8998-smmu-v2", "qcom,smmu-v2";
904 #iommu-cells = <1>;
906 #global-interrupts = <0>;
917 compatible = "qcom,msm8998-smmu-v2", "qcom,smmu-v2";
919 #iommu-cells = <1>;
921 #global-interrupts = <0>;
936 compatible = "qcom,pcie-msm8998", "qcom,pcie-msm8996";
941 reg-names = "parf", "dbi", "elbi", "config";
943 linux,pci-domain = <0>;
944 bus-range = <0x00 0xff>;
945 #address-cells = <3>;
946 #size-cells = <2>;
947 num-lanes = <1>;
949 phy-names = "pciephy";
955 #interrupt-cells = <1>;
957 interrupt-names = "msi";
958 interrupt-map-mask = <0 0 0 0x7>;
959 interrupt-map = <0 0 0 1 &intc 0 0 135 IRQ_TYPE_LEVEL_HIGH>,
969 clock-names = "pipe", "aux", "cfg", "bus_master", "bus_slave";
971 power-domains = <&gcc PCIE_0_GDSC>;
972 iommu-map = <0x100 &anoc1_smmu 0x1480 1>;
973 perst-gpios = <&tlmm 35 GPIO_ACTIVE_LOW>;
977 compatible = "qcom,msm8998-qmp-pcie-phy";
979 #address-cells = <1>;
980 #size-cells = <1>;
987 clock-names = "aux", "cfg_ahb", "ref";
990 reset-names = "phy", "common";
992 vdda-phy-supply = <&vreg_l1a_0p875>;
993 vdda-pll-supply = <&vreg_l2a_1p2>;
997 #phy-cells = <0>;
1000 clock-names = "pipe0";
1001 clock-output-names = "pcie_0_pipe_clk_src";
1002 #clock-cells = <0>;
1007 compatible = "qcom,msm8998-ufshc", "qcom,ufshc", "jedec,ufs-2.0";
1011 phy-names = "ufsphy";
1012 lanes-per-direction = <2>;
1013 power-domains = <&gcc UFS_GDSC>;
1015 #reset-cells = <1>;
1017 clock-names =
1035 freq-table-hz =
1046 reset-names = "rst";
1050 compatible = "qcom,msm8998-qmp-ufs-phy";
1052 #address-cells = <1>;
1053 #size-cells = <1>;
1057 clock-names =
1064 reset-names = "ufsphy";
1073 #phy-cells = <0>;
1078 compatible = "qcom,tcsr-mutex";
1080 #hwlock-cells = <1>;
1084 compatible = "qcom,msm8998-tcsr", "syscon";
1089 compatible = "qcom,msm8998-pinctrl";
1092 gpio-ranges = <&tlmm 0 0 150>;
1093 gpio-controller;
1094 #gpio-cells = <2>;
1095 interrupt-controller;
1096 #interrupt-cells = <2>;
1098 sdc2_on: sdc2-on-state {
1099 clk-pins {
1101 drive-strength = <16>;
1102 bias-disable;
1105 cmd-pins {
1107 drive-strength = <10>;
1108 bias-pull-up;
1111 data-pins {
1113 drive-strength = <10>;
1114 bias-pull-up;
1118 sdc2_off: sdc2-off-state {
1119 clk-pins {
1121 drive-strength = <2>;
1122 bias-disable;
1125 cmd-pins {
1127 drive-strength = <2>;
1128 bias-pull-up;
1131 data-pins {
1133 drive-strength = <2>;
1134 bias-pull-up;
1138 sdc2_cd: sdc2-cd-state {
1141 bias-pull-up;
1142 drive-strength = <2>;
1145 blsp1_uart3_on: blsp1-uart3-on-state {
1146 tx-pins {
1149 drive-strength = <2>;
1150 bias-disable;
1153 rx-pins {
1156 drive-strength = <2>;
1157 bias-disable;
1160 cts-pins {
1163 drive-strength = <2>;
1164 bias-disable;
1167 rfr-pins {
1170 drive-strength = <2>;
1171 bias-disable;
1175 blsp1_i2c1_default: blsp1-i2c1-default-state {
1178 drive-strength = <2>;
1179 bias-disable;
1182 blsp1_i2c1_sleep: blsp1-i2c1-sleep-state-state {
1185 drive-strength = <2>;
1186 bias-pull-up;
1189 blsp1_i2c2_default: blsp1-i2c2-default-state {
1192 drive-strength = <2>;
1193 bias-disable;
1196 blsp1_i2c2_sleep: blsp1-i2c2-sleep-state-state {
1199 drive-strength = <2>;
1200 bias-pull-up;
1203 blsp1_i2c3_default: blsp1-i2c3-default-state {
1206 drive-strength = <2>;
1207 bias-disable;
1210 blsp1_i2c3_sleep: blsp1-i2c3-sleep-state {
1213 drive-strength = <2>;
1214 bias-pull-up;
1217 blsp1_i2c4_default: blsp1-i2c4-default-state {
1220 drive-strength = <2>;
1221 bias-disable;
1224 blsp1_i2c4_sleep: blsp1-i2c4-sleep-state {
1227 drive-strength = <2>;
1228 bias-pull-up;
1231 blsp1_i2c5_default: blsp1-i2c5-default-state {
1234 drive-strength = <2>;
1235 bias-disable;
1238 blsp1_i2c5_sleep: blsp1-i2c5-sleep-state {
1241 drive-strength = <2>;
1242 bias-pull-up;
1245 blsp1_i2c6_default: blsp1-i2c6-default-state {
1248 drive-strength = <2>;
1249 bias-disable;
1252 blsp1_i2c6_sleep: blsp1-i2c6-sleep-state {
1255 drive-strength = <2>;
1256 bias-pull-up;
1259 blsp1_spi_b_default: blsp1-spi-b-default-state {
1262 drive-strength = <6>;
1263 bias-disable;
1266 blsp1_spi1_default: blsp1-spi1-default-state {
1269 drive-strength = <6>;
1270 bias-disable;
1273 blsp1_spi2_default: blsp1-spi2-default-state {
1276 drive-strength = <6>;
1277 bias-disable;
1280 blsp1_spi3_default: blsp1-spi3-default-state {
1283 drive-strength = <6>;
1284 bias-disable;
1287 blsp1_spi4_default: blsp1-spi4-default-state {
1290 drive-strength = <6>;
1291 bias-disable;
1294 blsp1_spi5_default: blsp1-spi5-default-state {
1297 drive-strength = <6>;
1298 bias-disable;
1301 blsp1_spi6_default: blsp1-spi6-default-state {
1304 drive-strength = <6>;
1305 bias-disable;
1310 blsp2_i2c1_default: blsp2-i2c1-default-state {
1313 drive-strength = <2>;
1314 bias-disable;
1317 blsp2_i2c1_sleep: blsp2-i2c1-sleep-state {
1320 drive-strength = <2>;
1321 bias-pull-up;
1324 blsp2_i2c2_default: blsp2-i2c2-default-state {
1327 drive-strength = <2>;
1328 bias-disable;
1331 blsp2_i2c2_sleep: blsp2-i2c2-sleep-state {
1334 drive-strength = <2>;
1335 bias-pull-up;
1338 blsp2_i2c3_default: blsp2-i2c3-default-state {
1341 drive-strength = <2>;
1342 bias-disable;
1345 blsp2_i2c3_sleep: blsp2-i2c3-sleep-state {
1348 drive-strength = <2>;
1349 bias-pull-up;
1352 blsp2_i2c4_default: blsp2-i2c4-default-state {
1355 drive-strength = <2>;
1356 bias-disable;
1359 blsp2_i2c4_sleep: blsp2-i2c4-sleep-state {
1362 drive-strength = <2>;
1363 bias-pull-up;
1366 blsp2_i2c5_default: blsp2-i2c5-default-state {
1369 drive-strength = <2>;
1370 bias-disable;
1373 blsp2_i2c5_sleep: blsp2-i2c5-sleep-state {
1376 drive-strength = <2>;
1377 bias-pull-up;
1380 blsp2_i2c6_default: blsp2-i2c6-default-state {
1383 drive-strength = <2>;
1384 bias-disable;
1387 blsp2_i2c6_sleep: blsp2-i2c6-sleep-state {
1390 drive-strength = <2>;
1391 bias-pull-up;
1394 blsp2_spi1_default: blsp2-spi1-default-state {
1397 drive-strength = <6>;
1398 bias-disable;
1401 blsp2_spi2_default: blsp2-spi2-default-state {
1404 drive-strength = <6>;
1405 bias-disable;
1408 blsp2_spi3_default: blsp2-spi3-default-state {
1411 drive-strength = <6>;
1412 bias-disable;
1415 blsp2_spi4_default: blsp2-spi4-default-state {
1418 drive-strength = <6>;
1419 bias-disable;
1422 blsp2_spi5_default: blsp2-spi5-default-state {
1425 drive-strength = <6>;
1426 bias-disable;
1429 blsp2_spi6_default: blsp2-spi6-default-state {
1432 drive-strength = <6>;
1433 bias-disable;
1438 compatible = "qcom,msm8998-mss-pil";
1440 reg-names = "qdsp6", "rmb";
1442 interrupts-extended =
1449 interrupt-names = "wdog", "fatal", "ready",
1450 "handover", "stop-ack",
1451 "shutdown-ack";
1461 clock-names = "iface", "bus", "mem", "gpll0_mss",
1464 qcom,smem-states = <&modem_smp2p_out 0>;
1465 qcom,smem-state-names = "stop";
1468 reset-names = "mss_restart";
1470 qcom,halt-regs = <&tcsr_regs_1 0x3000 0x5000 0x4000>;
1472 power-domains = <&rpmpd MSM8998_VDDCX>,
1474 power-domain-names = "cx", "mx";
1479 memory-region = <&mba_mem>;
1483 memory-region = <&mpss_mem>;
1487 memory-region = <&mdata_mem>;
1490 glink-edge {
1493 qcom,remote-pid = <1>;
1499 compatible = "qcom,adreno-540.1", "qcom,adreno";
1501 reg-names = "kgsl_3d0_reg_memory";
1509 clock-names = "iface",
1518 operating-points-v2 = <&gpu_opp_table>;
1519 power-domains = <&rpmpd MSM8998_VDDMX>;
1522 gpu_opp_table: opp-table {
1523 compatible = "operating-points-v2";
1524 opp-710000097 {
1525 opp-hz = /bits/ 64 <710000097>;
1526 opp-level = <RPM_SMD_LEVEL_TURBO>;
1527 opp-supported-hw = <0xff>;
1530 opp-670000048 {
1531 opp-hz = /bits/ 64 <670000048>;
1532 opp-level = <RPM_SMD_LEVEL_NOM_PLUS>;
1533 opp-supported-hw = <0xff>;
1536 opp-596000097 {
1537 opp-hz = /bits/ 64 <596000097>;
1538 opp-level = <RPM_SMD_LEVEL_NOM>;
1539 opp-supported-hw = <0xff>;
1542 opp-515000097 {
1543 opp-hz = /bits/ 64 <515000097>;
1544 opp-level = <RPM_SMD_LEVEL_SVS_PLUS>;
1545 opp-supported-hw = <0xff>;
1548 opp-414000000 {
1549 opp-hz = /bits/ 64 <414000000>;
1550 opp-level = <RPM_SMD_LEVEL_SVS>;
1551 opp-supported-hw = <0xff>;
1554 opp-342000000 {
1555 opp-hz = /bits/ 64 <342000000>;
1556 opp-level = <RPM_SMD_LEVEL_LOW_SVS>;
1557 opp-supported-hw = <0xff>;
1560 opp-257000000 {
1561 opp-hz = /bits/ 64 <257000000>;
1562 opp-level = <RPM_SMD_LEVEL_MIN_SVS>;
1563 opp-supported-hw = <0xff>;
1569 compatible = "qcom,msm8998-smmu-v2", "qcom,smmu-v2";
1574 clock-names = "iface", "mem", "mem_iface";
1576 #global-interrupts = <0>;
1577 #iommu-cells = <1>;
1583 * GPU-GX GDSC's parent is GPU-CX. We need to bring up the
1584 * GPU-CX for SMMU but we need both of them up for Adreno.
1590 power-domains = <&gpucc GPU_GX_GDSC>;
1593 gpucc: clock-controller@5065000 {
1594 compatible = "qcom,msm8998-gpucc";
1595 #clock-cells = <1>;
1596 #reset-cells = <1>;
1597 #power-domain-cells = <1>;
1602 clock-names = "xo",
1607 compatible = "qcom,msm8998-slpi-pas";
1610 interrupts-extended = <&intc GIC_SPI 390 IRQ_TYPE_EDGE_RISING>,
1615 interrupt-names = "wdog", "fatal", "ready",
1616 "handover", "stop-ack";
1618 px-supply = <&vreg_lvs2a_1p8>;
1622 clock-names = "xo", "aggre2";
1624 memory-region = <&slpi_mem>;
1626 qcom,smem-states = <&slpi_smp2p_out 0>;
1627 qcom,smem-state-names = "stop";
1629 power-domains = <&rpmpd MSM8998_SSCCX>;
1630 power-domain-names = "ssc_cx";
1634 glink-edge {
1637 qcom,remote-pid = <3>;
1643 compatible = "arm,coresight-stm", "arm,primecell";
1646 reg-names = "stm-base", "stm-stimulus-base";
1650 clock-names = "apb_pclk", "atclk";
1652 out-ports {
1655 remote-endpoint = <&funnel0_in7>;
1662 compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1667 clock-names = "apb_pclk", "atclk";
1669 out-ports {
1672 remote-endpoint =
1678 in-ports {
1679 #address-cells = <1>;
1680 #size-cells = <0>;
1685 remote-endpoint = <&stm_out>;
1692 compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1697 clock-names = "apb_pclk", "atclk";
1699 out-ports {
1702 remote-endpoint =
1708 in-ports {
1709 #address-cells = <1>;
1710 #size-cells = <0>;
1715 remote-endpoint =
1723 compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1728 clock-names = "apb_pclk", "atclk";
1730 out-ports {
1733 remote-endpoint =
1739 in-ports {
1740 #address-cells = <1>;
1741 #size-cells = <0>;
1746 remote-endpoint =
1754 remote-endpoint =
1762 compatible = "arm,coresight-dynamic-replicator", "arm,primecell";
1767 clock-names = "apb_pclk", "atclk";
1769 out-ports {
1772 remote-endpoint = <&etr_in>;
1777 in-ports {
1780 remote-endpoint = <&etf_out>;
1787 compatible = "arm,coresight-tmc", "arm,primecell";
1792 clock-names = "apb_pclk", "atclk";
1794 out-ports {
1797 remote-endpoint =
1803 in-ports {
1806 remote-endpoint =
1814 compatible = "arm,coresight-tmc", "arm,primecell";
1819 clock-names = "apb_pclk", "atclk";
1820 arm,scatter-gather;
1822 in-ports {
1825 remote-endpoint =
1833 compatible = "arm,coresight-etm4x", "arm,primecell";
1838 clock-names = "apb_pclk", "atclk";
1842 out-ports {
1845 remote-endpoint =
1853 compatible = "arm,coresight-etm4x", "arm,primecell";
1858 clock-names = "apb_pclk", "atclk";
1862 out-ports {
1865 remote-endpoint =
1873 compatible = "arm,coresight-etm4x", "arm,primecell";
1878 clock-names = "apb_pclk", "atclk";
1882 out-ports {
1885 remote-endpoint =
1893 compatible = "arm,coresight-etm4x", "arm,primecell";
1898 clock-names = "apb_pclk", "atclk";
1902 out-ports {
1905 remote-endpoint =
1913 compatible = "arm,coresight-etm4x", "arm,primecell";
1918 clock-names = "apb_pclk", "atclk";
1920 out-ports {
1923 remote-endpoint =
1929 in-ports {
1930 #address-cells = <1>;
1931 #size-cells = <0>;
1936 remote-endpoint =
1944 remote-endpoint =
1952 remote-endpoint =
1960 remote-endpoint =
1968 remote-endpoint =
1976 remote-endpoint =
1984 remote-endpoint =
1992 remote-endpoint =
2000 compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
2005 clock-names = "apb_pclk", "atclk";
2007 out-ports {
2010 remote-endpoint =
2016 in-ports {
2019 remote-endpoint =
2027 compatible = "arm,coresight-etm4x", "arm,primecell";
2032 clock-names = "apb_pclk", "atclk";
2036 out-ports {
2039 remote-endpoint = <&apss_funnel_in4>;
2046 compatible = "arm,coresight-etm4x", "arm,primecell";
2051 clock-names = "apb_pclk", "atclk";
2055 out-ports {
2058 remote-endpoint = <&apss_funnel_in5>;
2065 compatible = "arm,coresight-etm4x", "arm,primecell";
2070 clock-names = "apb_pclk", "atclk";
2074 out-ports {
2077 remote-endpoint = <&apss_funnel_in6>;
2084 compatible = "arm,coresight-etm4x", "arm,primecell";
2089 clock-names = "apb_pclk", "atclk";
2093 out-ports {
2096 remote-endpoint = <&apss_funnel_in7>;
2103 compatible = "qcom,rpm-stats";
2108 compatible = "qcom,spmi-pmic-arb";
2114 reg-names = "core", "chnls", "obsrvr", "intr", "cnfg";
2115 interrupt-names = "periph_irq";
2119 #address-cells = <2>;
2120 #size-cells = <0>;
2121 interrupt-controller;
2122 #interrupt-cells = <4>;
2126 compatible = "qcom,msm8998-dwc3", "qcom,dwc3";
2129 #address-cells = <1>;
2130 #size-cells = <1>;
2138 clock-names = "cfg_noc",
2144 assigned-clocks = <&gcc GCC_USB30_MOCK_UTMI_CLK>,
2146 assigned-clock-rates = <19200000>, <120000000>;
2150 interrupt-names = "hs_phy_irq", "ss_phy_irq";
2152 power-domains = <&gcc USB_30_GDSC>;
2162 snps,parkmode-disable-ss-quirk;
2164 phy-names = "usb2-phy", "usb3-phy";
2165 snps,has-lpm-erratum;
2166 snps,hird-threshold = /bits/ 8 <0x10>;
2171 compatible = "qcom,msm8998-qmp-usb3-phy";
2178 clock-names = "aux",
2182 clock-output-names = "usb3_phy_pipe_clk_src";
2183 #clock-cells = <0>;
2184 #phy-cells = <0>;
2188 reset-names = "phy",
2195 compatible = "qcom,msm8998-qusb2-phy";
2198 #phy-cells = <0>;
2202 clock-names = "cfg_ahb", "ref";
2206 nvmem-cells = <&qusb2_hstx_trim>;
2210 compatible = "qcom,msm8998-sdhci", "qcom,sdhci-msm-v4";
2212 reg-names = "hc", "core";
2216 interrupt-names = "hc_irq", "pwr_irq";
2218 clock-names = "iface", "core", "xo";
2222 bus-width = <4>;
2226 blsp1_dma: dma-controller@c144000 {
2227 compatible = "qcom,bam-v1.7.0";
2231 clock-names = "bam_clk";
2232 #dma-cells = <1>;
2234 qcom,controlled-remotely;
2235 num-channels = <18>;
2236 qcom,num-ees = <4>;
2240 compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm";
2245 clock-names = "core", "iface";
2247 dma-names = "tx", "rx";
2248 pinctrl-names = "default";
2249 pinctrl-0 = <&blsp1_uart3_on>;
2254 compatible = "qcom,i2c-qup-v2.2.1";
2260 clock-names = "core", "iface";
2262 dma-names = "tx", "rx";
2263 pinctrl-names = "default", "sleep";
2264 pinctrl-0 = <&blsp1_i2c1_default>;
2265 pinctrl-1 = <&blsp1_i2c1_sleep>;
2266 clock-frequency = <400000>;
2269 #address-cells = <1>;
2270 #size-cells = <0>;
2274 compatible = "qcom,i2c-qup-v2.2.1";
2280 clock-names = "core", "iface";
2282 dma-names = "tx", "rx";
2283 pinctrl-names = "default", "sleep";
2284 pinctrl-0 = <&blsp1_i2c2_default>;
2285 pinctrl-1 = <&blsp1_i2c2_sleep>;
2286 clock-frequency = <400000>;
2289 #address-cells = <1>;
2290 #size-cells = <0>;
2294 compatible = "qcom,i2c-qup-v2.2.1";
2300 clock-names = "core", "iface";
2302 dma-names = "tx", "rx";
2303 pinctrl-names = "default", "sleep";
2304 pinctrl-0 = <&blsp1_i2c3_default>;
2305 pinctrl-1 = <&blsp1_i2c3_sleep>;
2306 clock-frequency = <400000>;
2309 #address-cells = <1>;
2310 #size-cells = <0>;
2314 compatible = "qcom,i2c-qup-v2.2.1";
2320 clock-names = "core", "iface";
2322 dma-names = "tx", "rx";
2323 pinctrl-names = "default", "sleep";
2324 pinctrl-0 = <&blsp1_i2c4_default>;
2325 pinctrl-1 = <&blsp1_i2c4_sleep>;
2326 clock-frequency = <400000>;
2329 #address-cells = <1>;
2330 #size-cells = <0>;
2334 compatible = "qcom,i2c-qup-v2.2.1";
2340 clock-names = "core", "iface";
2342 dma-names = "tx", "rx";
2343 pinctrl-names = "default", "sleep";
2344 pinctrl-0 = <&blsp1_i2c5_default>;
2345 pinctrl-1 = <&blsp1_i2c5_sleep>;
2346 clock-frequency = <400000>;
2349 #address-cells = <1>;
2350 #size-cells = <0>;
2354 compatible = "qcom,i2c-qup-v2.2.1";
2360 clock-names = "core", "iface";
2362 dma-names = "tx", "rx";
2363 pinctrl-names = "default", "sleep";
2364 pinctrl-0 = <&blsp1_i2c6_default>;
2365 pinctrl-1 = <&blsp1_i2c6_sleep>;
2366 clock-frequency = <400000>;
2369 #address-cells = <1>;
2370 #size-cells = <0>;
2374 compatible = "qcom,spi-qup-v2.2.1";
2380 clock-names = "core", "iface";
2382 dma-names = "tx", "rx";
2383 pinctrl-names = "default";
2384 pinctrl-0 = <&blsp1_spi1_default>;
2387 #address-cells = <1>;
2388 #size-cells = <0>;
2392 compatible = "qcom,spi-qup-v2.2.1";
2398 clock-names = "core", "iface";
2400 dma-names = "tx", "rx";
2401 pinctrl-names = "default";
2402 pinctrl-0 = <&blsp1_spi2_default>;
2405 #address-cells = <1>;
2406 #size-cells = <0>;
2410 compatible = "qcom,spi-qup-v2.2.1";
2416 clock-names = "core", "iface";
2418 dma-names = "tx", "rx";
2419 pinctrl-names = "default";
2420 pinctrl-0 = <&blsp1_spi3_default>;
2423 #address-cells = <1>;
2424 #size-cells = <0>;
2428 compatible = "qcom,spi-qup-v2.2.1";
2434 clock-names = "core", "iface";
2436 dma-names = "tx", "rx";
2437 pinctrl-names = "default";
2438 pinctrl-0 = <&blsp1_spi4_default>;
2441 #address-cells = <1>;
2442 #size-cells = <0>;
2446 compatible = "qcom,spi-qup-v2.2.1";
2452 clock-names = "core", "iface";
2454 dma-names = "tx", "rx";
2455 pinctrl-names = "default";
2456 pinctrl-0 = <&blsp1_spi5_default>;
2459 #address-cells = <1>;
2460 #size-cells = <0>;
2464 compatible = "qcom,spi-qup-v2.2.1";
2470 clock-names = "core", "iface";
2472 dma-names = "tx", "rx";
2473 pinctrl-names = "default";
2474 pinctrl-0 = <&blsp1_spi6_default>;
2477 #address-cells = <1>;
2478 #size-cells = <0>;
2481 blsp2_dma: dma-controller@c184000 {
2482 compatible = "qcom,bam-v1.7.0";
2486 clock-names = "bam_clk";
2487 #dma-cells = <1>;
2489 qcom,controlled-remotely;
2490 num-channels = <18>;
2491 qcom,num-ees = <4>;
2495 compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm";
2500 clock-names = "core", "iface";
2505 compatible = "qcom,i2c-qup-v2.2.1";
2511 clock-names = "core", "iface";
2513 dma-names = "tx", "rx";
2514 pinctrl-names = "default", "sleep";
2515 pinctrl-0 = <&blsp2_i2c1_default>;
2516 pinctrl-1 = <&blsp2_i2c1_sleep>;
2517 clock-frequency = <400000>;
2520 #address-cells = <1>;
2521 #size-cells = <0>;
2525 compatible = "qcom,i2c-qup-v2.2.1";
2531 clock-names = "core", "iface";
2533 dma-names = "tx", "rx";
2534 pinctrl-names = "default", "sleep";
2535 pinctrl-0 = <&blsp2_i2c2_default>;
2536 pinctrl-1 = <&blsp2_i2c2_sleep>;
2537 clock-frequency = <400000>;
2540 #address-cells = <1>;
2541 #size-cells = <0>;
2545 compatible = "qcom,i2c-qup-v2.2.1";
2551 clock-names = "core", "iface";
2553 dma-names = "tx", "rx";
2554 pinctrl-names = "default", "sleep";
2555 pinctrl-0 = <&blsp2_i2c3_default>;
2556 pinctrl-1 = <&blsp2_i2c3_sleep>;
2557 clock-frequency = <400000>;
2560 #address-cells = <1>;
2561 #size-cells = <0>;
2565 compatible = "qcom,i2c-qup-v2.2.1";
2571 clock-names = "core", "iface";
2573 dma-names = "tx", "rx";
2574 pinctrl-names = "default", "sleep";
2575 pinctrl-0 = <&blsp2_i2c4_default>;
2576 pinctrl-1 = <&blsp2_i2c4_sleep>;
2577 clock-frequency = <400000>;
2580 #address-cells = <1>;
2581 #size-cells = <0>;
2585 compatible = "qcom,i2c-qup-v2.2.1";
2591 clock-names = "core", "iface";
2593 dma-names = "tx", "rx";
2594 pinctrl-names = "default", "sleep";
2595 pinctrl-0 = <&blsp2_i2c5_default>;
2596 pinctrl-1 = <&blsp2_i2c5_sleep>;
2597 clock-frequency = <400000>;
2600 #address-cells = <1>;
2601 #size-cells = <0>;
2605 compatible = "qcom,i2c-qup-v2.2.1";
2611 clock-names = "core", "iface";
2613 dma-names = "tx", "rx";
2614 pinctrl-names = "default", "sleep";
2615 pinctrl-0 = <&blsp2_i2c6_default>;
2616 pinctrl-1 = <&blsp2_i2c6_sleep>;
2617 clock-frequency = <400000>;
2620 #address-cells = <1>;
2621 #size-cells = <0>;
2625 compatible = "qcom,spi-qup-v2.2.1";
2631 clock-names = "core", "iface";
2633 dma-names = "tx", "rx";
2634 pinctrl-names = "default";
2635 pinctrl-0 = <&blsp2_spi1_default>;
2638 #address-cells = <1>;
2639 #size-cells = <0>;
2643 compatible = "qcom,spi-qup-v2.2.1";
2649 clock-names = "core", "iface";
2651 dma-names = "tx", "rx";
2652 pinctrl-names = "default";
2653 pinctrl-0 = <&blsp2_spi2_default>;
2656 #address-cells = <1>;
2657 #size-cells = <0>;
2661 compatible = "qcom,spi-qup-v2.2.1";
2667 clock-names = "core", "iface";
2669 dma-names = "tx", "rx";
2670 pinctrl-names = "default";
2671 pinctrl-0 = <&blsp2_spi3_default>;
2674 #address-cells = <1>;
2675 #size-cells = <0>;
2679 compatible = "qcom,spi-qup-v2.2.1";
2685 clock-names = "core", "iface";
2687 dma-names = "tx", "rx";
2688 pinctrl-names = "default";
2689 pinctrl-0 = <&blsp2_spi4_default>;
2692 #address-cells = <1>;
2693 #size-cells = <0>;
2697 compatible = "qcom,spi-qup-v2.2.1";
2703 clock-names = "core", "iface";
2705 dma-names = "tx", "rx";
2706 pinctrl-names = "default";
2707 pinctrl-0 = <&blsp2_spi5_default>;
2710 #address-cells = <1>;
2711 #size-cells = <0>;
2715 compatible = "qcom,spi-qup-v2.2.1";
2721 clock-names = "core", "iface";
2723 dma-names = "tx", "rx";
2724 pinctrl-names = "default";
2725 pinctrl-0 = <&blsp2_spi6_default>;
2728 #address-cells = <1>;
2729 #size-cells = <0>;
2732 mmcc: clock-controller@c8c0000 {
2733 compatible = "qcom,mmcc-msm8998";
2734 #clock-cells = <1>;
2735 #reset-cells = <1>;
2736 #power-domain-cells = <1>;
2739 clock-names = "xo",
2761 mdss: display-subsystem@c900000 {
2762 compatible = "qcom,msm8998-mdss";
2764 reg-names = "mdss";
2767 interrupt-controller;
2768 #interrupt-cells = <1>;
2773 clock-names = "iface",
2777 power-domains = <&mmcc MDSS_GDSC>;
2780 #address-cells = <1>;
2781 #size-cells = <1>;
2786 mdss_mdp: display-controller@c901000 {
2787 compatible = "qcom,msm8998-dpu";
2792 reg-names = "mdp",
2797 interrupt-parent = <&mdss>;
2805 clock-names = "iface",
2811 assigned-clocks = <&mmcc MDSS_VSYNC_CLK>;
2812 assigned-clock-rates = <19200000>;
2814 operating-points-v2 = <&mdp_opp_table>;
2815 power-domains = <&rpmpd MSM8998_VDDMX>;
2817 mdp_opp_table: opp-table {
2818 compatible = "operating-points-v2";
2820 opp-171430000 {
2821 opp-hz = /bits/ 64 <171430000>;
2822 required-opps = <&rpmpd_opp_low_svs>;
2825 opp-275000000 {
2826 opp-hz = /bits/ 64 <275000000>;
2827 required-opps = <&rpmpd_opp_svs>;
2830 opp-330000000 {
2831 opp-hz = /bits/ 64 <330000000>;
2832 required-opps = <&rpmpd_opp_nom>;
2835 opp-412500000 {
2836 opp-hz = /bits/ 64 <412500000>;
2837 required-opps = <&rpmpd_opp_turbo>;
2842 #address-cells = <1>;
2843 #size-cells = <0>;
2849 remote-endpoint = <&mdss_dsi0_in>;
2857 remote-endpoint = <&mdss_dsi1_in>;
2864 compatible = "qcom,msm8998-dsi-ctrl", "qcom,mdss-dsi-ctrl";
2866 reg-names = "dsi_ctrl";
2868 interrupt-parent = <&mdss>;
2877 clock-names = "byte",
2883 assigned-clocks = <&mmcc BYTE0_CLK_SRC>,
2885 assigned-clock-parents = <&mdss_dsi0_phy 0>,
2888 operating-points-v2 = <&dsi_opp_table>;
2889 power-domains = <&rpmpd MSM8998_VDDCX>;
2892 phy-names = "dsi";
2894 #address-cells = <1>;
2895 #size-cells = <0>;
2900 #address-cells = <1>;
2901 #size-cells = <0>;
2907 remote-endpoint = <&dpu_intf1_out>;
2921 compatible = "qcom,dsi-phy-10nm-8998";
2925 reg-names = "dsi_phy",
2931 clock-names = "iface", "ref";
2933 #clock-cells = <1>;
2934 #phy-cells = <0>;
2940 compatible = "qcom,msm8998-dsi-ctrl", "qcom,mdss-dsi-ctrl";
2942 reg-names = "dsi_ctrl";
2944 interrupt-parent = <&mdss>;
2953 clock-names = "byte",
2959 assigned-clocks = <&mmcc BYTE1_CLK_SRC>,
2961 assigned-clock-parents = <&mdss_dsi1_phy 0>,
2964 operating-points-v2 = <&dsi_opp_table>;
2965 power-domains = <&rpmpd MSM8998_VDDCX>;
2968 phy-names = "dsi";
2970 #address-cells = <1>;
2971 #size-cells = <0>;
2976 #address-cells = <1>;
2977 #size-cells = <0>;
2983 remote-endpoint = <&dpu_intf2_out>;
2997 compatible = "qcom,dsi-phy-10nm-8998";
3001 reg-names = "dsi_phy",
3007 clock-names = "iface",
3010 #clock-cells = <1>;
3011 #phy-cells = <0>;
3018 compatible = "qcom,msm8998-smmu-v2", "qcom,smmu-v2";
3020 #iommu-cells = <1>;
3025 clock-names = "iface-mm",
3026 "iface-smmu",
3027 "bus-smmu";
3029 #global-interrupts = <0>;
3052 power-domains = <&mmcc BIMC_SMMU_GDSC>;
3056 compatible = "qcom,msm8998-adsp-pas";
3059 interrupts-extended = <&intc GIC_SPI 162 IRQ_TYPE_EDGE_RISING>,
3064 interrupt-names = "wdog", "fatal", "ready",
3065 "handover", "stop-ack";
3068 clock-names = "xo";
3070 memory-region = <&adsp_mem>;
3072 qcom,smem-states = <&adsp_smp2p_out 0>;
3073 qcom,smem-state-names = "stop";
3075 power-domains = <&rpmpd MSM8998_VDDCX>;
3076 power-domain-names = "cx";
3080 glink-edge {
3083 qcom,remote-pid = <2>;
3089 compatible = "qcom,msm8998-apcs-hmss-global",
3090 "qcom,msm8994-apcs-kpss-global";
3093 #mbox-cells = <1>;
3097 #address-cells = <1>;
3098 #size-cells = <1>;
3100 compatible = "arm,armv7-timer-mem";
3104 frame-number = <0>;
3112 frame-number = <1>;
3119 frame-number = <2>;
3126 frame-number = <3>;
3133 frame-number = <4>;
3140 frame-number = <5>;
3147 frame-number = <6>;
3154 intc: interrupt-controller@17a00000 {
3155 compatible = "arm,gic-v3";
3158 #interrupt-cells = <3>;
3159 #address-cells = <1>;
3160 #size-cells = <1>;
3162 interrupt-controller;
3163 #redistributor-regions = <1>;
3164 redistributor-stride = <0x0 0x20000>;
3169 compatible = "qcom,wcn3990-wifi";
3172 reg-names = "membase";
3173 memory-region = <&wlan_msa_mem>;
3175 clock-names = "cxo_ref_clk_pin";
3191 qcom,snoc-host-cap-8bit-quirk;