Description
In the Linux kernel, the following vulnerability has been resolved: spi: use generic driver_override infrastructure When a driver is probed through __driver_attach(), the bus' match() callback is called without the device lock held, thus accessing the driver_override field without a lock, which can cause a UAF. Fix this by using the driver-core driver_override infrastructure taking care of proper locking internally. Note that calling match() from __driver_attach() without the device lock held is intentional. [1] Also note that we do not enable the driver_override feature of struct bus_type, as SPI - in contrast to most other buses - passes "" to sysfs_emit() when the driver_override pointer is NULL. Thus, printing "\n" instead of "(null)\n".
Product status
5039563e7c25eccd7fec1de6706011009d1c5665 (git) before eedf220442d13b6d97294e5b0ac8a2c38ee1a1a0
5039563e7c25eccd7fec1de6706011009d1c5665 (git) before c73a58661a760373d08a6883af4f0bb5cc991a67
5039563e7c25eccd7fec1de6706011009d1c5665 (git) before e0ae367a2de06c49aa1de6ec9b1ab6860bbb2cf0
5039563e7c25eccd7fec1de6706011009d1c5665 (git) before cc34d77dd48708d810c12bfd6f5bf03304f6c824
4.20
Any version before 4.20
6.12.80 (semver)
6.18.21 (semver)
6.19.11 (semver)
7.0 (original_commit_for_fix)
References
git.kernel.org/...c/eedf220442d13b6d97294e5b0ac8a2c38ee1a1a0
git.kernel.org/...c/c73a58661a760373d08a6883af4f0bb5cc991a67
git.kernel.org/...c/e0ae367a2de06c49aa1de6ec9b1ab6860bbb2cf0
git.kernel.org/...c/cc34d77dd48708d810c12bfd6f5bf03304f6c824