1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright (c) 2016, The Linux Foundation. All rights reserved. */
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,rpmcc.h>
8 #include <dt-bindings/power/qcom-rpmpd.h>
9 #include <dt-bindings/gpio/gpio.h>
12 interrupt-parent = <&intc>;
14 qcom,msm-id = <292 0x0>;
22 device_type = "memory";
23 /* We expect the bootloader to fill in the reg */
32 hyp_mem: memory@85800000 {
33 reg = <0x0 0x85800000 0x0 0x600000>;
37 xbl_mem: memory@85e00000 {
38 reg = <0x0 0x85e00000 0x0 0x100000>;
42 smem_mem: smem-mem@86000000 {
43 reg = <0x0 0x86000000 0x0 0x200000>;
47 tz_mem: memory@86200000 {
48 reg = <0x0 0x86200000 0x0 0x2d00000>;
52 rmtfs_mem: memory@88f00000 {
53 compatible = "qcom,rmtfs-mem";
54 reg = <0x0 0x88f00000 0x0 0x200000>;
61 spss_mem: memory@8ab00000 {
62 reg = <0x0 0x8ab00000 0x0 0x700000>;
66 adsp_mem: memory@8b200000 {
67 reg = <0x0 0x8b200000 0x0 0x1a00000>;
71 mpss_mem: memory@8cc00000 {
72 reg = <0x0 0x8cc00000 0x0 0x7000000>;
76 venus_mem: memory@93c00000 {
77 reg = <0x0 0x93c00000 0x0 0x500000>;
81 mba_mem: memory@94100000 {
82 reg = <0x0 0x94100000 0x0 0x200000>;
86 slpi_mem: memory@94300000 {
87 reg = <0x0 0x94300000 0x0 0xf00000>;
91 ipa_fw_mem: memory@95200000 {
92 reg = <0x0 0x95200000 0x0 0x10000>;
96 ipa_gsi_mem: memory@95210000 {
97 reg = <0x0 0x95210000 0x0 0x5000>;
101 gpu_mem: memory@95600000 {
102 reg = <0x0 0x95600000 0x0 0x100000>;
106 wlan_msa_mem: memory@95700000 {
107 reg = <0x0 0x95700000 0x0 0x100000>;
114 compatible = "fixed-clock";
116 clock-frequency = <19200000>;
117 clock-output-names = "xo_board";
121 compatible = "fixed-clock";
123 clock-frequency = <32764>;
128 #address-cells = <2>;
133 compatible = "arm,armv8";
135 enable-method = "psci";
136 cpu-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
137 next-level-cache = <&L2_0>;
139 compatible = "arm,arch-cache";
143 compatible = "arm,arch-cache";
146 compatible = "arm,arch-cache";
152 compatible = "arm,armv8";
154 enable-method = "psci";
155 cpu-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
156 next-level-cache = <&L2_0>;
158 compatible = "arm,arch-cache";
161 compatible = "arm,arch-cache";
167 compatible = "arm,armv8";
169 enable-method = "psci";
170 cpu-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
171 next-level-cache = <&L2_0>;
173 compatible = "arm,arch-cache";
176 compatible = "arm,arch-cache";
182 compatible = "arm,armv8";
184 enable-method = "psci";
185 cpu-idle-states = <&LITTLE_CPU_SLEEP_0 &LITTLE_CPU_SLEEP_1>;
186 next-level-cache = <&L2_0>;
188 compatible = "arm,arch-cache";
191 compatible = "arm,arch-cache";
197 compatible = "arm,armv8";
199 enable-method = "psci";
200 cpu-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
201 next-level-cache = <&L2_1>;
203 compatible = "arm,arch-cache";
206 L1_I_100: l1-icache {
207 compatible = "arm,arch-cache";
209 L1_D_100: l1-dcache {
210 compatible = "arm,arch-cache";
216 compatible = "arm,armv8";
218 enable-method = "psci";
219 cpu-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
220 next-level-cache = <&L2_1>;
221 L1_I_101: l1-icache {
222 compatible = "arm,arch-cache";
224 L1_D_101: l1-dcache {
225 compatible = "arm,arch-cache";
231 compatible = "arm,armv8";
233 enable-method = "psci";
234 cpu-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
235 next-level-cache = <&L2_1>;
236 L1_I_102: l1-icache {
237 compatible = "arm,arch-cache";
239 L1_D_102: l1-dcache {
240 compatible = "arm,arch-cache";
246 compatible = "arm,armv8";
248 enable-method = "psci";
249 cpu-idle-states = <&BIG_CPU_SLEEP_0 &BIG_CPU_SLEEP_1>;
250 next-level-cache = <&L2_1>;
251 L1_I_103: l1-icache {
252 compatible = "arm,arch-cache";
254 L1_D_103: l1-dcache {
255 compatible = "arm,arch-cache";
298 entry-method = "psci";
300 LITTLE_CPU_SLEEP_0: cpu-sleep-0-0 {
301 compatible = "arm,idle-state";
302 idle-state-name = "little-retention";
303 arm,psci-suspend-param = <0x00000002>;
304 entry-latency-us = <81>;
305 exit-latency-us = <86>;
306 min-residency-us = <200>;
309 LITTLE_CPU_SLEEP_1: cpu-sleep-0-1 {
310 compatible = "arm,idle-state";
311 idle-state-name = "little-power-collapse";
312 arm,psci-suspend-param = <0x40000003>;
313 entry-latency-us = <273>;
314 exit-latency-us = <612>;
315 min-residency-us = <1000>;
319 BIG_CPU_SLEEP_0: cpu-sleep-1-0 {
320 compatible = "arm,idle-state";
321 idle-state-name = "big-retention";
322 arm,psci-suspend-param = <0x00000002>;
323 entry-latency-us = <79>;
324 exit-latency-us = <82>;
325 min-residency-us = <200>;
328 BIG_CPU_SLEEP_1: cpu-sleep-1-1 {
329 compatible = "arm,idle-state";
330 idle-state-name = "big-power-collapse";
331 arm,psci-suspend-param = <0x40000003>;
332 entry-latency-us = <336>;
333 exit-latency-us = <525>;
334 min-residency-us = <1000>;
342 compatible = "qcom,scm-msm8998", "qcom,scm";
347 compatible = "qcom,tcsr-mutex";
348 syscon = <&tcsr_mutex_regs 0 0x1000>;
353 compatible = "arm,psci-1.0";
358 compatible = "qcom,glink-rpm";
360 interrupts = <GIC_SPI 168 IRQ_TYPE_EDGE_RISING>;
361 qcom,rpm-msg-ram = <&rpm_msg_ram>;
362 mboxes = <&apcs_glb 0>;
364 rpm_requests: rpm-requests {
365 compatible = "qcom,rpm-msm8998";
366 qcom,glink-channels = "rpm_requests";
368 rpmcc: clock-controller {
369 compatible = "qcom,rpmcc-msm8998", "qcom,rpmcc";
373 rpmpd: power-controller {
374 compatible = "qcom,msm8998-rpmpd";
375 #power-domain-cells = <1>;
376 operating-points-v2 = <&rpmpd_opp_table>;
378 rpmpd_opp_table: opp-table {
379 compatible = "operating-points-v2";
381 rpmpd_opp_ret: opp1 {
385 rpmpd_opp_ret_plus: opp2 {
389 rpmpd_opp_min_svs: opp3 {
393 rpmpd_opp_low_svs: opp4 {
397 rpmpd_opp_svs: opp5 {
401 rpmpd_opp_svs_plus: opp6 {
405 rpmpd_opp_nom: opp7 {
409 rpmpd_opp_nom_plus: opp8 {
413 rpmpd_opp_turbo: opp9 {
417 rpmpd_opp_turbo_plus: opp10 {
426 compatible = "qcom,smem";
427 memory-region = <&smem_mem>;
428 hwlocks = <&tcsr_mutex 3>;
432 compatible = "qcom,smp2p";
433 qcom,smem = <443>, <429>;
435 interrupts = <GIC_SPI 158 IRQ_TYPE_EDGE_RISING>;
437 mboxes = <&apcs_glb 10>;
439 qcom,local-pid = <0>;
440 qcom,remote-pid = <2>;
442 adsp_smp2p_out: master-kernel {
443 qcom,entry-name = "master-kernel";
444 #qcom,smem-state-cells = <1>;
447 adsp_smp2p_in: slave-kernel {
448 qcom,entry-name = "slave-kernel";
450 interrupt-controller;
451 #interrupt-cells = <2>;
456 compatible = "qcom,smp2p";
457 qcom,smem = <435>, <428>;
458 interrupts = <GIC_SPI 451 IRQ_TYPE_EDGE_RISING>;
459 mboxes = <&apcs_glb 14>;
460 qcom,local-pid = <0>;
461 qcom,remote-pid = <1>;
463 modem_smp2p_out: master-kernel {
464 qcom,entry-name = "master-kernel";
465 #qcom,smem-state-cells = <1>;
468 modem_smp2p_in: slave-kernel {
469 qcom,entry-name = "slave-kernel";
470 interrupt-controller;
471 #interrupt-cells = <2>;
476 compatible = "qcom,smp2p";
477 qcom,smem = <481>, <430>;
478 interrupts = <GIC_SPI 178 IRQ_TYPE_EDGE_RISING>;
479 mboxes = <&apcs_glb 26>;
480 qcom,local-pid = <0>;
481 qcom,remote-pid = <3>;
483 slpi_smp2p_out: master-kernel {
484 qcom,entry-name = "master-kernel";
485 #qcom,smem-state-cells = <1>;
488 slpi_smp2p_in: slave-kernel {
489 qcom,entry-name = "slave-kernel";
490 interrupt-controller;
491 #interrupt-cells = <2>;
497 polling-delay-passive = <250>;
498 polling-delay = <1000>;
500 thermal-sensors = <&tsens0 1>;
503 cpu0_alert0: trip-point@0 {
504 temperature = <75000>;
509 cpu0_crit: cpu_crit {
510 temperature = <110000>;
518 polling-delay-passive = <250>;
519 polling-delay = <1000>;
521 thermal-sensors = <&tsens0 2>;
524 cpu1_alert0: trip-point@0 {
525 temperature = <75000>;
530 cpu1_crit: cpu_crit {
531 temperature = <110000>;
539 polling-delay-passive = <250>;
540 polling-delay = <1000>;
542 thermal-sensors = <&tsens0 3>;
545 cpu2_alert0: trip-point@0 {
546 temperature = <75000>;
551 cpu2_crit: cpu_crit {
552 temperature = <110000>;
560 polling-delay-passive = <250>;
561 polling-delay = <1000>;
563 thermal-sensors = <&tsens0 4>;
566 cpu3_alert0: trip-point@0 {
567 temperature = <75000>;
572 cpu3_crit: cpu_crit {
573 temperature = <110000>;
581 polling-delay-passive = <250>;
582 polling-delay = <1000>;
584 thermal-sensors = <&tsens0 7>;
587 cpu4_alert0: trip-point@0 {
588 temperature = <75000>;
593 cpu4_crit: cpu_crit {
594 temperature = <110000>;
602 polling-delay-passive = <250>;
603 polling-delay = <1000>;
605 thermal-sensors = <&tsens0 8>;
608 cpu5_alert0: trip-point@0 {
609 temperature = <75000>;
614 cpu5_crit: cpu_crit {
615 temperature = <110000>;
623 polling-delay-passive = <250>;
624 polling-delay = <1000>;
626 thermal-sensors = <&tsens0 9>;
629 cpu6_alert0: trip-point@0 {
630 temperature = <75000>;
635 cpu6_crit: cpu_crit {
636 temperature = <110000>;
644 polling-delay-passive = <250>;
645 polling-delay = <1000>;
647 thermal-sensors = <&tsens0 10>;
650 cpu7_alert0: trip-point@0 {
651 temperature = <75000>;
656 cpu7_crit: cpu_crit {
657 temperature = <110000>;
665 polling-delay-passive = <250>;
666 polling-delay = <1000>;
668 thermal-sensors = <&tsens0 12>;
671 gpu1_alert0: trip-point@0 {
672 temperature = <90000>;
680 polling-delay-passive = <250>;
681 polling-delay = <1000>;
683 thermal-sensors = <&tsens0 13>;
686 gpu2_alert0: trip-point@0 {
687 temperature = <90000>;
695 polling-delay-passive = <250>;
696 polling-delay = <1000>;
698 thermal-sensors = <&tsens0 5>;
701 cluster0_mhm_alert0: trip-point@0 {
702 temperature = <90000>;
710 polling-delay-passive = <250>;
711 polling-delay = <1000>;
713 thermal-sensors = <&tsens0 6>;
716 cluster1_mhm_alert0: trip-point@0 {
717 temperature = <90000>;
724 cluster1-l2-thermal {
725 polling-delay-passive = <250>;
726 polling-delay = <1000>;
728 thermal-sensors = <&tsens0 11>;
731 cluster1_l2_alert0: trip-point@0 {
732 temperature = <90000>;
740 polling-delay-passive = <250>;
741 polling-delay = <1000>;
743 thermal-sensors = <&tsens1 1>;
746 modem_alert0: trip-point@0 {
747 temperature = <90000>;
755 polling-delay-passive = <250>;
756 polling-delay = <1000>;
758 thermal-sensors = <&tsens1 2>;
761 mem_alert0: trip-point@0 {
762 temperature = <90000>;
770 polling-delay-passive = <250>;
771 polling-delay = <1000>;
773 thermal-sensors = <&tsens1 3>;
776 wlan_alert0: trip-point@0 {
777 temperature = <90000>;
785 polling-delay-passive = <250>;
786 polling-delay = <1000>;
788 thermal-sensors = <&tsens1 4>;
791 q6_dsp_alert0: trip-point@0 {
792 temperature = <90000>;
800 polling-delay-passive = <250>;
801 polling-delay = <1000>;
803 thermal-sensors = <&tsens1 5>;
806 camera_alert0: trip-point@0 {
807 temperature = <90000>;
815 polling-delay-passive = <250>;
816 polling-delay = <1000>;
818 thermal-sensors = <&tsens1 6>;
821 multimedia_alert0: trip-point@0 {
822 temperature = <90000>;
831 compatible = "arm,armv8-timer";
832 interrupts = <GIC_PPI 1 IRQ_TYPE_LEVEL_LOW>,
833 <GIC_PPI 2 IRQ_TYPE_LEVEL_LOW>,
834 <GIC_PPI 3 IRQ_TYPE_LEVEL_LOW>,
835 <GIC_PPI 0 IRQ_TYPE_LEVEL_LOW>;
839 #address-cells = <1>;
841 ranges = <0 0 0 0xffffffff>;
842 compatible = "simple-bus";
844 gcc: clock-controller@100000 {
845 compatible = "qcom,gcc-msm8998";
848 #power-domain-cells = <1>;
849 reg = <0x00100000 0xb0000>;
852 rpm_msg_ram: memory@778000 {
853 compatible = "qcom,rpm-msg-ram";
854 reg = <0x00778000 0x7000>;
857 qfprom: qfprom@780000 {
858 compatible = "qcom,qfprom";
859 reg = <0x00780000 0x621c>;
860 #address-cells = <1>;
863 qusb2_hstx_trim: hstx-trim@423a {
869 tsens0: thermal@10ab000 {
870 compatible = "qcom,msm8998-tsens", "qcom,tsens-v2";
871 reg = <0x010ab000 0x1000>, /* TM */
872 <0x010aa000 0x1000>; /* SROT */
873 #qcom,sensors = <14>;
874 interrupts = <GIC_SPI 458 IRQ_TYPE_LEVEL_HIGH>,
875 <GIC_SPI 445 IRQ_TYPE_LEVEL_HIGH>;
876 interrupt-names = "uplow", "critical";
877 #thermal-sensor-cells = <1>;
880 tsens1: thermal@10ae000 {
881 compatible = "qcom,msm8998-tsens", "qcom,tsens-v2";
882 reg = <0x010ae000 0x1000>, /* TM */
883 <0x010ad000 0x1000>; /* SROT */
885 interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>,
886 <GIC_SPI 430 IRQ_TYPE_LEVEL_HIGH>;
887 interrupt-names = "uplow", "critical";
888 #thermal-sensor-cells = <1>;
891 anoc1_smmu: iommu@1680000 {
892 compatible = "qcom,msm8998-smmu-v2", "qcom,smmu-v2";
893 reg = <0x01680000 0x10000>;
896 #global-interrupts = <0>;
898 <GIC_SPI 364 IRQ_TYPE_EDGE_RISING>,
899 <GIC_SPI 365 IRQ_TYPE_EDGE_RISING>,
900 <GIC_SPI 366 IRQ_TYPE_EDGE_RISING>,
901 <GIC_SPI 367 IRQ_TYPE_EDGE_RISING>,
902 <GIC_SPI 368 IRQ_TYPE_EDGE_RISING>,
903 <GIC_SPI 369 IRQ_TYPE_EDGE_RISING>;
906 anoc2_smmu: iommu@16c0000 {
907 compatible = "qcom,msm8998-smmu-v2", "qcom,smmu-v2";
908 reg = <0x016c0000 0x40000>;
911 #global-interrupts = <0>;
913 <GIC_SPI 373 IRQ_TYPE_EDGE_RISING>,
914 <GIC_SPI 374 IRQ_TYPE_EDGE_RISING>,
915 <GIC_SPI 375 IRQ_TYPE_EDGE_RISING>,
916 <GIC_SPI 376 IRQ_TYPE_EDGE_RISING>,
917 <GIC_SPI 377 IRQ_TYPE_EDGE_RISING>,
918 <GIC_SPI 378 IRQ_TYPE_EDGE_RISING>,
919 <GIC_SPI 462 IRQ_TYPE_EDGE_RISING>,
920 <GIC_SPI 463 IRQ_TYPE_EDGE_RISING>,
921 <GIC_SPI 464 IRQ_TYPE_EDGE_RISING>,
922 <GIC_SPI 465 IRQ_TYPE_EDGE_RISING>;
926 compatible = "qcom,pcie-msm8996";
927 reg = <0x01c00000 0x2000>,
930 <0x1b100000 0x100000>;
931 reg-names = "parf", "dbi", "elbi", "config";
933 linux,pci-domain = <0>;
934 bus-range = <0x00 0xff>;
935 #address-cells = <3>;
939 phy-names = "pciephy";
941 ranges = <0x01000000 0x0 0x1b200000 0x1b200000 0x0 0x100000>,
942 <0x02000000 0x0 0x1b300000 0x1b300000 0x0 0xd00000>;
944 #interrupt-cells = <1>;
945 interrupts = <GIC_SPI 405 IRQ_TYPE_LEVEL_HIGH>;
946 interrupt-names = "msi";
947 interrupt-map-mask = <0 0 0 0x7>;
948 interrupt-map = <0 0 0 1 &intc 0 135 IRQ_TYPE_LEVEL_HIGH>,
949 <0 0 0 2 &intc 0 136 IRQ_TYPE_LEVEL_HIGH>,
950 <0 0 0 3 &intc 0 138 IRQ_TYPE_LEVEL_HIGH>,
951 <0 0 0 4 &intc 0 139 IRQ_TYPE_LEVEL_HIGH>;
953 clocks = <&gcc GCC_PCIE_0_PIPE_CLK>,
954 <&gcc GCC_PCIE_0_MSTR_AXI_CLK>,
955 <&gcc GCC_PCIE_0_SLV_AXI_CLK>,
956 <&gcc GCC_PCIE_0_CFG_AHB_CLK>,
957 <&gcc GCC_PCIE_0_AUX_CLK>;
958 clock-names = "pipe", "bus_master", "bus_slave", "cfg", "aux";
960 power-domains = <&gcc PCIE_0_GDSC>;
961 iommu-map = <0x100 &anoc1_smmu 0x1480 1>;
962 perst-gpios = <&tlmm 35 GPIO_ACTIVE_LOW>;
966 compatible = "qcom,msm8998-qmp-pcie-phy";
967 reg = <0x01c06000 0x18c>;
968 #address-cells = <1>;
972 clocks = <&gcc GCC_PCIE_PHY_AUX_CLK>,
973 <&gcc GCC_PCIE_0_CFG_AHB_CLK>,
974 <&gcc GCC_PCIE_CLKREF_CLK>;
975 clock-names = "aux", "cfg_ahb", "ref";
977 resets = <&gcc GCC_PCIE_0_PHY_BCR>, <&gcc GCC_PCIE_PHY_BCR>;
978 reset-names = "phy", "common";
980 vdda-phy-supply = <&vreg_l1a_0p875>;
981 vdda-pll-supply = <&vreg_l2a_1p2>;
983 pciephy: lane@1c06800 {
984 reg = <0x01c06200 0x128>, <0x01c06400 0x1fc>, <0x01c06800 0x20c>;
987 clocks = <&gcc GCC_PCIE_0_PIPE_CLK>;
988 clock-names = "pipe0";
989 clock-output-names = "pcie_0_pipe_clk_src";
994 ufshc: ufshc@1da4000 {
995 compatible = "qcom,msm8998-ufshc", "qcom,ufshc", "jedec,ufs-2.0";
996 reg = <0x01da4000 0x2500>;
997 interrupts = <GIC_SPI 265 IRQ_TYPE_LEVEL_HIGH>;
998 phys = <&ufsphy_lanes>;
999 phy-names = "ufsphy";
1000 lanes-per-direction = <2>;
1001 power-domains = <&gcc UFS_GDSC>;
1010 "tx_lane0_sync_clk",
1011 "rx_lane0_sync_clk",
1012 "rx_lane1_sync_clk";
1014 <&gcc GCC_UFS_AXI_CLK>,
1015 <&gcc GCC_AGGRE1_UFS_AXI_CLK>,
1016 <&gcc GCC_UFS_AHB_CLK>,
1017 <&gcc GCC_UFS_UNIPRO_CORE_CLK>,
1018 <&rpmcc RPM_SMD_LN_BB_CLK1>,
1019 <&gcc GCC_UFS_TX_SYMBOL_0_CLK>,
1020 <&gcc GCC_UFS_RX_SYMBOL_0_CLK>,
1021 <&gcc GCC_UFS_RX_SYMBOL_1_CLK>;
1023 <50000000 200000000>,
1026 <37500000 150000000>,
1032 resets = <&gcc GCC_UFS_BCR>;
1033 reset-names = "rst";
1036 ufsphy: phy@1da7000 {
1037 compatible = "qcom,msm8998-qmp-ufs-phy";
1038 reg = <0x01da7000 0x18c>;
1039 #address-cells = <1>;
1047 <&gcc GCC_UFS_CLKREF_CLK>,
1048 <&gcc GCC_UFS_PHY_AUX_CLK>;
1050 reset-names = "ufsphy";
1051 resets = <&ufshc 0>;
1053 ufsphy_lanes: lanes@1da7400 {
1054 reg = <0x01da7400 0x128>,
1063 tcsr_mutex_regs: syscon@1f40000 {
1064 compatible = "syscon";
1065 reg = <0x01f40000 0x40000>;
1068 tlmm: pinctrl@3400000 {
1069 compatible = "qcom,msm8998-pinctrl";
1070 reg = <0x03400000 0xc00000>;
1071 interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>;
1073 #gpio-cells = <0x2>;
1074 interrupt-controller;
1075 #interrupt-cells = <0x2>;
1078 remoteproc_mss: remoteproc@4080000 {
1079 compatible = "qcom,msm8998-mss-pil";
1080 reg = <0x04080000 0x100>, <0x04180000 0x20>;
1081 reg-names = "qdsp6", "rmb";
1083 interrupts-extended =
1084 <&intc GIC_SPI 448 IRQ_TYPE_EDGE_RISING>,
1085 <&modem_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
1086 <&modem_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
1087 <&modem_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
1088 <&modem_smp2p_in 3 IRQ_TYPE_EDGE_RISING>,
1089 <&modem_smp2p_in 7 IRQ_TYPE_EDGE_RISING>;
1090 interrupt-names = "wdog", "fatal", "ready",
1091 "handover", "stop-ack",
1094 clocks = <&gcc GCC_MSS_CFG_AHB_CLK>,
1095 <&gcc GCC_BIMC_MSS_Q6_AXI_CLK>,
1096 <&gcc GCC_BOOT_ROM_AHB_CLK>,
1097 <&gcc GCC_MSS_GPLL0_DIV_CLK_SRC>,
1098 <&gcc GCC_MSS_SNOC_AXI_CLK>,
1099 <&gcc GCC_MSS_MNOC_BIMC_AXI_CLK>,
1100 <&rpmcc RPM_SMD_QDSS_CLK>,
1101 <&rpmcc RPM_SMD_XO_CLK_SRC>;
1102 clock-names = "iface", "bus", "mem", "gpll0_mss",
1103 "snoc_axi", "mnoc_axi", "qdss", "xo";
1105 qcom,smem-states = <&modem_smp2p_out 0>;
1106 qcom,smem-state-names = "stop";
1108 resets = <&gcc GCC_MSS_RESTART>;
1109 reset-names = "mss_restart";
1111 qcom,halt-regs = <&tcsr_mutex_regs 0x23000 0x25000 0x24000>;
1113 power-domains = <&rpmpd MSM8998_VDDCX>,
1114 <&rpmpd MSM8998_VDDMX>;
1115 power-domain-names = "cx", "mx";
1118 memory-region = <&mba_mem>;
1122 memory-region = <&mpss_mem>;
1126 interrupts = <GIC_SPI 452 IRQ_TYPE_EDGE_RISING>;
1128 qcom,remote-pid = <1>;
1129 mboxes = <&apcs_glb 15>;
1133 gpucc: clock-controller@5065000 {
1134 compatible = "qcom,msm8998-gpucc";
1137 #power-domain-cells = <1>;
1138 reg = <0x05065000 0x9000>;
1140 clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>,
1141 <&gcc GPLL0_OUT_MAIN>;
1146 remoteproc_slpi: remoteproc@5800000 {
1147 compatible = "qcom,msm8998-slpi-pas";
1148 reg = <0x05800000 0x4040>;
1150 interrupts-extended = <&intc GIC_SPI 390 IRQ_TYPE_EDGE_RISING>,
1151 <&slpi_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
1152 <&slpi_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
1153 <&slpi_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
1154 <&slpi_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
1155 interrupt-names = "wdog", "fatal", "ready",
1156 "handover", "stop-ack";
1158 px-supply = <&vreg_lvs2a_1p8>;
1160 clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>,
1161 <&rpmcc RPM_SMD_AGGR2_NOC_CLK>;
1162 clock-names = "xo", "aggre2";
1164 memory-region = <&slpi_mem>;
1166 qcom,smem-states = <&slpi_smp2p_out 0>;
1167 qcom,smem-state-names = "stop";
1169 power-domains = <&rpmpd MSM8998_SSCCX>;
1170 power-domain-names = "ssc_cx";
1172 status = "disabled";
1175 interrupts = <GIC_SPI 179 IRQ_TYPE_EDGE_RISING>;
1177 qcom,remote-pid = <3>;
1178 mboxes = <&apcs_glb 27>;
1183 compatible = "arm,coresight-stm", "arm,primecell";
1184 reg = <0x06002000 0x1000>,
1185 <0x16280000 0x180000>;
1186 reg-names = "stm-base", "stm-data-base";
1187 status = "disabled";
1189 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1190 clock-names = "apb_pclk", "atclk";
1195 remote-endpoint = <&funnel0_in7>;
1201 funnel1: funnel@6041000 {
1202 compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1203 reg = <0x06041000 0x1000>;
1204 status = "disabled";
1206 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1207 clock-names = "apb_pclk", "atclk";
1211 funnel0_out: endpoint {
1213 <&merge_funnel_in0>;
1219 #address-cells = <1>;
1224 funnel0_in7: endpoint {
1225 remote-endpoint = <&stm_out>;
1231 funnel2: funnel@6042000 {
1232 compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1233 reg = <0x06042000 0x1000>;
1234 status = "disabled";
1236 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1237 clock-names = "apb_pclk", "atclk";
1241 funnel1_out: endpoint {
1243 <&merge_funnel_in1>;
1249 #address-cells = <1>;
1254 funnel1_in6: endpoint {
1256 <&apss_merge_funnel_out>;
1262 funnel3: funnel@6045000 {
1263 compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1264 reg = <0x06045000 0x1000>;
1265 status = "disabled";
1267 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1268 clock-names = "apb_pclk", "atclk";
1272 merge_funnel_out: endpoint {
1280 #address-cells = <1>;
1285 merge_funnel_in0: endpoint {
1293 merge_funnel_in1: endpoint {
1301 replicator1: replicator@6046000 {
1302 compatible = "arm,coresight-dynamic-replicator", "arm,primecell";
1303 reg = <0x06046000 0x1000>;
1304 status = "disabled";
1306 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1307 clock-names = "apb_pclk", "atclk";
1311 replicator_out: endpoint {
1312 remote-endpoint = <&etr_in>;
1319 replicator_in: endpoint {
1320 remote-endpoint = <&etf_out>;
1327 compatible = "arm,coresight-tmc", "arm,primecell";
1328 reg = <0x06047000 0x1000>;
1329 status = "disabled";
1331 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1332 clock-names = "apb_pclk", "atclk";
1347 <&merge_funnel_out>;
1354 compatible = "arm,coresight-tmc", "arm,primecell";
1355 reg = <0x06048000 0x1000>;
1356 status = "disabled";
1358 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1359 clock-names = "apb_pclk", "atclk";
1373 compatible = "arm,coresight-etm4x", "arm,primecell";
1374 reg = <0x07840000 0x1000>;
1375 status = "disabled";
1377 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1378 clock-names = "apb_pclk", "atclk";
1384 etm0_out: endpoint {
1393 compatible = "arm,coresight-etm4x", "arm,primecell";
1394 reg = <0x07940000 0x1000>;
1395 status = "disabled";
1397 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1398 clock-names = "apb_pclk", "atclk";
1404 etm1_out: endpoint {
1413 compatible = "arm,coresight-etm4x", "arm,primecell";
1414 reg = <0x07a40000 0x1000>;
1415 status = "disabled";
1417 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1418 clock-names = "apb_pclk", "atclk";
1424 etm2_out: endpoint {
1433 compatible = "arm,coresight-etm4x", "arm,primecell";
1434 reg = <0x07b40000 0x1000>;
1435 status = "disabled";
1437 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1438 clock-names = "apb_pclk", "atclk";
1444 etm3_out: endpoint {
1452 funnel4: funnel@7b60000 { /* APSS Funnel */
1453 compatible = "arm,coresight-etm4x", "arm,primecell";
1454 reg = <0x07b60000 0x1000>;
1455 status = "disabled";
1457 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1458 clock-names = "apb_pclk", "atclk";
1462 apss_funnel_out: endpoint {
1464 <&apss_merge_funnel_in>;
1470 #address-cells = <1>;
1475 apss_funnel_in0: endpoint {
1483 apss_funnel_in1: endpoint {
1491 apss_funnel_in2: endpoint {
1499 apss_funnel_in3: endpoint {
1507 apss_funnel_in4: endpoint {
1515 apss_funnel_in5: endpoint {
1523 apss_funnel_in6: endpoint {
1531 apss_funnel_in7: endpoint {
1539 funnel5: funnel@7b70000 {
1540 compatible = "arm,coresight-dynamic-funnel", "arm,primecell";
1541 reg = <0x07b70000 0x1000>;
1542 status = "disabled";
1544 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1545 clock-names = "apb_pclk", "atclk";
1549 apss_merge_funnel_out: endpoint {
1558 apss_merge_funnel_in: endpoint {
1567 compatible = "arm,coresight-etm4x", "arm,primecell";
1568 reg = <0x07c40000 0x1000>;
1569 status = "disabled";
1571 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1572 clock-names = "apb_pclk", "atclk";
1577 etm4_out: endpoint {
1578 remote-endpoint = <&apss_funnel_in4>;
1584 compatible = "arm,coresight-etm4x", "arm,primecell";
1585 reg = <0x07d40000 0x1000>;
1586 status = "disabled";
1588 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1589 clock-names = "apb_pclk", "atclk";
1594 etm5_out: endpoint {
1595 remote-endpoint = <&apss_funnel_in5>;
1601 compatible = "arm,coresight-etm4x", "arm,primecell";
1602 reg = <0x07e40000 0x1000>;
1603 status = "disabled";
1605 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1606 clock-names = "apb_pclk", "atclk";
1611 etm6_out: endpoint {
1612 remote-endpoint = <&apss_funnel_in6>;
1618 compatible = "arm,coresight-etm4x", "arm,primecell";
1619 reg = <0x07f40000 0x1000>;
1620 status = "disabled";
1622 clocks = <&rpmcc RPM_SMD_QDSS_CLK>, <&rpmcc RPM_SMD_QDSS_A_CLK>;
1623 clock-names = "apb_pclk", "atclk";
1628 etm7_out: endpoint {
1629 remote-endpoint = <&apss_funnel_in7>;
1634 spmi_bus: spmi@800f000 {
1635 compatible = "qcom,spmi-pmic-arb";
1636 reg = <0x0800f000 0x1000>,
1637 <0x08400000 0x1000000>,
1638 <0x09400000 0x1000000>,
1639 <0x0a400000 0x220000>,
1640 <0x0800a000 0x3000>;
1641 reg-names = "core", "chnls", "obsrvr", "intr", "cnfg";
1642 interrupt-names = "periph_irq";
1643 interrupts = <GIC_SPI 326 IRQ_TYPE_LEVEL_HIGH>;
1646 #address-cells = <2>;
1648 interrupt-controller;
1649 #interrupt-cells = <4>;
1654 compatible = "qcom,msm8998-dwc3", "qcom,dwc3";
1655 reg = <0x0a8f8800 0x400>;
1656 status = "disabled";
1657 #address-cells = <1>;
1661 clocks = <&gcc GCC_CFG_NOC_USB3_AXI_CLK>,
1662 <&gcc GCC_USB30_MASTER_CLK>,
1663 <&gcc GCC_AGGRE1_USB3_AXI_CLK>,
1664 <&gcc GCC_USB30_MOCK_UTMI_CLK>,
1665 <&gcc GCC_USB30_SLEEP_CLK>;
1666 clock-names = "cfg_noc", "core", "iface", "mock_utmi",
1669 assigned-clocks = <&gcc GCC_USB30_MOCK_UTMI_CLK>,
1670 <&gcc GCC_USB30_MASTER_CLK>;
1671 assigned-clock-rates = <19200000>, <120000000>;
1673 interrupts = <GIC_SPI 347 IRQ_TYPE_LEVEL_HIGH>,
1674 <GIC_SPI 243 IRQ_TYPE_LEVEL_HIGH>;
1675 interrupt-names = "hs_phy_irq", "ss_phy_irq";
1677 power-domains = <&gcc USB_30_GDSC>;
1679 resets = <&gcc GCC_USB_30_BCR>;
1681 usb3_dwc3: dwc3@a800000 {
1682 compatible = "snps,dwc3";
1683 reg = <0x0a800000 0xcd00>;
1684 interrupts = <GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>;
1685 snps,dis_u2_susphy_quirk;
1686 snps,dis_enblslpm_quirk;
1687 phys = <&qusb2phy>, <&usb1_ssphy>;
1688 phy-names = "usb2-phy", "usb3-phy";
1689 snps,has-lpm-erratum;
1690 snps,hird-threshold = /bits/ 8 <0x10>;
1694 usb3phy: phy@c010000 {
1695 compatible = "qcom,msm8998-qmp-usb3-phy";
1696 reg = <0x0c010000 0x18c>;
1697 status = "disabled";
1699 #address-cells = <1>;
1703 clocks = <&gcc GCC_USB3_PHY_AUX_CLK>,
1704 <&gcc GCC_USB_PHY_CFG_AHB2PHY_CLK>,
1705 <&gcc GCC_USB3_CLKREF_CLK>;
1706 clock-names = "aux", "cfg_ahb", "ref";
1708 resets = <&gcc GCC_USB3_PHY_BCR>,
1709 <&gcc GCC_USB3PHY_PHY_BCR>;
1710 reset-names = "phy", "common";
1712 usb1_ssphy: lane@c010200 {
1713 reg = <0xc010200 0x128>,
1719 clocks = <&gcc GCC_USB3_PHY_PIPE_CLK>;
1720 clock-names = "pipe0";
1721 clock-output-names = "usb3_phy_pipe_clk_src";
1725 qusb2phy: phy@c012000 {
1726 compatible = "qcom,msm8998-qusb2-phy";
1727 reg = <0x0c012000 0x2a8>;
1728 status = "disabled";
1731 clocks = <&gcc GCC_USB_PHY_CFG_AHB2PHY_CLK>,
1732 <&gcc GCC_RX1_USB2_CLKREF_CLK>;
1733 clock-names = "cfg_ahb", "ref";
1735 resets = <&gcc GCC_QUSB2PHY_PRIM_BCR>;
1737 nvmem-cells = <&qusb2_hstx_trim>;
1740 sdhc2: sdhci@c0a4900 {
1741 compatible = "qcom,sdhci-msm-v4";
1742 reg = <0x0c0a4900 0x314>, <0x0c0a4000 0x800>;
1743 reg-names = "hc_mem", "core_mem";
1745 interrupts = <GIC_SPI 125 IRQ_TYPE_LEVEL_HIGH>,
1746 <GIC_SPI 221 IRQ_TYPE_LEVEL_HIGH>;
1747 interrupt-names = "hc_irq", "pwr_irq";
1749 clock-names = "iface", "core", "xo";
1750 clocks = <&gcc GCC_SDCC2_AHB_CLK>,
1751 <&gcc GCC_SDCC2_APPS_CLK>,
1754 status = "disabled";
1757 blsp1_dma: dma@c144000 {
1758 compatible = "qcom,bam-v1.7.0";
1759 reg = <0x0c144000 0x25000>;
1760 interrupts = <GIC_SPI 238 IRQ_TYPE_LEVEL_HIGH>;
1761 clocks = <&gcc GCC_BLSP1_AHB_CLK>;
1762 clock-names = "bam_clk";
1765 qcom,controlled-remotely;
1766 num-channels = <18>;
1770 blsp1_uart3: serial@c171000 {
1771 compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm";
1772 reg = <0x0c171000 0x1000>;
1773 interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
1774 clocks = <&gcc GCC_BLSP1_UART3_APPS_CLK>,
1775 <&gcc GCC_BLSP1_AHB_CLK>;
1776 clock-names = "core", "iface";
1777 dmas = <&blsp1_dma 4>, <&blsp1_dma 5>;
1778 dma-names = "tx", "rx";
1779 pinctrl-names = "default";
1780 pinctrl-0 = <&blsp1_uart3_on>;
1781 status = "disabled";
1784 blsp1_i2c1: i2c@c175000 {
1785 compatible = "qcom,i2c-qup-v2.2.1";
1786 reg = <0x0c175000 0x600>;
1787 interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>;
1789 clocks = <&gcc GCC_BLSP1_QUP1_I2C_APPS_CLK>,
1790 <&gcc GCC_BLSP1_AHB_CLK>;
1791 clock-names = "core", "iface";
1792 clock-frequency = <400000>;
1794 status = "disabled";
1795 #address-cells = <1>;
1799 blsp1_i2c2: i2c@c176000 {
1800 compatible = "qcom,i2c-qup-v2.2.1";
1801 reg = <0x0c176000 0x600>;
1802 interrupts = <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>;
1804 clocks = <&gcc GCC_BLSP1_QUP2_I2C_APPS_CLK>,
1805 <&gcc GCC_BLSP1_AHB_CLK>;
1806 clock-names = "core", "iface";
1807 clock-frequency = <400000>;
1809 status = "disabled";
1810 #address-cells = <1>;
1814 blsp1_i2c3: i2c@c177000 {
1815 compatible = "qcom,i2c-qup-v2.2.1";
1816 reg = <0x0c177000 0x600>;
1817 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>;
1819 clocks = <&gcc GCC_BLSP1_QUP3_I2C_APPS_CLK>,
1820 <&gcc GCC_BLSP1_AHB_CLK>;
1821 clock-names = "core", "iface";
1822 clock-frequency = <400000>;
1824 status = "disabled";
1825 #address-cells = <1>;
1829 blsp1_i2c4: i2c@c178000 {
1830 compatible = "qcom,i2c-qup-v2.2.1";
1831 reg = <0x0c178000 0x600>;
1832 interrupts = <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>;
1834 clocks = <&gcc GCC_BLSP1_QUP4_I2C_APPS_CLK>,
1835 <&gcc GCC_BLSP1_AHB_CLK>;
1836 clock-names = "core", "iface";
1837 clock-frequency = <400000>;
1839 status = "disabled";
1840 #address-cells = <1>;
1844 blsp1_i2c5: i2c@c179000 {
1845 compatible = "qcom,i2c-qup-v2.2.1";
1846 reg = <0x0c179000 0x600>;
1847 interrupts = <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>;
1849 clocks = <&gcc GCC_BLSP1_QUP5_I2C_APPS_CLK>,
1850 <&gcc GCC_BLSP1_AHB_CLK>;
1851 clock-names = "core", "iface";
1852 clock-frequency = <400000>;
1854 status = "disabled";
1855 #address-cells = <1>;
1859 blsp1_i2c6: i2c@c17a000 {
1860 compatible = "qcom,i2c-qup-v2.2.1";
1861 reg = <0x0c17a000 0x600>;
1862 interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
1864 clocks = <&gcc GCC_BLSP1_QUP6_I2C_APPS_CLK>,
1865 <&gcc GCC_BLSP1_AHB_CLK>;
1866 clock-names = "core", "iface";
1867 clock-frequency = <400000>;
1869 status = "disabled";
1870 #address-cells = <1>;
1874 blsp2_uart1: serial@c1b0000 {
1875 compatible = "qcom,msm-uartdm-v1.4", "qcom,msm-uartdm";
1876 reg = <0x0c1b0000 0x1000>;
1877 interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>;
1878 clocks = <&gcc GCC_BLSP2_UART2_APPS_CLK>,
1879 <&gcc GCC_BLSP2_AHB_CLK>;
1880 clock-names = "core", "iface";
1881 status = "disabled";
1884 blsp2_i2c0: i2c@c1b5000 {
1885 compatible = "qcom,i2c-qup-v2.2.1";
1886 reg = <0x0c1b5000 0x600>;
1887 interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
1889 clocks = <&gcc GCC_BLSP2_QUP1_I2C_APPS_CLK>,
1890 <&gcc GCC_BLSP2_AHB_CLK>;
1891 clock-names = "core", "iface";
1892 clock-frequency = <400000>;
1894 status = "disabled";
1895 #address-cells = <1>;
1899 blsp2_i2c1: i2c@c1b6000 {
1900 compatible = "qcom,i2c-qup-v2.2.1";
1901 reg = <0x0c1b6000 0x600>;
1902 interrupts = <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
1904 clocks = <&gcc GCC_BLSP2_QUP2_I2C_APPS_CLK>,
1905 <&gcc GCC_BLSP2_AHB_CLK>;
1906 clock-names = "core", "iface";
1907 clock-frequency = <400000>;
1909 status = "disabled";
1910 #address-cells = <1>;
1914 blsp2_i2c2: i2c@c1b7000 {
1915 compatible = "qcom,i2c-qup-v2.2.1";
1916 reg = <0x0c1b7000 0x600>;
1917 interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
1919 clocks = <&gcc GCC_BLSP2_QUP3_I2C_APPS_CLK>,
1920 <&gcc GCC_BLSP2_AHB_CLK>;
1921 clock-names = "core", "iface";
1922 clock-frequency = <400000>;
1924 status = "disabled";
1925 #address-cells = <1>;
1929 blsp2_i2c3: i2c@c1b8000 {
1930 compatible = "qcom,i2c-qup-v2.2.1";
1931 reg = <0x0c1b8000 0x600>;
1932 interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>;
1934 clocks = <&gcc GCC_BLSP2_QUP4_I2C_APPS_CLK>,
1935 <&gcc GCC_BLSP2_AHB_CLK>;
1936 clock-names = "core", "iface";
1937 clock-frequency = <400000>;
1939 status = "disabled";
1940 #address-cells = <1>;
1944 blsp2_i2c4: i2c@c1b9000 {
1945 compatible = "qcom,i2c-qup-v2.2.1";
1946 reg = <0x0c1b9000 0x600>;
1947 interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
1949 clocks = <&gcc GCC_BLSP2_QUP5_I2C_APPS_CLK>,
1950 <&gcc GCC_BLSP2_AHB_CLK>;
1951 clock-names = "core", "iface";
1952 clock-frequency = <400000>;
1954 status = "disabled";
1955 #address-cells = <1>;
1959 blsp2_i2c5: i2c@c1ba000 {
1960 compatible = "qcom,i2c-qup-v2.2.1";
1961 reg = <0x0c1ba000 0x600>;
1962 interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
1964 clocks = <&gcc GCC_BLSP2_QUP6_I2C_APPS_CLK>,
1965 <&gcc GCC_BLSP2_AHB_CLK>;
1966 clock-names = "core", "iface";
1967 clock-frequency = <400000>;
1969 status = "disabled";
1970 #address-cells = <1>;
1974 remoteproc_adsp: remoteproc@17300000 {
1975 compatible = "qcom,msm8998-adsp-pas";
1976 reg = <0x17300000 0x4040>;
1978 interrupts-extended = <&intc GIC_SPI 162 IRQ_TYPE_EDGE_RISING>,
1979 <&adsp_smp2p_in 0 IRQ_TYPE_EDGE_RISING>,
1980 <&adsp_smp2p_in 1 IRQ_TYPE_EDGE_RISING>,
1981 <&adsp_smp2p_in 2 IRQ_TYPE_EDGE_RISING>,
1982 <&adsp_smp2p_in 3 IRQ_TYPE_EDGE_RISING>;
1983 interrupt-names = "wdog", "fatal", "ready",
1984 "handover", "stop-ack";
1986 clocks = <&rpmcc RPM_SMD_XO_CLK_SRC>;
1989 memory-region = <&adsp_mem>;
1991 qcom,smem-states = <&adsp_smp2p_out 0>;
1992 qcom,smem-state-names = "stop";
1994 power-domains = <&rpmpd MSM8998_VDDCX>;
1995 power-domain-names = "cx";
1997 status = "disabled";
2000 interrupts = <GIC_SPI 157 IRQ_TYPE_EDGE_RISING>;
2002 qcom,remote-pid = <2>;
2003 mboxes = <&apcs_glb 9>;
2007 apcs_glb: mailbox@17911000 {
2008 compatible = "qcom,msm8998-apcs-hmss-global";
2009 reg = <0x17911000 0x1000>;
2015 #address-cells = <1>;
2018 compatible = "arm,armv7-timer-mem";
2019 reg = <0x17920000 0x1000>;
2023 interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>,
2024 <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
2025 reg = <0x17921000 0x1000>,
2026 <0x17922000 0x1000>;
2031 interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
2032 reg = <0x17923000 0x1000>;
2033 status = "disabled";
2038 interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
2039 reg = <0x17924000 0x1000>;
2040 status = "disabled";
2045 interrupts = <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
2046 reg = <0x17925000 0x1000>;
2047 status = "disabled";
2052 interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
2053 reg = <0x17926000 0x1000>;
2054 status = "disabled";
2059 interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
2060 reg = <0x17927000 0x1000>;
2061 status = "disabled";
2066 interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
2067 reg = <0x17928000 0x1000>;
2068 status = "disabled";
2072 intc: interrupt-controller@17a00000 {
2073 compatible = "arm,gic-v3";
2074 reg = <0x17a00000 0x10000>, /* GICD */
2075 <0x17b00000 0x100000>; /* GICR * 8 */
2076 #interrupt-cells = <3>;
2077 #address-cells = <1>;
2080 interrupt-controller;
2081 #redistributor-regions = <1>;
2082 redistributor-stride = <0x0 0x20000>;
2083 interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
2086 wifi: wifi@18800000 {
2087 compatible = "qcom,wcn3990-wifi";
2088 status = "disabled";
2089 reg = <0x18800000 0x800000>;
2090 reg-names = "membase";
2091 memory-region = <&wlan_msa_mem>;
2092 clocks = <&rpmcc RPM_SMD_RF_CLK2_PIN>;
2093 clock-names = "cxo_ref_clk_pin";
2095 <GIC_SPI 413 IRQ_TYPE_LEVEL_HIGH>,
2096 <GIC_SPI 414 IRQ_TYPE_LEVEL_HIGH>,
2097 <GIC_SPI 415 IRQ_TYPE_LEVEL_HIGH>,
2098 <GIC_SPI 416 IRQ_TYPE_LEVEL_HIGH>,
2099 <GIC_SPI 417 IRQ_TYPE_LEVEL_HIGH>,
2100 <GIC_SPI 418 IRQ_TYPE_LEVEL_HIGH>,
2101 <GIC_SPI 420 IRQ_TYPE_LEVEL_HIGH>,
2102 <GIC_SPI 421 IRQ_TYPE_LEVEL_HIGH>,
2103 <GIC_SPI 422 IRQ_TYPE_LEVEL_HIGH>,
2104 <GIC_SPI 423 IRQ_TYPE_LEVEL_HIGH>,
2105 <GIC_SPI 424 IRQ_TYPE_LEVEL_HIGH>,
2106 <GIC_SPI 425 IRQ_TYPE_LEVEL_HIGH>;
2107 iommus = <&anoc2_smmu 0x1900>,
2108 <&anoc2_smmu 0x1901>;
2109 qcom,snoc-host-cap-8bit-quirk;
2114 #include "msm8998-pins.dtsi"