Commit 810251b0 authored by Alain Volmat's avatar Alain Volmat Committed by Stephen Boyd

clk: st: clkgen-mux: search reg within node or parent

In order to avoid having duplicated addresses within the DT,
only have one unit-address per clockgen and each driver within
the clockgen should look at the parent node (overall clockgen)
to figure out the reg property.  Such behavior is already in
place in other STi platform clock drivers such as clk-flexgen
and clkgen-pll.  Keep backward compatibility by first looking
at reg within the node before looking into the parent node.
Signed-off-by: default avatarAlain Volmat <avolmat@me.com>
Link: https://lore.kernel.org/r/20211218211157.188214-3-avolmat@me.comReviewed-by: default avatarPatrice Chotard <patrice.chotard@foss.st.com>
Signed-off-by: default avatarStephen Boyd <sboyd@kernel.org>
parent 3efe64ef
...@@ -57,10 +57,17 @@ static void __init st_of_clkgen_mux_setup(struct device_node *np, ...@@ -57,10 +57,17 @@ static void __init st_of_clkgen_mux_setup(struct device_node *np,
const char **parents; const char **parents;
int num_parents = 0; int num_parents = 0;
/*
* First check for reg property within the node to keep backward
* compatibility, then if reg doesn't exist look at the parent node
*/
reg = of_iomap(np, 0); reg = of_iomap(np, 0);
if (!reg) { if (!reg) {
pr_err("%s: Failed to get base address\n", __func__); reg = of_iomap(of_get_parent(np), 0);
return; if (!reg) {
pr_err("%s: Failed to get base address\n", __func__);
return;
}
} }
parents = clkgen_mux_get_parents(np, &num_parents); parents = clkgen_mux_get_parents(np, &num_parents);
......
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