Description
In the Linux kernel, the following vulnerability has been resolved: platform/x86: classmate-laptop: Add missing NULL pointer checks In a few places in the Classmate laptop driver, code using the accel object may run before that object's address is stored in the driver data of the input device using it. For example, cmpc_accel_sensitivity_store_v4() is the "show" method of cmpc_accel_sensitivity_attr_v4 which is added in cmpc_accel_add_v4(), before calling dev_set_drvdata() for inputdev->dev. If the sysfs attribute is accessed prematurely, the dev_get_drvdata(&inputdev->dev) call in in cmpc_accel_sensitivity_store_v4() returns NULL which leads to a NULL pointer dereference going forward. Moreover, sysfs attributes using the input device are added before initializing that device by cmpc_add_acpi_notify_device() and if one of them is accessed before running that function, a NULL pointer dereference will occur. For example, cmpc_accel_sensitivity_attr_v4 is added before calling cmpc_add_acpi_notify_device() and if it is read prematurely, the dev_get_drvdata(&acpi->dev) call in cmpc_accel_sensitivity_show_v4() returns NULL which leads to a NULL pointer dereference going forward. Fix this by adding NULL pointer checks in all of the relevant places.
Product status
529aa8cb0a59367d08883f818e8c47028e819d0d (git) before 993708fc18d0d0919db438361b4e8c1f980a8d1b
529aa8cb0a59367d08883f818e8c47028e819d0d (git) before af673209d43b46257540997aba042b90ef3258c0
529aa8cb0a59367d08883f818e8c47028e819d0d (git) before eb214804f03c829decf10998e9b7dd26f4c8ab9e
529aa8cb0a59367d08883f818e8c47028e819d0d (git) before 9cf4b9b8ad09d6e05307abc4e951cabdff4be652
529aa8cb0a59367d08883f818e8c47028e819d0d (git) before da6e06a5fdbabea3870d18c227734b5dea5b3be6
529aa8cb0a59367d08883f818e8c47028e819d0d (git) before 97528b1622b8f129574d29a571c32a3c85eafa3c
529aa8cb0a59367d08883f818e8c47028e819d0d (git) before fe747d7112283f47169e9c16e751179a9b38611e
2.6.33
Any version before 2.6.33
5.10.251 (semver)
5.15.201 (semver)
6.1.164 (semver)
6.6.127 (semver)
6.12.74 (semver)
6.18.13 (semver)
6.19 (original_commit_for_fix)
References
git.kernel.org/...c/993708fc18d0d0919db438361b4e8c1f980a8d1b
git.kernel.org/...c/af673209d43b46257540997aba042b90ef3258c0
git.kernel.org/...c/eb214804f03c829decf10998e9b7dd26f4c8ab9e
git.kernel.org/...c/9cf4b9b8ad09d6e05307abc4e951cabdff4be652
git.kernel.org/...c/da6e06a5fdbabea3870d18c227734b5dea5b3be6
git.kernel.org/...c/97528b1622b8f129574d29a571c32a3c85eafa3c
git.kernel.org/...c/fe747d7112283f47169e9c16e751179a9b38611e