]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
usb: dwc3: of-simple: fix clock resource leak in dwc3_of_simple_probe
authorMiaoqian Lin <linmq006@gmail.com>
Thu, 11 Dec 2025 06:49:36 +0000 (10:49 +0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 17 Dec 2025 13:54:38 +0000 (14:54 +0100)
When clk_bulk_prepare_enable() fails, the error path jumps to
err_resetc_assert, skipping clk_bulk_put_all() and leaking the
clock references acquired by clk_bulk_get_all().

Add err_clk_put_all label to properly release clock resources
in all error paths.

Found via static analysis and code review.

Fixes: c0c61471ef86 ("usb: dwc3: of-simple: Convert to bulk clk API")
Cc: stable <stable@kernel.org>
Signed-off-by: Miaoqian Lin <linmq006@gmail.com>
Acked-by: Thinh Nguyen <Thinh.Nguyen@synopsys.com>
Link: https://patch.msgid.link/20251211064937.2360510-1-linmq006@gmail.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/usb/dwc3/dwc3-of-simple.c

index a4954a21be9301067a13ac99b17320ea49d76d66..c116143335d9f97086c7cfdc3b26b738858fdc27 100644 (file)
@@ -70,11 +70,11 @@ static int dwc3_of_simple_probe(struct platform_device *pdev)
        simple->num_clocks = ret;
        ret = clk_bulk_prepare_enable(simple->num_clocks, simple->clks);
        if (ret)
-               goto err_resetc_assert;
+               goto err_clk_put_all;
 
        ret = of_platform_populate(np, NULL, NULL, dev);
        if (ret)
-               goto err_clk_put;
+               goto err_clk_disable;
 
        pm_runtime_set_active(dev);
        pm_runtime_enable(dev);
@@ -82,8 +82,9 @@ static int dwc3_of_simple_probe(struct platform_device *pdev)
 
        return 0;
 
-err_clk_put:
+err_clk_disable:
        clk_bulk_disable_unprepare(simple->num_clocks, simple->clks);
+err_clk_put_all:
        clk_bulk_put_all(simple->num_clocks, simple->clks);
 
 err_resetc_assert: