]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
clk: st: Fix memory leak in st_of_quadfs_setup()
authorXiu Jianfeng <xiujianfeng@huawei.com>
Tue, 22 Nov 2022 13:36:14 +0000 (21:36 +0800)
committerStephen Boyd <sboyd@kernel.org>
Thu, 8 Dec 2022 02:27:11 +0000 (18:27 -0800)
If st_clk_register_quadfs_pll() fails, @lock should be freed before goto
@err_exit, otherwise will cause meory leak issue, fix it.

Signed-off-by: Xiu Jianfeng <xiujianfeng@huawei.com>
Link: https://lore.kernel.org/r/20221122133614.184910-1-xiujianfeng@huawei.com
Reviewed-by: Patrice Chotard <patrice.chotard@foss.st.com>
Signed-off-by: Stephen Boyd <sboyd@kernel.org>
drivers/clk/st/clkgen-fsyn.c

index d820292a381d0a78c818775b9b316c17f2d79e78..40df1db102a77bbe5144d42f6e05361b66634e9a 100644 (file)
@@ -1020,9 +1020,10 @@ static void __init st_of_quadfs_setup(struct device_node *np,
 
        clk = st_clk_register_quadfs_pll(pll_name, clk_parent_name, datac->data,
                        reg, lock);
-       if (IS_ERR(clk))
+       if (IS_ERR(clk)) {
+               kfree(lock);
                goto err_exit;
-       else
+       else
                pr_debug("%s: parent %s rate %u\n",
                        __clk_get_name(clk),
                        __clk_get_name(clk_get_parent(clk)),