]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
stm class: Fix a double free in stm_register_device()
authorDan Carpenter <dan.carpenter@linaro.org>
Mon, 29 Apr 2024 13:01:05 +0000 (16:01 +0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 4 May 2024 16:57:21 +0000 (18:57 +0200)
The put_device(&stm->dev) call will trigger stm_device_release() which
frees "stm" so the vfree(stm) on the next line is a double free.

Fixes: 389b6699a2aa ("stm class: Fix stm device initialization order")
Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
Reviewed-by: Amelie Delaunay <amelie.delaunay@foss.st.com>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Link: https://lore.kernel.org/r/20240429130119.1518073-2-alexander.shishkin@linux.intel.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/hwtracing/stm/core.c

index 534fbefc7f6aab2882a256b53d5d6d9919c94b2b..20895d39156236d19ff88cfeaab13f59b26110bd 100644 (file)
@@ -868,8 +868,11 @@ int stm_register_device(struct device *parent, struct stm_data *stm_data,
                return -ENOMEM;
 
        stm->major = register_chrdev(0, stm_data->name, &stm_fops);
-       if (stm->major < 0)
-               goto err_free;
+       if (stm->major < 0) {
+               err = stm->major;
+               vfree(stm);
+               return err;
+       }
 
        device_initialize(&stm->dev);
        stm->dev.devt = MKDEV(stm->major, 0);
@@ -913,10 +916,8 @@ int stm_register_device(struct device *parent, struct stm_data *stm_data,
 err_device:
        unregister_chrdev(stm->major, stm_data->name);
 
-       /* matches device_initialize() above */
+       /* calls stm_device_release() */
        put_device(&stm->dev);
-err_free:
-       vfree(stm);
 
        return err;
 }