Commit 7ee9d2e8 authored by Dmitry Baryshkov's avatar Dmitry Baryshkov Committed by Bjorn Andersson

clk: qcom: gcc-sm8450: use new clk_regmap_phy_mux_ops for PCIe pipe clocks

Use newly defined clk_regmap_phy_mux_ops for PCIe pipe clocks to let
the clock framework automatically park the clock when the clock is
switched off and restore the parent when the clock is switched on.
Reviewed-by: default avatarJohan Hovold <johan+linaro@kernel.org>
Signed-off-by: default avatarDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Reviewed-by: default avatarStephen Boyd <sboyd@kernel.org>
Signed-off-by: default avatarBjorn Andersson <bjorn.andersson@linaro.org>
Link: https://lore.kernel.org/r/20220608105238.2973600-3-dmitry.baryshkov@linaro.org
parent 74e4190c
...@@ -17,6 +17,7 @@ ...@@ -17,6 +17,7 @@
#include "clk-regmap.h" #include "clk-regmap.h"
#include "clk-regmap-divider.h" #include "clk-regmap-divider.h"
#include "clk-regmap-mux.h" #include "clk-regmap-mux.h"
#include "clk-regmap-phy-mux.h"
#include "gdsc.h" #include "gdsc.h"
#include "reset.h" #include "reset.h"
...@@ -26,9 +27,7 @@ enum { ...@@ -26,9 +27,7 @@ enum {
P_GCC_GPLL0_OUT_MAIN, P_GCC_GPLL0_OUT_MAIN,
P_GCC_GPLL4_OUT_MAIN, P_GCC_GPLL4_OUT_MAIN,
P_GCC_GPLL9_OUT_MAIN, P_GCC_GPLL9_OUT_MAIN,
P_PCIE_0_PIPE_CLK,
P_PCIE_1_PHY_AUX_CLK, P_PCIE_1_PHY_AUX_CLK,
P_PCIE_1_PIPE_CLK,
P_SLEEP_CLK, P_SLEEP_CLK,
P_UFS_PHY_RX_SYMBOL_0_CLK, P_UFS_PHY_RX_SYMBOL_0_CLK,
P_UFS_PHY_RX_SYMBOL_1_CLK, P_UFS_PHY_RX_SYMBOL_1_CLK,
...@@ -153,16 +152,6 @@ static const struct clk_parent_data gcc_parent_data_3[] = { ...@@ -153,16 +152,6 @@ static const struct clk_parent_data gcc_parent_data_3[] = {
{ .fw_name = "bi_tcxo" }, { .fw_name = "bi_tcxo" },
}; };
static const struct parent_map gcc_parent_map_4[] = {
{ P_PCIE_0_PIPE_CLK, 0 },
{ P_BI_TCXO, 2 },
};
static const struct clk_parent_data gcc_parent_data_4[] = {
{ .fw_name = "pcie_0_pipe_clk", },
{ .fw_name = "bi_tcxo", },
};
static const struct parent_map gcc_parent_map_5[] = { static const struct parent_map gcc_parent_map_5[] = {
{ P_PCIE_1_PHY_AUX_CLK, 0 }, { P_PCIE_1_PHY_AUX_CLK, 0 },
{ P_BI_TCXO, 2 }, { P_BI_TCXO, 2 },
...@@ -173,16 +162,6 @@ static const struct clk_parent_data gcc_parent_data_5[] = { ...@@ -173,16 +162,6 @@ static const struct clk_parent_data gcc_parent_data_5[] = {
{ .fw_name = "bi_tcxo" }, { .fw_name = "bi_tcxo" },
}; };
static const struct parent_map gcc_parent_map_6[] = {
{ P_PCIE_1_PIPE_CLK, 0 },
{ P_BI_TCXO, 2 },
};
static const struct clk_parent_data gcc_parent_data_6[] = {
{ .fw_name = "pcie_1_pipe_clk" },
{ .fw_name = "bi_tcxo" },
};
static const struct parent_map gcc_parent_map_7[] = { static const struct parent_map gcc_parent_map_7[] = {
{ P_BI_TCXO, 0 }, { P_BI_TCXO, 0 },
{ P_GCC_GPLL0_OUT_MAIN, 1 }, { P_GCC_GPLL0_OUT_MAIN, 1 },
...@@ -239,17 +218,16 @@ static const struct clk_parent_data gcc_parent_data_11[] = { ...@@ -239,17 +218,16 @@ static const struct clk_parent_data gcc_parent_data_11[] = {
{ .fw_name = "bi_tcxo" }, { .fw_name = "bi_tcxo" },
}; };
static struct clk_regmap_mux gcc_pcie_0_pipe_clk_src = { static struct clk_regmap_phy_mux gcc_pcie_0_pipe_clk_src = {
.reg = 0x7b060, .reg = 0x7b060,
.shift = 0,
.width = 2,
.parent_map = gcc_parent_map_4,
.clkr = { .clkr = {
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "gcc_pcie_0_pipe_clk_src", .name = "gcc_pcie_0_pipe_clk_src",
.parent_data = gcc_parent_data_4, .parent_data = &(const struct clk_parent_data){
.num_parents = ARRAY_SIZE(gcc_parent_data_4), .fw_name = "pcie_0_pipe_clk",
.ops = &clk_regmap_mux_closest_ops, },
.num_parents = 1,
.ops = &clk_regmap_phy_mux_ops,
}, },
}, },
}; };
...@@ -269,17 +247,16 @@ static struct clk_regmap_mux gcc_pcie_1_phy_aux_clk_src = { ...@@ -269,17 +247,16 @@ static struct clk_regmap_mux gcc_pcie_1_phy_aux_clk_src = {
}, },
}; };
static struct clk_regmap_mux gcc_pcie_1_pipe_clk_src = { static struct clk_regmap_phy_mux gcc_pcie_1_pipe_clk_src = {
.reg = 0x9d064, .reg = 0x9d064,
.shift = 0,
.width = 2,
.parent_map = gcc_parent_map_6,
.clkr = { .clkr = {
.hw.init = &(struct clk_init_data){ .hw.init = &(struct clk_init_data){
.name = "gcc_pcie_1_pipe_clk_src", .name = "gcc_pcie_1_pipe_clk_src",
.parent_data = gcc_parent_data_6, .parent_data = &(const struct clk_parent_data){
.num_parents = ARRAY_SIZE(gcc_parent_data_6), .fw_name = "pcie_1_pipe_clk",
.ops = &clk_regmap_mux_closest_ops, },
.num_parents = 1,
.ops = &clk_regmap_phy_mux_ops,
}, },
}, },
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment