Commit 8c6239f6 authored by Zhang Qilong's avatar Zhang Qilong Committed by Stephen Boyd

clk: ti: Fix memleak in ti_fapll_synth_setup

If clk_register fails, we should goto free branch
before function returns to prevent memleak.

Fixes: 163152cb ("clk: ti: Add support for FAPLL on dm816x")
Reported-by: default avatarHulk Robot <hulkci@huawei.com>
Signed-off-by: default avatarZhang Qilong <zhangqilong3@huawei.com>
Link: https://lore.kernel.org/r/20201113131623.2098222-1-zhangqilong3@huawei.comAcked-by: default avatarTony Lindgren <tony@atomide.com>
Signed-off-by: default avatarStephen Boyd <sboyd@kernel.org>
parent 3650b228
...@@ -498,6 +498,7 @@ static struct clk * __init ti_fapll_synth_setup(struct fapll_data *fd, ...@@ -498,6 +498,7 @@ static struct clk * __init ti_fapll_synth_setup(struct fapll_data *fd,
{ {
struct clk_init_data *init; struct clk_init_data *init;
struct fapll_synth *synth; struct fapll_synth *synth;
struct clk *clk = ERR_PTR(-ENOMEM);
init = kzalloc(sizeof(*init), GFP_KERNEL); init = kzalloc(sizeof(*init), GFP_KERNEL);
if (!init) if (!init)
...@@ -520,13 +521,19 @@ static struct clk * __init ti_fapll_synth_setup(struct fapll_data *fd, ...@@ -520,13 +521,19 @@ static struct clk * __init ti_fapll_synth_setup(struct fapll_data *fd,
synth->hw.init = init; synth->hw.init = init;
synth->clk_pll = pll_clk; synth->clk_pll = pll_clk;
return clk_register(NULL, &synth->hw); clk = clk_register(NULL, &synth->hw);
if (IS_ERR(clk)) {
pr_err("failed to register clock\n");
goto free;
}
return clk;
free: free:
kfree(synth); kfree(synth);
kfree(init); kfree(init);
return ERR_PTR(-ENOMEM); return clk;
} }
static void __init ti_fapll_setup(struct device_node *node) static void __init ti_fapll_setup(struct device_node *node)
......
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