Commit 4974259e authored by James Liao's avatar James Liao Committed by Stephen Boyd

clk: mediatek: Fix memory leak on clock init fail

mtk_clk_register_composite() may leak memory due to some error
handling path don't free all allocated memory. This patch
free all pointers that may allocate memory before error return.
And it's safe because kfree() can handle NULL pointers.
Signed-off-by: default avatarJames Liao <jamesjj.liao@mediatek.com>
Reviewed-by: default avatarDaniel Kurtz <djkurtz@chromium.org>
Signed-off-by: default avatarStephen Boyd <sboyd@codeaurora.org>
parent 5fd9c05c
...@@ -209,12 +209,14 @@ struct clk * __init mtk_clk_register_composite(const struct mtk_composite *mc, ...@@ -209,12 +209,14 @@ struct clk * __init mtk_clk_register_composite(const struct mtk_composite *mc,
mc->flags); mc->flags);
if (IS_ERR(clk)) { if (IS_ERR(clk)) {
kfree(gate); ret = PTR_ERR(clk);
kfree(mux); goto err_out;
} }
return clk; return clk;
err_out: err_out:
kfree(div);
kfree(gate);
kfree(mux); kfree(mux);
return ERR_PTR(ret); return ERR_PTR(ret);
......
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