Commit 615c6e82 authored by Dan Carpenter's avatar Dan Carpenter Committed by Guo Mengqi
Browse files

stm class: Fix a double free in stm_register_device()

stable inclusion
from stable-v5.10.219
commit 713fc00c571dde4af3db2dbd5d1b0eadc327817b
category: bugfix
bugzilla: https://gitee.com/src-openeuler/kernel/issues/IA7D3T
CVE: CVE-2024-38627

Reference: https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git/commit/?id=713fc00c571dde4af3db2dbd5d1b0eadc327817b



--------------------------------

[ Upstream commit 3df463865ba42b8f88a590326f4c9ea17a1ce459 ]

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: 389b6699 ("stm class: Fix stm device initialization order")
Signed-off-by: default avatarDan Carpenter <dan.carpenter@linaro.org>
Reviewed-by: default avatarAmelie Delaunay <amelie.delaunay@foss.st.com>
Reviewed-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: default avatarAlexander Shishkin <alexander.shishkin@linux.intel.com>
Link: https://lore.kernel.org/r/20240429130119.1518073-2-alexander.shishkin@linux.intel.com


Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarSasha Levin <sashal@kernel.org>
Signed-off-by: default avatarWang Wensheng <wangwensheng4@huawei.com>
parent 12511146
Loading
Loading
Loading
Loading
+6 −5
Original line number Diff line number Diff line
@@ -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;
}