CVE-2024-50280

HIGH

Linux Kernel 4.9.337-4.10 - Use-After-Free in dm cache error path

Title source: llm
STIX 2.1

Description

In the Linux kernel, the following vulnerability has been resolved: dm cache: fix flushing uninitialized delayed_work on cache_ctr error An unexpected WARN_ON from flush_work() may occur when cache creation fails, caused by destroying the uninitialized delayed_work waker in the error path of cache_create(). For example, the warning appears on the superblock checksum error. Reproduce steps: dmsetup create cmeta --table "0 8192 linear /dev/sdc 0" dmsetup create cdata --table "0 65536 linear /dev/sdc 8192" dmsetup create corig --table "0 524288 linear /dev/sdc 262144" dd if=/dev/urandom of=/dev/mapper/cmeta bs=4k count=1 oflag=direct dmsetup create cache --table "0 524288 cache /dev/mapper/cmeta \ /dev/mapper/cdata /dev/mapper/corig 128 2 metadata2 writethrough smq 0" Kernel logs: (snip) WARNING: CPU: 0 PID: 84 at kernel/workqueue.c:4178 __flush_work+0x5d4/0x890 Fix by pulling out the cancel_delayed_work_sync() from the constructor's error path. This patch doesn't affect the use-after-free fix for concurrent dm_resume and dm_destroy (commit 6a459d8edbdb ("dm cache: Fix UAF in destroy()")) as cache_dtr is not changed.

Scores

CVSS v3 7.8
EPSS 0.0024
EPSS Percentile 15.5%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

CISA SSVC

Vulnrichment
Exploitation none
Automatable no
Technical Impact total

Details

CWE
CWE-416
Status published
Products (29)
Linux/Linux < 6.2
Linux/Linux 034cbc8d3b47a56acd89453c29632a9c117de09d
Linux/Linux 2b17026685a270b2beaf1cdd9857fcedd3505c7e - 40fac0271c7aedf60d81ed8214e80851e5b26312
Linux/Linux 2f097dfac7579fd84ff98eb1d3acd41d53a485f3
Linux/Linux 4.14.303 - 4.15
Linux/Linux 4.19.270 - 4.20
Linux/Linux 4.9.337 - 4.10
Linux/Linux 4d20032dd90664de09f2902a7ea49ae2f7771746
Linux/Linux 5.10.163 - 5.10.237
Linux/Linux 5.10.237 - 5.10.*
... and 19 more
Published Nov 19, 2024
Tracked Since Feb 18, 2026