| /* |
| * Copyright (c) 2015-2016, 2018, The Linux Foundation. All rights reserved. |
| * |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License version 2 and |
| * only version 2 as published by the Free Software Foundation. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| */ |
| |
| #include <dt-bindings/msm/pm.h> |
| |
| &soc { |
| qcom,spm@b012000 { |
| compatible = "qcom,spm-v2"; |
| #address-cells = <1>; |
| #size-cells = <1>; |
| reg = <0xb012000 0x1000>; |
| qcom,name = "perf-l2"; |
| qcom,saw2-ver-reg = <0xfd0>; |
| qcom,saw2-cfg = <0x14>; |
| qcom,saw2-spm-dly= <0x3C11840A>; |
| qcom,saw2-spm-ctl = <0xe>; |
| qcom,cpu-vctl-list = <&CPU0 &CPU1 &CPU2 &CPU3>; |
| qcom,vctl-timeout-us = <500>; |
| qcom,vctl-port = <0x0>; |
| }; |
| |
| qcom,lpm-levels { |
| compatible = "qcom,lpm-levels"; |
| qcom,use-psci; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| |
| qcom,pm-cluster@0{ |
| reg = <0>; |
| #address-cells = <1>; |
| #size-cells = <0>; |
| label = "perf"; |
| qcom,spm-device-names = "l2"; |
| qcom,default-level=<0>; |
| qcom,psci-mode-shift = <4>; |
| qcom,psci-mode-mask = <0xf>; |
| |
| qcom,pm-cluster-level@0{ |
| reg = <0>; |
| label = "perf-l2-wfi"; |
| qcom,psci-mode = <1>; |
| qcom,latency-us = <180>; |
| qcom,ss-power = <429>; |
| qcom,energy-overhead = <162991>; |
| qcom,time-overhead = <305>; |
| }; |
| |
| qcom,pm-cluster-level@1{ |
| reg = <1>; |
| label = "perf-l2-gdhs"; |
| qcom,psci-mode = <4>; |
| qcom,latency-us = <280>; |
| qcom,ss-power = <421>; |
| qcom,energy-overhead = <257510>; |
| qcom,time-overhead = <520>; |
| qcom,min-child-idx = <1>; |
| qcom,reset-level = <LPM_RESET_LVL_GDHS>; |
| }; |
| |
| qcom,pm-cluster-level@2{ |
| reg = <2>; |
| label = "perf-l2-retention"; |
| qcom,psci-mode = <2>; |
| qcom,latency-us = <650>; |
| qcom,ss-power = <350>; |
| qcom,energy-overhead = <651061>; |
| qcom,time-overhead = <1350>; |
| qcom,min-child-idx = <1>; |
| qcom,reset-level = <LPM_RESET_LVL_RET>; |
| }; |
| |
| qcom,pm-cluster-level@3{ |
| reg = <3>; |
| label = "perf-l2-pc"; |
| qcom,psci-mode = <5>; |
| qcom,latency-us = <11200>; |
| qcom,ss-power = <320>; |
| qcom,energy-overhead = <917561>; |
| qcom,time-overhead = <1700>; |
| qcom,min-child-idx = <1>; |
| qcom,is-reset; |
| qcom,notify-rpm; |
| qcom,reset-level = <LPM_RESET_LVL_PC>; |
| }; |
| |
| qcom,pm-cpu { |
| #address-cells = <1>; |
| #size-cells = <0>; |
| qcom,psci-mode-shift = <0>; |
| qcom,psci-mode-mask = <0xf>; |
| |
| qcom,pm-cpu-level@0 { |
| reg = <0>; |
| qcom,psci-cpu-mode = <0>; |
| label = "wfi"; |
| qcom,latency-us = <12>; |
| qcom,ss-power = <463>; |
| qcom,energy-overhead = <23520>; |
| qcom,time-overhead = <25>; |
| }; |
| |
| qcom,pm-cpu-level@1 { |
| reg = <1>; |
| qcom,psci-cpu-mode = <3>; |
| label = "pc"; |
| qcom,latency-us = <180>; |
| qcom,ss-power = <429>; |
| qcom,energy-overhead = <162991>; |
| qcom,time-overhead = <305>; |
| qcom,use-broadcast-timer; |
| qcom,is-reset; |
| qcom,reset-level = <LPM_RESET_LVL_PC>; |
| }; |
| }; |
| }; |
| }; |
| |
| qcom,mpm@601d0 { |
| compatible = "qcom,mpm-v2"; |
| reg = <0x601d0 0x1000>, /* MSM_RPM_MPM_BASE 4K */ |
| <0xb011008 0x4>; |
| reg-names = "vmpm", "ipc"; |
| interrupts = <0 171 1>; |
| clocks = <&clock_gcc clk_xo_lpm_clk>; |
| clock-names = "xo"; |
| qcom,ipc-bit-offset = <1>; |
| qcom,gic-parent = <&intc>; |
| qcom,gic-map = <2 216>, /* tsens_upper_lower_int */ |
| <49 172>, /* usb1_hs_async_wakeup_irq */ |
| <58 166>, /* usb_hs_irq */ |
| <53 104>, /* mdss_irq */ |
| <62 222>, /* ee0_krait_hlos_spmi_periph_irq */ |
| <0xff 18>, /* APC_qgicQTmrSecPhysIrptReq */ |
| <0xff 19>, /* APC_qgicQTmrNonSecPhysIrptReq */ |
| <0xff 20>, /* qgicQTmrVirtIrptReq */ |
| <0xff 35>, /* WDT_barkInt */ |
| <0xff 39>, /* arch_mem_timer */ |
| <0xff 40>, /* qtmr_phy_irq[0] */ |
| <0xff 47>, /* rbif_irq[0] */ |
| <0xff 56>, /* q6_wdog_expired_irq */ |
| <0xff 57>, /* mss_to_apps_irq(0) */ |
| <0xff 58>, /* mss_to_apps_irq(1) */ |
| <0xff 59>, /* mss_to_apps_irq(2) */ |
| <0xff 60>, /* mss_to_apps_irq(3) */ |
| <0xff 61>, /* mss_a2_bam_irq */ |
| <0xff 65>, /* o_gc_sys_irq[0] */ |
| <0xff 69>, /* vbif_irpt */ |
| <0xff 73>, /* smmu_intr_bus[1] */ |
| <0xff 74>, /* smmu_bus_intr[2] */ |
| <0xff 75>, /* smmu_bus_intr[3] */ |
| <0xff 76>, /* venus_irq */ |
| <0xff 78>, /* smmu_bus_intr[5] */ |
| <0xff 79>, /* smmu_bus_intr[6] */ |
| <0xff 85>, /* smmu_bus_intr[31] */ |
| <0xff 86>, /* smmu_bus_intr[32] */ |
| <0xff 90>, /* smmu_bus_intr[33] */ |
| <0xff 92>, /* smmu_bus_intr[34] */ |
| <0xff 93>, /* smmu_bus_intr[35] */ |
| <0xff 97>, /* smmu_bus_intr[10] */ |
| <0xff 102>, /* smmu_bus_intr[14] */ |
| <0xff 108>, /* smmu_bus_intr[36] */ |
| <0xff 109>, /* smmu_bus_intr[37] */ |
| <0xff 112>, /* smmu_bus_intr[38] */ |
| <0xff 114>, /* qdsd_intr_out */ |
| <0xff 126>, /* smmu_bus_intr[39] */ |
| <0xff 128>, /* blsp1_peripheral_irq[3] */ |
| <0xff 129>, /* blsp1_peripheral_irq[4] */ |
| <0xff 131>, /* qup_irq */ |
| <0xff 136>, /* smmu_bus_intr[43] */ |
| <0xff 137>, /* smmu_intr_bus[44] */ |
| <0xff 138>, /* smmu_intr_bus[45] */ |
| <0xff 140>, /* uart_dm_intr */ |
| <0xff 141>, /* smmu_bus_intr[46] */ |
| <0xff 142>, /* smmu_bus_intr[47] */ |
| <0xff 143>, /* smmu_bus_intr[48] */ |
| <0xff 144>, /* smmu_bus_intr[49] */ |
| <0xff 145>, /* smmu_bus_intr[50] */ |
| <0xff 146>, /* smmu_bus_intr[51] */ |
| <0xff 147>, /* smmu_bus_intr[52] */ |
| <0xff 148>, /* smmu_bus_intr[53] */ |
| <0xff 149>, /* smmu_bus_intr[54] */ |
| <0xff 150>, /* smmu_bus_intr[55] */ |
| <0xff 151>, /* smmu_bus_intr[56] */ |
| <0xff 152>, /* smmu_bus_intr[57] */ |
| <0xff 153>, /* smmu_bus_intr[58] */ |
| <0xff 155>, /* sdc1_irq(0) */ |
| <0xff 157>, /* sdc2_irq(0) */ |
| <0xff 167>, /* bam_irq(0) */ |
| <0xff 170>, /* sdc1_pwr_cmd_irq */ |
| <0xff 173>, /* o_wcss_apss_smd_hi */ |
| <0xff 174>, /* o_wcss_apss_smd_med */ |
| <0xff 175>, /* o_wcss_apss_smd_low */ |
| <0xff 176>, /* o_wcss_apss_smsm_irq */ |
| <0xff 177>, /* o_wcss_apss_wlan_data_xfer_done */ |
| <0xff 178>, /* o_wcss_apss_wlan_rx_data_avail */ |
| <0xff 179>, /* o_wcss_apss_asic_intr */ |
| <0xff 181>, /* o_wcss_apss_wdog_bite_and_reset_rdy */ |
| <0xff 188>, /* lpass_irq_out_apcs(0) */ |
| <0xff 189>, /* lpass_irq_out_apcs(1) */ |
| <0xff 190>, /* lpass_irq_out_apcs(2) */ |
| <0xff 191>, /* lpass_irq_out_apcs(3) */ |
| <0xff 192>, /* lpass_irq_out_apcs(4) */ |
| <0xff 193>, /* lpass_irq_out_apcs(5) */ |
| <0xff 194>, /* lpass_irq_out_apcs(6) */ |
| <0xff 195>, /* lpass_irq_out_apcs(7) */ |
| <0xff 196>, /* lpass_irq_out_apcs(8) */ |
| <0xff 197>, /* lpass_irq_out_apcs(9) */ |
| <0xff 198>, /* coresight-tmc-etr interrupt */ |
| <0xff 200>, /* rpm_ipc(4) */ |
| <0xff 201>, /* rpm_ipc(5) */ |
| <0xff 202>, /* rpm_ipc(6) */ |
| <0xff 203>, /* rpm_ipc(7) */ |
| <0xff 204>, /* rpm_ipc(24) */ |
| <0xff 205>, /* rpm_ipc(25) */ |
| <0xff 206>, /* rpm_ipc(26) */ |
| <0xff 207>, /* rpm_ipc(27) */ |
| <0xff 215>, /* o_bimc_intr[0] */ |
| <0xff 224>, /* SPDM interrupt */ |
| <0xff 239>, /* crypto_bam_irq[1]*/ |
| <0xff 240>, /* summary_irq_kpss */ |
| <0xff 253>, /* sdcc_pwr_cmd_irq */ |
| <0xff 260>, /* ipa_irq[0] */ |
| <0xff 261>, /* ipa_irq[2] */ |
| <0xff 262>, /* ipa_bam_irq[0] */ |
| <0xff 263>, /* ipa_bam_irq[2] */ |
| <0xff 269>, /* rpm_wdog_expired_irq */ |
| <0xff 270>, /* blsp1_bam_irq[0] */ |
| <0xff 272>, /* smmu_intr_bus[17] */ |
| <0xff 273>, /* smmu_bus_intr[18] */ |
| <0xff 274>, /* smmu_bus_intr[19] */ |
| <0xff 275>, /* rpm_ipc(30) */ |
| <0xff 276>, /* rpm_ipc(31) */ |
| <0xff 277>, /* smmu_intr_bus[20] */ |
| <0xff 285>, /* smmu_bus_intr[28] */ |
| <0xff 286>, /* smmu_bus_intr[29] */ |
| <0xff 287>, /* smmu_bus_intr[30] */ |
| <0xff 321>, /* q6ss_irq_out(4) */ |
| <0xff 322>, /* q6ss_irq_out(5) */ |
| <0xff 323>, /* q6ss_irq_out(6) */ |
| <0xff 325>, /* q6ss_wdog_exp_irq */ |
| <0xff 344>; /* sdcc1ice */ |
| |
| qcom,gpio-parent = <&tlmm>; |
| qcom,gpio-map = <3 38 >, |
| <4 1 >, |
| <5 5 >, |
| <6 9 >, |
| <8 37>, |
| <9 36>, |
| <10 13>, |
| <11 35>, |
| <12 17>, |
| <13 21>, |
| <14 54>, |
| <15 34>, |
| <16 31>, |
| <17 58>, |
| <18 28>, |
| <19 42>, |
| <20 25>, |
| <21 12>, |
| <22 43>, |
| <23 44>, |
| <24 45>, |
| <25 46>, |
| <26 48>, |
| <27 65>, |
| <28 93>, |
| <29 97>, |
| <30 63>, |
| <31 70>, |
| <32 71>, |
| <33 72>, |
| <34 81>, |
| <35 126>, |
| <36 90>, |
| <37 128>, |
| <38 91>, |
| <39 41>, |
| <40 127>, |
| <41 86>, |
| <50 67>, |
| <51 73>, |
| <52 74>, |
| <53 62>, |
| <54 124>, |
| <55 61>, |
| <56 130>, |
| <57 59>, |
| <59 50>; |
| }; |
| |
| qcom,cpu-sleep-status { |
| compatible = "qcom,cpu-sleep-status"; |
| }; |
| |
| qcom,rpm-log@29dc00 { |
| compatible = "qcom,rpm-log"; |
| reg = <0x29dc00 0x4000>; |
| qcom,rpm-addr-phys = <0x200000>; |
| qcom,offset-version = <4>; |
| qcom,offset-page-buffer-addr = <36>; |
| qcom,offset-log-len = <40>; |
| qcom,offset-log-len-mask = <44>; |
| qcom,offset-page-indices = <56>; |
| }; |
| |
| qcom,rpm-stats@29dba0 { |
| compatible = "qcom,rpm-stats"; |
| reg = <0x200000 0x1000>, |
| <0x290014 0x4>, |
| <0x29001c 0x4>; |
| reg-names = "phys_addr_base", "offset_addr", |
| "heap_phys_addrbase"; |
| qcom,sleep-stats-version = <2>; |
| }; |
| |
| qcom,rpm-master-stats@60150 { |
| compatible = "qcom,rpm-master-stats"; |
| reg = <0x60150 0x5000>; |
| qcom,masters = "APSS", "MPSS", "PRONTO", "TZ", "LPASS"; |
| qcom,master-stats-version = <2>; |
| qcom,master-offset = <4096>; |
| }; |
| }; |