mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2025-01-20 14:37:56 +07:00
clk: sunxi: Make clocks setup functions return their clock
The clocks registration code in clk-sunxi was most of the time not returning the struct clk (or struct clk array) that was registered, preventing the users of such functions to manipulate it, for example to protect it. Make them return it so that we can start using it. Signed-off-by: Maxime Ripard <maxime.ripard@free-electrons.com>
This commit is contained in:
parent
d221b7a878
commit
96f185ac9a
@ -615,8 +615,8 @@ static const struct mux_data sun8i_h3_ahb2_mux_data __initconst = {
|
|||||||
.shift = 0,
|
.shift = 0,
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init sunxi_mux_clk_setup(struct device_node *node,
|
static struct clk * __init sunxi_mux_clk_setup(struct device_node *node,
|
||||||
struct mux_data *data)
|
struct mux_data *data)
|
||||||
{
|
{
|
||||||
struct clk *clk;
|
struct clk *clk;
|
||||||
const char *clk_name = node->name;
|
const char *clk_name = node->name;
|
||||||
@ -646,10 +646,12 @@ static void __init sunxi_mux_clk_setup(struct device_node *node,
|
|||||||
|
|
||||||
of_clk_add_provider(node, of_clk_src_simple_get, clk);
|
of_clk_add_provider(node, of_clk_src_simple_get, clk);
|
||||||
clk_register_clkdev(clk, clk_name, NULL);
|
clk_register_clkdev(clk, clk_name, NULL);
|
||||||
return;
|
|
||||||
|
return clk;
|
||||||
|
|
||||||
out_unmap:
|
out_unmap:
|
||||||
iounmap(reg);
|
iounmap(reg);
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -820,8 +822,8 @@ static const struct divs_data sun6i_a31_pll6_divs_data __initconst = {
|
|||||||
* |________________________|
|
* |________________________|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static void __init sunxi_divs_clk_setup(struct device_node *node,
|
static struct clk ** __init sunxi_divs_clk_setup(struct device_node *node,
|
||||||
struct divs_data *data)
|
struct divs_data *data)
|
||||||
{
|
{
|
||||||
struct clk_onecell_data *clk_data;
|
struct clk_onecell_data *clk_data;
|
||||||
const char *parent;
|
const char *parent;
|
||||||
@ -848,7 +850,7 @@ static void __init sunxi_divs_clk_setup(struct device_node *node,
|
|||||||
|
|
||||||
clk_data = kmalloc(sizeof(struct clk_onecell_data), GFP_KERNEL);
|
clk_data = kmalloc(sizeof(struct clk_onecell_data), GFP_KERNEL);
|
||||||
if (!clk_data)
|
if (!clk_data)
|
||||||
return;
|
return NULL;
|
||||||
|
|
||||||
clks = kcalloc(ndivs, sizeof(*clks), GFP_KERNEL);
|
clks = kcalloc(ndivs, sizeof(*clks), GFP_KERNEL);
|
||||||
if (!clks)
|
if (!clks)
|
||||||
@ -934,7 +936,7 @@ static void __init sunxi_divs_clk_setup(struct device_node *node,
|
|||||||
|
|
||||||
of_clk_add_provider(node, of_clk_src_onecell_get, clk_data);
|
of_clk_add_provider(node, of_clk_src_onecell_get, clk_data);
|
||||||
|
|
||||||
return;
|
return clks;
|
||||||
|
|
||||||
free_gate:
|
free_gate:
|
||||||
kfree(gate);
|
kfree(gate);
|
||||||
@ -942,6 +944,7 @@ static void __init sunxi_divs_clk_setup(struct device_node *node,
|
|||||||
kfree(clks);
|
kfree(clks);
|
||||||
free_clkdata:
|
free_clkdata:
|
||||||
kfree(clk_data);
|
kfree(clk_data);
|
||||||
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user