clk: imx: composite-8m: Less function calls in __imx8m_clk_hw_composite() after error...
authorMarkus Elfring <elfring@users.sourceforge.net>
Fri, 22 Dec 2023 15:48:24 +0000 (16:48 +0100)
committerAbel Vesa <abel.vesa@linaro.org>
Mon, 26 Feb 2024 08:58:42 +0000 (10:58 +0200)
The function “kfree” was called in up to three cases
by the function “__imx8m_clk_hw_composite” during error handling
even if the passed variables contained a null pointer.

Adjust jump targets according to the Linux coding style convention.

Signed-off-by: Markus Elfring <elfring@users.sourceforge.net>
Reviewed-by: Peng Fan <peng.fan@nxp.com>
Link: https://lore.kernel.org/r/147ca1e6-69f3-4586-b5b3-b69f9574a862@web.de
Signed-off-by: Abel Vesa <abel.vesa@linaro.org>
drivers/clk/imx/clk-composite-8m.c

index 27a08c50ac1d84dc31d8a1684f14a6e5401c951f..eb5392f7a2574955c87b602923a3c46d8b2b960d 100644 (file)
@@ -220,7 +220,7 @@ struct clk_hw *__imx8m_clk_hw_composite(const char *name,
 
        mux = kzalloc(sizeof(*mux), GFP_KERNEL);
        if (!mux)
-               goto fail;
+               return ERR_CAST(hw);
 
        mux_hw = &mux->hw;
        mux->reg = reg;
@@ -230,7 +230,7 @@ struct clk_hw *__imx8m_clk_hw_composite(const char *name,
 
        div = kzalloc(sizeof(*div), GFP_KERNEL);
        if (!div)
-               goto fail;
+               goto free_mux;
 
        div_hw = &div->hw;
        div->reg = reg;
@@ -260,7 +260,7 @@ struct clk_hw *__imx8m_clk_hw_composite(const char *name,
        if (!mcore_booted) {
                gate = kzalloc(sizeof(*gate), GFP_KERNEL);
                if (!gate)
-                       goto fail;
+                       goto free_div;
 
                gate_hw = &gate->hw;
                gate->reg = reg;
@@ -272,13 +272,15 @@ struct clk_hw *__imx8m_clk_hw_composite(const char *name,
                        mux_hw, mux_ops, div_hw,
                        divider_ops, gate_hw, &clk_gate_ops, flags);
        if (IS_ERR(hw))
-               goto fail;
+               goto free_gate;
 
        return hw;
 
-fail:
+free_gate:
        kfree(gate);
+free_div:
        kfree(div);
+free_mux:
        kfree(mux);
        return ERR_CAST(hw);
 }