ARM: dts: msm: Add clock controller and gdsc nodes for sm8150

Add support for all the clock controllers and also add gdsc regulators.

Change-Id: Ic313db887845e43c1d69b82f6bd8af4154145832
This commit is contained in:
Veera Vegivada
2022-01-12 21:23:13 +05:30
parent 6ce1f2837b
commit 915cff3fe2
4 changed files with 554 additions and 4 deletions

View File

@@ -7,3 +7,23 @@
qcom,msm-name = "SA8155 V1";
qcom,msm-id = <362 0x10000>;
};
&scc {
compatible = "qcom,sa8155-scc", "syscon";
};
&gcc {
compatible = "qcom,sa8155-gcc", "syscon";
};
&videocc {
compatible = "qcom,sa8155-videocc", "syscon";
};
&npucc {
compatible = "qcom,sa8155-npucc", "syscon";
};
&camcc {
compatible = "qcom,sa8155-camcc", "syscon";
};

View File

@@ -62,3 +62,16 @@
ranges;
};
};
&gpucc {
compatible = "qcom,sa8155-gpucc", "syscon";
};
&scc {
vdd_scc_cx-supply = <&VDD_CX_LEVEL>;
status = "ok";
};
&gpu_gx_gdsc {
parent-supply = <&VDD_GFX_LEVEL>;
};

244
qcom/sm8150-gdsc.dtsi Normal file
View File

@@ -0,0 +1,244 @@
&soc {
/* GDSCs in Global CC */
emac_gdsc: qcom,gdsc@106004 {
compatible = "qcom,gdsc";
regulator-name = "emac_gdsc";
reg = <0x106004 0x4>;
status = "disabled";
};
pcie_0_gdsc: qcom,gdsc@16b004 {
compatible = "qcom,gdsc";
regulator-name = "pcie_0_gdsc";
reg = <0x16b004 0x4>;
status = "disabled";
};
pcie_1_gdsc: qcom,gdsc@18d004 {
compatible = "qcom,gdsc";
regulator-name = "pcie_1_gdsc";
reg = <0x18d004 0x4>;
status = "disabled";
};
ufs_card_gdsc: qcom,gdsc@175004 {
compatible = "qcom,gdsc";
regulator-name = "ufs_card_gdsc";
reg = <0x175004 0x4>;
status = "disabled";
};
ufs_phy_gdsc: qcom,gdsc@177004 {
compatible = "qcom,gdsc";
regulator-name = "ufs_phy_gdsc";
reg = <0x177004 0x4>;
status = "disabled";
};
usb30_prim_gdsc: qcom,gdsc@10f004 {
compatible = "qcom,gdsc";
regulator-name = "usb30_prim_gdsc";
reg = <0x10f004 0x4>;
status = "disabled";
};
usb30_sec_gdsc: qcom,gdsc@110004 {
compatible = "qcom,gdsc";
regulator-name = "usb30_sec_gdsc";
reg = <0x110004 0x4>;
status = "disabled";
};
hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc: qcom,gdsc@17d040 {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc";
reg = <0x17d040 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
hlos1_vote_aggre_noc_mmu_tbu1_gdsc: qcom,gdsc@17d044 {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_aggre_noc_mmu_tbu1_gdsc";
reg = <0x17d044 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
hlos1_vote_aggre_noc_mmu_tbu2_gdsc: qcom,gdsc@17d048 {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_aggre_noc_mmu_tbu2_gdsc";
reg = <0x17d048 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc: qcom,gdsc@17d04c {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc";
reg = <0x17d04c 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc: qcom,gdsc@17d050 {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc";
reg = <0x17d050 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
hlos1_vote_mmnoc_mmu_tbu_sf_gdsc: qcom,gdsc@17d054 {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_mmnoc_mmu_tbu_sf_gdsc";
reg = <0x17d054 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc: qcom,gdsc@17d058 {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc";
reg = <0x17d058 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
hlos1_vote_turing_mmu_tbu0_gdsc: qcom,gdsc@17d05c {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_turing_mmu_tbu0_gdsc";
reg = <0x17d05c 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
hlos1_vote_turing_mmu_tbu1_gdsc: qcom,gdsc@17d060 {
compatible = "qcom,gdsc";
regulator-name = "hlos1_vote_turing_mmu_tbu1_gdsc";
reg = <0x17d060 0x4>;
qcom,no-status-check-on-disable;
status = "disabled";
};
/* GDSCs in Camera CC */
bps_gdsc: qcom,gdsc@ad07004 {
compatible = "qcom,gdsc";
regulator-name = "bps_gdsc";
reg = <0xad07004 0x4>;
status = "disabled";
};
ipe_0_gdsc: qcom,gdsc@ad08004 {
compatible = "qcom,gdsc";
regulator-name = "ipe_0_gdsc";
reg = <0xad08004 0x4>;
status = "disabled";
};
ipe_1_gdsc: qcom,gdsc@ad09004 {
compatible = "qcom,gdsc";
regulator-name = "ipe_1_gdsc";
reg = <0xad09004 0x4>;
status = "disabled";
};
ife_0_gdsc: qcom,gdsc@ad0a004 {
compatible = "qcom,gdsc";
regulator-name = "ife_0_gdsc";
reg = <0xad0a004 0x4>;
status = "disabled";
};
ife_1_gdsc: qcom,gdsc@ad0b004 {
compatible = "qcom,gdsc";
regulator-name = "ife_1_gdsc";
reg = <0xad0b004 0x4>;
status = "disabled";
};
titan_top_gdsc: qcom,gdsc@ad0c1bc {
compatible = "qcom,gdsc";
regulator-name = "titan_top_gdsc";
reg = <0xad0c1bc 0x4>;
status = "disabled";
};
/* GDSCs in Display CC */
mdss_core_gdsc: qcom,gdsc@af03000 {
compatible = "qcom,gdsc";
regulator-name = "mdss_core_gdsc";
reg = <0xaf03000 0x4>;
qcom,support-hw-trigger;
status = "disabled";
proxy-supply = <&mdss_core_gdsc>;
qcom,proxy-consumer-enable;
};
/* GDSCs in Graphics CC */
gpu_cx_hw_ctrl: syscon@2c91540 {
compatible = "syscon";
reg = <0x2c91540 0x4>;
};
gpu_cx_gdsc: qcom,gdsc@2c9106c {
compatible = "qcom,gdsc";
regulator-name = "gpu_cx_gdsc";
reg = <0x2c9106c 0x4>;
hw-ctrl-addr = <&gpu_cx_hw_ctrl>;
qcom,skip-disable;
qcom,clk-dis-wait-val = <8>;
mboxes = <&qmp_aop 0>;
status = "disabled";
};
gpu_gx_domain_addr: syscon@2c91508 {
compatible = "syscon";
reg = <0x2c91508 0x4>;
};
gpu_gx_sw_reset: syscon@2c91008 {
compatible = "syscon";
reg = <0x2c91008 0x4>;
};
gpu_gx_gdsc: qcom,gdsc@2c9100c {
compatible = "qcom,gdsc";
regulator-name = "gpu_gx_gdsc";
reg = <0x2c9100c 0x4>;
domain-addr = <&gpu_gx_domain_addr>;
sw-reset = <&gpu_gx_sw_reset>;
qcom,reset-aon-logic;
status = "disabled";
};
/* GDSCs in Video CC */
mvsc_gdsc: qcom,gdsc@ab00814 {
compatible = "qcom,gdsc";
regulator-name = "mvsc_gdsc";
reg = <0xab00814 0x4>;
status = "disabled";
};
mvs0_gdsc: qcom,gdsc@ab00874 {
compatible = "qcom,gdsc";
regulator-name = "mvs0_gdsc";
reg = <0xab00874 0x4>;
status = "disabled";
};
mvs1_gdsc: qcom,gdsc@ab008b4 {
compatible = "qcom,gdsc";
regulator-name = "mvs1_gdsc";
reg = <0xab008b4 0x4>;
status = "disabled";
};
/* GDSCs in NPU CC */
npu_core_gdsc: qcom,gdsc@9911028 {
compatible = "qcom,gdsc";
regulator-name = "npu_core_gdsc";
reg = <0x9911028 0x4>;
status = "disabled";
};
};

View File

@@ -3,6 +3,12 @@
#include <dt-bindings/clock/qcom,rpmh.h>
#include <dt-bindings/clock/qcom,gcc-sm8150.h>
#include <dt-bindings/clock/qcom,aop-qmp.h>
#include <dt-bindings/clock/qcom,camcc-sm8150.h>
#include <dt-bindings/clock/qcom,dispcc-sm8150.h>
#include <dt-bindings/clock/qcom,gpucc-sm8150.h>
#include <dt-bindings/clock/qcom,npucc-sm8150.h>
#include <dt-bindings/clock/qcom,scc-sm8150.h>
#include <dt-bindings/clock/qcom,videocc-sm8150.h>
/ {
model = "Qualcomm Technologies, Inc. SM8150";
@@ -703,14 +709,125 @@
};
gcc: clock-controller@100000 {
compatible = "qcom,gcc-sm8150";
compatible = "qcom,sm8150-gcc", "syscon";
reg = <0x100000 0x1f0000>;
reg-names = "cc_base";
vdd_cx-supply = <&VDD_CX_LEVEL>;
vdd_cx_ao-supply = <&VDD_CX_LEVEL_AO>;
vdd_mm-supply = <&VDD_MMCX_LEVEL>;
clocks = <&rpmhcc RPMH_CXO_CLK>, <&rpmhcc RPMH_CXO_CLK_A>,
<&sleep_clk>;
clock-names = "bi_tcxo", "bi_tcxo_ao", "sleep_clk";
#clock-cells = <1>;
#reset-cells = <1>;
};
videocc: clock-controller@ab00000 {
compatible = "qcom,sm8150-videocc", "syscon";
reg = <0xab00000 0x10000>;
reg-names = "cc_base";
vdd_mm-supply = <&VDD_MMCX_LEVEL>;
clocks = <&gcc GCC_VIDEO_AHB_CLK>, <&rpmhcc RPMH_CXO_CLK>;
clock-names = "iface", "bi_tcxo";
#clock-cells = <1>;
#reset-cells = <1>;
};
camcc: clock-controller@ad00000 {
compatible = "qcom,sm8150-camcc", "syscon";
reg = <0xad00000 0x10000>;
reg-names = "cc_base";
vdd_mx-supply = <&VDD_MX_LEVEL>;
vdd_mm-supply = <&VDD_MMCX_LEVEL>;
clocks = <&gcc GCC_CAMERA_AHB_CLK>, <&rpmhcc RPMH_CXO_CLK>;
clock-names = "iface", "bi_tcxo";
#clock-cells = <1>;
#reset-cells = <1>;
};
dispcc: clock-controller@af00000 {
compatible = "qcom,sm8150-dispcc", "syscon";
reg = <0xaf00000 0x20000>;
reg-names = "cc_base";
vdd_mm-supply = <&VDD_MMCX_LEVEL>;
clocks = <&gcc GCC_DISP_AHB_CLK>, <&rpmhcc RPMH_CXO_CLK>;
clock-names = "iface", "bi_tcxo";
#clock-cells = <1>;
#reset-cells = <1>;
};
npucc: clock-controller@9910000 {
compatible = "qcom,sm8150-npucc", "syscon";
reg = <0x9910000 0x10000>;
reg-names = "cc_base";
vdd_cx-supply = <&VDD_CX_LEVEL>;
vdd_gdsc-supply = <&npu_core_gdsc>;
clocks =
<&rpmhcc RPMH_CXO_CLK>,
<&gcc GCC_NPU_GPLL0_DIV_CLK_SRC>,
<&gcc GCC_NPU_GPLL0_CLK_SRC>,
<&gcc GCC_NPU_AXI_CLK>;
clock-names =
"bi_tcxo",
"gcc_npu_gpll0_div_clk_src",
"gcc_npu_gpll0_clk_src",
"gcc_npu_axi_clk";
#clock-cells = <1>;
#reset-cells = <1>;
};
gpucc: clock-controller@2c90000 {
compatible = "qcom,sm8150-gpucc", "syscon";
reg = <0x2c90000 0x9000>;
reg-names = "cc_base";
vdd_cx-supply = <&VDD_CX_LEVEL>;
vdd_mx-supply = <&VDD_MX_LEVEL>;
clocks =
<&rpmhcc RPMH_CXO_CLK>,
<&gcc GCC_GPU_GPLL0_CLK_SRC>,
<&gcc GCC_GPU_GPLL0_DIV_CLK_SRC>,
<&gcc GCC_GPU_CFG_AHB_CLK>;
clock-names = "bi_tcxo",
"sleep_clk";
clocks = <&rpmhcc RPMH_CXO_CLK>,
<&sleep_clk>;
"gcc_gpu_gpll0_clk_src",
"gcc_gpu_gpll0_div_clk_src",
"iface";
#clock-cells = <1>;
#reset-cells = <1>;
};
scc: clock-controller@2b10000 {
compatible = "qcom,sm8150-scc", "syscon";
reg = <0x2b10000 0x30000>;
vdd_scc_cx-supply = <&pm8150_l8_level>;
clocks = <&rpmhcc RPMH_CXO_CLK>;
clock-names = "bi_tcxo";
#clock-cells = <1>;
status = "disabled";
};
cpucc: syscon@182a0000 {
compatible = "syscon";
reg = <0x182a0000 0x4>;
};
mccc: syscon@90b0000 {
compatible = "syscon";
reg = <0x90b0000 0x1000>;
};
debugcc: debug-clock-controller@0 {
compatible = "qcom,sm8150-debugcc";
qcom,gcc = <&gcc>;
qcom,videocc = <&videocc>;
qcom,camcc = <&camcc>;
qcom,dispcc = <&dispcc>;
qcom,npucc = <&npucc>;
qcom,gpucc = <&gpucc>;
qcom,cpucc = <&cpucc>;
qcom,mccc = <&mccc>;
clock-names = "xo_clk_src";
clocks = <&rpmhcc RPMH_CXO_CLK>;
#clock-cells = <1>;
};
qupv3_id_1: geniqup@ac0000 {
@@ -781,3 +898,159 @@
#include "sm8150-regulator.dtsi"
#include "sm8150-pinctrl.dtsi"
#include "sm8150-dma-heaps.dtsi"
#include "sm8150-gdsc.dtsi"
&emac_gdsc {
status = "ok";
};
&pcie_0_gdsc {
status = "ok";
};
&pcie_1_gdsc {
status = "ok";
};
&ufs_phy_gdsc {
status = "ok";
};
&ufs_card_gdsc {
status = "ok";
};
&usb30_prim_gdsc {
status = "ok";
};
&usb30_sec_gdsc {
status = "ok";
};
&hlos1_vote_aggre_noc_mmu_audio_tbu_gdsc {
status = "ok";
};
&hlos1_vote_aggre_noc_mmu_tbu1_gdsc {
status = "ok";
};
&hlos1_vote_aggre_noc_mmu_tbu2_gdsc {
status = "ok";
};
&hlos1_vote_aggre_noc_mmu_pcie_tbu_gdsc {
status = "ok";
};
&hlos1_vote_mmnoc_mmu_tbu_hf0_gdsc {
status = "ok";
};
&hlos1_vote_mmnoc_mmu_tbu_sf_gdsc {
status = "ok";
};
&hlos1_vote_mmnoc_mmu_tbu_hf1_gdsc {
status = "ok";
};
&hlos1_vote_turing_mmu_tbu0_gdsc {
status = "ok";
};
&hlos1_vote_turing_mmu_tbu1_gdsc {
status = "ok";
};
&bps_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_CAMERA_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
qcom,support-hw-trigger;
status = "ok";
};
&ipe_0_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_CAMERA_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
qcom,support-hw-trigger;
status = "ok";
};
&ipe_1_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_CAMERA_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
qcom,support-hw-trigger;
status = "ok";
};
&ife_0_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_CAMERA_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
status = "ok";
};
&ife_1_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_CAMERA_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
status = "ok";
};
&titan_top_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_CAMERA_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
status = "ok";
};
&mdss_core_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_DISP_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
status = "ok";
};
&gpu_cx_gdsc {
parent-supply = <&VDD_CX_LEVEL>;
status = "ok";
};
&gpu_gx_gdsc {
parent-supply = <&VDD_GFX_LEVEL>;
status = "ok";
};
&mvsc_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_VIDEO_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
status = "ok";
};
&mvs0_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_VIDEO_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
qcom,support-hw-trigger;
status = "ok";
};
&mvs1_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_VIDEO_AHB_CLK>;
parent-supply = <&VDD_MMCX_LEVEL>;
qcom,support-hw-trigger;
status = "ok";
};
&npu_core_gdsc {
clock-names = "ahb_clk";
clocks = <&gcc GCC_NPU_CFG_AHB_CLK>;
status = "ok";
};