Commit 05cc560c authored by Shawn Guo's avatar Shawn Guo Committed by Stephen Boyd

clk: qcom: a53pll/mux: Use unique clock name

Different from MSM8916 which has only one a53pll/mux clock, MSM8939 gets
three for Cluster0 (little cores), Cluster1 (big cores) and CCI (Cache
Coherent Interconnect).  That said, a53pll/mux clock needs to be named
uniquely.  Append @unit-address of device node to the clock name, so
that a53pll/mux will be named like below on MSM8939.

  a53pll@b016000
  a53pll@b116000
  a53pll@b1d0000

  a53mux@b1d1000
  a53mux@b011000
  a53mux@b111000
Signed-off-by: default avatarShawn Guo <shawn.guo@linaro.org>
Link: https://lore.kernel.org/r/20210704024032.11559-3-shawn.guo@linaro.orgSigned-off-by: default avatarStephen Boyd <sboyd@kernel.org>
parent 0dfe9bf9
...@@ -37,6 +37,7 @@ static const struct regmap_config a53pll_regmap_config = { ...@@ -37,6 +37,7 @@ static const struct regmap_config a53pll_regmap_config = {
static int qcom_a53pll_probe(struct platform_device *pdev) static int qcom_a53pll_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct device_node *np = dev->of_node;
struct regmap *regmap; struct regmap *regmap;
struct resource *res; struct resource *res;
struct clk_pll *pll; struct clk_pll *pll;
...@@ -66,7 +67,12 @@ static int qcom_a53pll_probe(struct platform_device *pdev) ...@@ -66,7 +67,12 @@ static int qcom_a53pll_probe(struct platform_device *pdev)
pll->status_bit = 16; pll->status_bit = 16;
pll->freq_tbl = a53pll_freq; pll->freq_tbl = a53pll_freq;
init.name = "a53pll"; /* Use an unique name by appending @unit-address */
init.name = devm_kasprintf(dev, GFP_KERNEL, "a53pll%s",
strchrnul(np->full_name, '@'));
if (!init.name)
return -ENOMEM;
init.parent_names = (const char *[]){ "xo" }; init.parent_names = (const char *[]){ "xo" };
init.num_parents = 1; init.num_parents = 1;
init.ops = &clk_pll_sr2_ops; init.ops = &clk_pll_sr2_ops;
......
...@@ -46,6 +46,7 @@ static int qcom_apcs_msm8916_clk_probe(struct platform_device *pdev) ...@@ -46,6 +46,7 @@ static int qcom_apcs_msm8916_clk_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct device *parent = dev->parent; struct device *parent = dev->parent;
struct device_node *np = parent->of_node;
struct clk_regmap_mux_div *a53cc; struct clk_regmap_mux_div *a53cc;
struct regmap *regmap; struct regmap *regmap;
struct clk_init_data init = { }; struct clk_init_data init = { };
...@@ -61,7 +62,12 @@ static int qcom_apcs_msm8916_clk_probe(struct platform_device *pdev) ...@@ -61,7 +62,12 @@ static int qcom_apcs_msm8916_clk_probe(struct platform_device *pdev)
if (!a53cc) if (!a53cc)
return -ENOMEM; return -ENOMEM;
init.name = "a53mux"; /* Use an unique name by appending parent's @unit-address */
init.name = devm_kasprintf(dev, GFP_KERNEL, "a53mux%s",
strchrnul(np->full_name, '@'));
if (!init.name)
return -ENOMEM;
init.parent_data = pdata; init.parent_data = pdata;
init.num_parents = ARRAY_SIZE(pdata); init.num_parents = ARRAY_SIZE(pdata);
init.ops = &clk_regmap_mux_div_ops; init.ops = &clk_regmap_mux_div_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