Commit 1b2189f3 authored by Rob Herring's avatar Rob Herring

clk: versatile: clk-icst: Ensure clock names are unique

Commit 2d3de197 ("ARM: dts: arm: Update ICST clock nodes 'reg' and
node names") moved to using generic node names. That results in trying
to register multiple clocks with the same name. Fix this by including
the unit-address in the clock name.

Fixes: 2d3de197 ("ARM: dts: arm: Update ICST clock nodes 'reg' and node names")
Cc: stable@vger.kernel.org
Cc: Linus Walleij <linus.walleij@linaro.org>
Cc: Stephen Boyd <sboyd@kernel.org>
Cc: linux-arm-kernel@lists.infradead.org
Cc: linux-clk@vger.kernel.org
Signed-off-by: default avatarRob Herring <robh@kernel.org>
Reviewed-by: default avatarStephen Boyd <sboyd@kernel.org>
Reviewed-by: default avatarLinus Walleij <linus.walleij@linaro.org>
Link: https://lore.kernel.org/r/20211109164650.2233507-3-robh@kernel.org
parent 68d16195
...@@ -484,7 +484,7 @@ static void __init of_syscon_icst_setup(struct device_node *np) ...@@ -484,7 +484,7 @@ static void __init of_syscon_icst_setup(struct device_node *np)
struct device_node *parent; struct device_node *parent;
struct regmap *map; struct regmap *map;
struct clk_icst_desc icst_desc; struct clk_icst_desc icst_desc;
const char *name = np->name; const char *name;
const char *parent_name; const char *parent_name;
struct clk *regclk; struct clk *regclk;
enum icst_control_type ctype; enum icst_control_type ctype;
...@@ -533,15 +533,17 @@ static void __init of_syscon_icst_setup(struct device_node *np) ...@@ -533,15 +533,17 @@ static void __init of_syscon_icst_setup(struct device_node *np)
icst_desc.params = &icst525_apcp_cm_params; icst_desc.params = &icst525_apcp_cm_params;
ctype = ICST_INTEGRATOR_CP_CM_MEM; ctype = ICST_INTEGRATOR_CP_CM_MEM;
} else { } else {
pr_err("unknown ICST clock %s\n", name); pr_err("unknown ICST clock %pOF\n", np);
return; return;
} }
/* Parent clock name is not the same as node parent */ /* Parent clock name is not the same as node parent */
parent_name = of_clk_get_parent_name(np, 0); parent_name = of_clk_get_parent_name(np, 0);
name = kasprintf(GFP_KERNEL, "%pOFP", np);
regclk = icst_clk_setup(NULL, &icst_desc, name, parent_name, map, ctype); regclk = icst_clk_setup(NULL, &icst_desc, name, parent_name, map, ctype);
if (IS_ERR(regclk)) { if (IS_ERR(regclk)) {
kfree(name);
pr_err("error setting up syscon ICST clock %s\n", name); pr_err("error setting up syscon ICST clock %s\n", name);
return; return;
} }
......
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