Re: [PATCH] iio: fix memory leak for iio_gts_build_avail_scale_table()

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi Matti,

Thank you for your concern! I haven't used it in my projects yet. I came across this issue while using smatch for code analysis. After reviewing the code, I noticed a few minor issues. However, I did not realize that the patch for the memory leak has already been submitted couple of days ago. Apologies for not checking the patches thoroughly and submitting a duplicate.

Yours,

-- Zicheng

On 2024/10/31 15:32, Matti Vaittinen wrote:
Hi Zicheng

On 31/10/2024 03:47, Zicheng Qu wrote:
In iio_gts_build_avail_scale_table(), the memory allocated for
per_time_gains is freed using kfree(per_time_gains) before return 0.
However, the type per_time_gains is 'int **', and the memory allocated
for its inner elements is not being freed, leading to a memory leak.

Cc: stable@xxxxxxxxxxxxxxx # v6.6+
Fixes: 38416c28e168 ("iio: light: Add gain-time-scale helpers")
Signed-off-by: Zicheng Qu <quzicheng@xxxxxxxxxx>
---
  drivers/iio/industrialio-gts-helper.c | 2 ++
  1 file changed, 2 insertions(+)

diff --git a/drivers/iio/industrialio-gts-helper.c b/drivers/iio/industrialio-gts-helper.c
index 59d7615c0f56..f2450b2e740d 100644
--- a/drivers/iio/industrialio-gts-helper.c
+++ b/drivers/iio/industrialio-gts-helper.c
@@ -307,6 +307,8 @@ static int iio_gts_build_avail_scale_table(struct iio_gts *gts)
      if (ret)
          goto err_free_out;
  +    for (j = 0; j < gts->num_itime; j++)
+        kfree(per_time_gains[i]);
      kfree(per_time_gains);
      gts->per_time_avail_scale_tables = per_time_scales;

You're right, thanks!
This, however, was already fixed by:
https://lore.kernel.org/all/20241011095512.3667549-1-ruanjinjie@xxxxxxxxxx/

Out of the curiosity (and no need to respond if you don't feel like) - are you using the gts helpers in some of your project(s)? I am glad seeing these fixes coming in and just wondered if all these bugs are found because these helpers are being used outside the ROHM drivers :)

Yours,
    -- Matti





[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Input]     [Linux Kernel]     [Linux SCSI]     [X.org]

  Powered by Linux