clk: qcom: gcc-ipq806x: add additional freq nss cores
Ipq8065 SoC (an evolution of ipq8064 SoC) contains nss cores that can be clocked to 800MHz. Add these missing freq to the gcc driver. Set the freq_tbl for the ubi32_cores to the correct values based on the machine compatible. Signed-off-by: Ansuel Smith <ansuelsmth@gmail.com> Reviewed-by: Stephen Boyd <sboyd@kernel.org> Tested-by: Jonathan McDowell <noodles@earth.li> Signed-off-by: Bjorn Andersson <bjorn.andersson@linaro.org> Link: https://lore.kernel.org/r/20220226135235.10051-8-ansuelsmth@gmail.com
This commit is contained in:
parent
a6aedd6532
commit
512ea2edfe
|
@ -232,7 +232,9 @@ static struct clk_regmap pll14_vote = {
|
||||||
|
|
||||||
static struct pll_freq_tbl pll18_freq_tbl[] = {
|
static struct pll_freq_tbl pll18_freq_tbl[] = {
|
||||||
NSS_PLL_RATE(550000000, 44, 0, 1, 0x01495625),
|
NSS_PLL_RATE(550000000, 44, 0, 1, 0x01495625),
|
||||||
|
NSS_PLL_RATE(600000000, 48, 0, 1, 0x01495625),
|
||||||
NSS_PLL_RATE(733000000, 58, 16, 25, 0x014b5625),
|
NSS_PLL_RATE(733000000, 58, 16, 25, 0x014b5625),
|
||||||
|
NSS_PLL_RATE(800000000, 64, 0, 1, 0x01495625),
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct clk_pll pll18 = {
|
static struct clk_pll pll18 = {
|
||||||
|
@ -2698,7 +2700,7 @@ static struct clk_branch nss_tcm_clk = {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct freq_tbl clk_tbl_nss[] = {
|
static const struct freq_tbl clk_tbl_nss_ipq8064[] = {
|
||||||
{ 110000000, P_PLL18, 1, 1, 5 },
|
{ 110000000, P_PLL18, 1, 1, 5 },
|
||||||
{ 275000000, P_PLL18, 2, 0, 0 },
|
{ 275000000, P_PLL18, 2, 0, 0 },
|
||||||
{ 550000000, P_PLL18, 1, 0, 0 },
|
{ 550000000, P_PLL18, 1, 0, 0 },
|
||||||
|
@ -2706,6 +2708,14 @@ static const struct freq_tbl clk_tbl_nss[] = {
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const struct freq_tbl clk_tbl_nss_ipq8065[] = {
|
||||||
|
{ 110000000, P_PLL18, 1, 1, 5 },
|
||||||
|
{ 275000000, P_PLL18, 2, 0, 0 },
|
||||||
|
{ 600000000, P_PLL18, 1, 0, 0 },
|
||||||
|
{ 800000000, P_PLL18, 1, 0, 0 },
|
||||||
|
{ }
|
||||||
|
};
|
||||||
|
|
||||||
static struct clk_dyn_rcg ubi32_core1_src_clk = {
|
static struct clk_dyn_rcg ubi32_core1_src_clk = {
|
||||||
.ns_reg[0] = 0x3d2c,
|
.ns_reg[0] = 0x3d2c,
|
||||||
.ns_reg[1] = 0x3d30,
|
.ns_reg[1] = 0x3d30,
|
||||||
|
@ -2745,7 +2755,7 @@ static struct clk_dyn_rcg ubi32_core1_src_clk = {
|
||||||
.pre_div_width = 2,
|
.pre_div_width = 2,
|
||||||
},
|
},
|
||||||
.mux_sel_bit = 0,
|
.mux_sel_bit = 0,
|
||||||
.freq_tbl = clk_tbl_nss,
|
/* nss freq table is selected based on the SoC compatible */
|
||||||
.clkr = {
|
.clkr = {
|
||||||
.enable_reg = 0x3d20,
|
.enable_reg = 0x3d20,
|
||||||
.enable_mask = BIT(1),
|
.enable_mask = BIT(1),
|
||||||
|
@ -2798,7 +2808,7 @@ static struct clk_dyn_rcg ubi32_core2_src_clk = {
|
||||||
.pre_div_width = 2,
|
.pre_div_width = 2,
|
||||||
},
|
},
|
||||||
.mux_sel_bit = 0,
|
.mux_sel_bit = 0,
|
||||||
.freq_tbl = clk_tbl_nss,
|
/* nss freq table is selected based on the SoC compatible */
|
||||||
.clkr = {
|
.clkr = {
|
||||||
.enable_reg = 0x3d40,
|
.enable_reg = 0x3d40,
|
||||||
.enable_mask = BIT(1),
|
.enable_mask = BIT(1),
|
||||||
|
@ -3131,6 +3141,14 @@ static int gcc_ipq806x_probe(struct platform_device *pdev)
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
|
if (of_machine_is_compatible("qcom,ipq8065")) {
|
||||||
|
ubi32_core1_src_clk.freq_tbl = clk_tbl_nss_ipq8065;
|
||||||
|
ubi32_core2_src_clk.freq_tbl = clk_tbl_nss_ipq8065;
|
||||||
|
} else {
|
||||||
|
ubi32_core1_src_clk.freq_tbl = clk_tbl_nss_ipq8064;
|
||||||
|
ubi32_core2_src_clk.freq_tbl = clk_tbl_nss_ipq8064;
|
||||||
|
}
|
||||||
|
|
||||||
ret = qcom_cc_probe(pdev, &gcc_ipq806x_desc);
|
ret = qcom_cc_probe(pdev, &gcc_ipq806x_desc);
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in New Issue