]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
clk: qcom: camcc-sc7280: Add parent dependency to all camera GDSCs
authorTaniya Das <quic_tdas@quicinc.com>
Fri, 31 May 2024 09:51:42 +0000 (15:21 +0530)
committerBjorn Andersson <andersson@kernel.org>
Fri, 31 May 2024 22:52:47 +0000 (17:52 -0500)
Camera titan top GDSC is a parent supply to all other camera GDSCs. Titan
top GDSC is required to be enabled before enabling any other camera GDSCs
and it should be disabled only after all other camera GDSCs are disabled.
Ensure this behavior by marking titan top GDSC as parent of all other
camera GDSCs.

Fixes: 1daec8cfebc2 ("clk: qcom: camcc: Add camera clock controller driver for SC7280")
Signed-off-by: Taniya Das <quic_tdas@quicinc.com>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Reviewed-by: Konrad Dybcio <konrad.dybcio@linaro.org>
Link: https://lore.kernel.org/r/20240531095142.9688-4-quic_tdas@quicinc.com
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
drivers/clk/qcom/camcc-sc7280.c

index 27bfb0f959c4b61e705942e8f7f5474ef3e4f4e1..da29d3b953eea79555709c79c39f56a9fe736c4f 100644 (file)
@@ -2267,6 +2267,7 @@ static struct gdsc cam_cc_bps_gdsc = {
                .name = "cam_cc_bps_gdsc",
        },
        .pwrsts = PWRSTS_OFF_ON,
+       .parent = &cam_cc_titan_top_gdsc.pd,
        .flags = HW_CTRL | RETAIN_FF_ENABLE,
 };
 
@@ -2279,6 +2280,7 @@ static struct gdsc cam_cc_ife_0_gdsc = {
                .name = "cam_cc_ife_0_gdsc",
        },
        .pwrsts = PWRSTS_OFF_ON,
+       .parent = &cam_cc_titan_top_gdsc.pd,
        .flags = RETAIN_FF_ENABLE,
 };
 
@@ -2291,6 +2293,7 @@ static struct gdsc cam_cc_ife_1_gdsc = {
                .name = "cam_cc_ife_1_gdsc",
        },
        .pwrsts = PWRSTS_OFF_ON,
+       .parent = &cam_cc_titan_top_gdsc.pd,
        .flags = RETAIN_FF_ENABLE,
 };
 
@@ -2303,6 +2306,7 @@ static struct gdsc cam_cc_ife_2_gdsc = {
                .name = "cam_cc_ife_2_gdsc",
        },
        .pwrsts = PWRSTS_OFF_ON,
+       .parent = &cam_cc_titan_top_gdsc.pd,
        .flags = RETAIN_FF_ENABLE,
 };
 
@@ -2315,6 +2319,7 @@ static struct gdsc cam_cc_ipe_0_gdsc = {
                .name = "cam_cc_ipe_0_gdsc",
        },
        .pwrsts = PWRSTS_OFF_ON,
+       .parent = &cam_cc_titan_top_gdsc.pd,
        .flags = HW_CTRL | RETAIN_FF_ENABLE,
 };