Re: [PATCH 1/2] platform/x86/intel/tpmi: use cleanup helpers in mem_write()
From: Ilpo Järvinen
Date: Wed May 20 2026 - 06:40:23 EST
On Wed, 20 May 2026, ZhaoJinming wrote:
> In mem_write(), the temporary array returned by parse_int_array_user() must be released on all error paths. Convert the array variable to use cleanup.h scope-based cleanup so it is freed automatically on return.
Not only on "error paths" but also when no error occurs.
> This also moves the array declaration next to parse_int_array_user() as required by cleanup.h usage guidelines.
Please fold any text paragraphs so they don't exceed 72 characters per
row.
> Fixes: 8e0a2fc68ec3 ("platform/x86/intel/tpmi: Use 32 bit aligned address for debugfs mem write")
> Cc: stable@xxxxxxxxxxxxxxx
> Signed-off-by: ZhaoJinming <zhaojinming@xxxxxxxxxxxxx>
> ---
> drivers/platform/x86/intel/vsec_tpmi.c | 26 +++++++++-----------------
> 1 file changed, 9 insertions(+), 17 deletions(-)
>
> diff --git a/drivers/platform/x86/intel/vsec_tpmi.c b/drivers/platform/x86/intel/vsec_tpmi.c
> index 16fd7aa41f20..e7bc3474c7aa 100644
> --- a/drivers/platform/x86/intel/vsec_tpmi.c
> +++ b/drivers/platform/x86/intel/vsec_tpmi.c
> @@ -51,6 +51,7 @@
> #include <linux/bitfield.h>
> #include <linux/debugfs.h>
> #include <linux/delay.h>
> +#include <linux/cleanup.h>
> #include <linux/intel_tpmi.h>
> #include <linux/intel_vsec.h>
> #include <linux/io.h>
> @@ -473,7 +474,7 @@ static ssize_t mem_write(struct file *file, const char __user *userbuf, size_t l
> struct seq_file *m = file->private_data;
> struct intel_tpmi_pm_feature *pfs = m->private;
> u32 addr, value, punit, size;
> - u32 num_elems, *array;
> + u32 num_elems;
> void __iomem *mem;
> int ret;
>
> @@ -481,15 +482,14 @@ static ssize_t mem_write(struct file *file, const char __user *userbuf, size_t l
> if (!size)
> return -EIO;
>
> + u32 *array __free(kfree) = NULL;
> ret = parse_int_array_user(userbuf, len, (int **)&array);
> if (ret < 0)
> return ret;
>
> num_elems = *array;
> - if (num_elems != 3) {
> - ret = -EINVAL;
> - goto exit_write;
> - }
> + if (num_elems != 3)
> + return -EINVAL;
>
> punit = array[1];
> addr = array[2];
> @@ -498,15 +498,11 @@ static ssize_t mem_write(struct file *file, const char __user *userbuf, size_t l
> if (!IS_ALIGNED(addr, sizeof(u32)))
> return -EINVAL;
>
> - if (punit >= pfs->pfs_header.num_entries) {
> - ret = -EINVAL;
> - goto exit_write;
> - }
> + if (punit >= pfs->pfs_header.num_entries)
> + return -EINVAL;
>
> - if (addr >= size) {
> - ret = -EINVAL;
> - goto exit_write;
> - }
> + if (addr >= size)
> + return -EINVAL;
>
> mutex_lock(&tpmi_dev_lock);
>
> @@ -522,12 +518,8 @@ static ssize_t mem_write(struct file *file, const char __user *userbuf, size_t l
>
> ret = len;
>
> -unlock_mem_write:
The last goto is only removed in the second patch so this will cause a
build failure mid-series which would be a problem when using git bisect.
Other than that, this change looked okay.
> mutex_unlock(&tpmi_dev_lock);
>
> -exit_write:
> - kfree(array);
> -
> return ret;
> }
>
>
--
i.