]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
clk: qcom: gcc-sm8450: Update the SDCC RCGs to use shared_floor_ops
authorJagadeesh Kona <jagadeesh.kona@oss.qualcomm.com>
Thu, 27 Nov 2025 17:57:36 +0000 (23:27 +0530)
committerBjorn Andersson <andersson@kernel.org>
Wed, 7 Jan 2026 15:12:00 +0000 (09:12 -0600)
Use shared_floor_ops for the SDCC RCGs so the RCG is safely parked
during disable and the new parent configuration is programmed in
hardware only when the new parent is enabled, avoiding cases where
the RCG configuration fails to update.

Fixes: a27ac3806b0a ("clk: qcom: gcc-sm8450: Use floor ops for SDCC RCGs")
Reviewed-by: Taniya Das <taniya.das@oss.qualcomm.com>
Reviewed-by: Imran Shaik <imran.shaik@oss.qualcomm.com>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
Reviewed-by: Vladimir Zapolskiy <vladimir.zapolskiy@linaro.org>
Signed-off-by: Jagadeesh Kona <jagadeesh.kona@oss.qualcomm.com>
Link: https://lore.kernel.org/r/20251127-sdcc_shared_floor_ops-v2-1-473afc86589c@oss.qualcomm.com
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
drivers/clk/qcom/gcc-sm8450.c

index 65d7d52bce034335707014797fe9002429212a14..b18bb34889ab28fba13cbf2ca8cf83101e4e0484 100644 (file)
@@ -1034,7 +1034,7 @@ static struct clk_rcg2 gcc_sdcc2_apps_clk_src = {
                .parent_data = gcc_parent_data_7,
                .num_parents = ARRAY_SIZE(gcc_parent_data_7),
                .flags = CLK_SET_RATE_PARENT,
-               .ops = &clk_rcg2_floor_ops,
+               .ops = &clk_rcg2_shared_floor_ops,
        },
 };
 
@@ -1057,7 +1057,7 @@ static struct clk_rcg2 gcc_sdcc4_apps_clk_src = {
                .parent_data = gcc_parent_data_0,
                .num_parents = ARRAY_SIZE(gcc_parent_data_0),
                .flags = CLK_SET_RATE_PARENT,
-               .ops = &clk_rcg2_floor_ops,
+               .ops = &clk_rcg2_shared_floor_ops,
        },
 };