Re: [PATCH] clk: mmp: pxa168: Fix memory leak in pxa168_clk_init()

From: Conor Dooley
Date: Mon Dec 11 2023 - 08:20:13 EST


On Mon, Dec 11, 2023 at 01:52:32AM +0800, Kuan-Wei Chiu wrote:
> In cases where mapping of mpmu/apmu/apbc registers fails, the code path
> does not handle the failure gracefully, potentially leading to a memory
> leak. This fix ensures proper cleanup by freeing the allocated memory
> for 'pxa_unit' before returning.
>
> Signed-off-by: Kuan-Wei Chiu <visitorckw@xxxxxxxxx>

I dunno why you have CCed me on this tbh, I guess I must have acked a
patch related to this driver's bindings somehow.

I wonder, is there actually any point in freeing these, isn't the system
going to fail to actually boot if these allocations fail?

> ---
> drivers/clk/mmp/clk-of-pxa168.c | 3 +++
> 1 file changed, 3 insertions(+)
>
> diff --git a/drivers/clk/mmp/clk-of-pxa168.c b/drivers/clk/mmp/clk-of-pxa168.c
> index fb0df64cf053..c5a7ba1deaa3 100644
> --- a/drivers/clk/mmp/clk-of-pxa168.c
> +++ b/drivers/clk/mmp/clk-of-pxa168.c
> @@ -308,18 +308,21 @@ static void __init pxa168_clk_init(struct device_node *np)
> pxa_unit->mpmu_base = of_iomap(np, 0);
> if (!pxa_unit->mpmu_base) {
> pr_err("failed to map mpmu registers\n");
> + kfree(pxa_unit);
> return;
> }
>
> pxa_unit->apmu_base = of_iomap(np, 1);
> if (!pxa_unit->apmu_base) {
> pr_err("failed to map apmu registers\n");
> + kfree(pxa_unit);
> return;
> }
>
> pxa_unit->apbc_base = of_iomap(np, 2);
> if (!pxa_unit->apbc_base) {
> pr_err("failed to map apbc registers\n");
> + kfree(pxa_unit);
> return;
> }
>
> --
> 2.25.1
>

Attachment: signature.asc
Description: PGP signature