We use these services and cookies to improve your user experience. You may opt out if you wish, however, this may limit some features on this site.

Please see our statement on Data Privacy.

Crisp.chat (Helpdesk and Chat)

Ok

THREATINT
PUBLISHED

CVE-2024-56693

brd: defer automatic disk creation until module initialization succeeds



Description

In the Linux kernel, the following vulnerability has been resolved: brd: defer automatic disk creation until module initialization succeeds My colleague Wupeng found the following problems during fault injection: BUG: unable to handle page fault for address: fffffbfff809d073 PGD 6e648067 P4D 123ec8067 PUD 123ec4067 PMD 100e38067 PTE 0 Oops: Oops: 0000 [#1] PREEMPT SMP KASAN NOPTI CPU: 5 UID: 0 PID: 755 Comm: modprobe Not tainted 6.12.0-rc3+ #17 Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.16.1-2.fc37 04/01/2014 RIP: 0010:__asan_load8+0x4c/0xa0 ... Call Trace: <TASK> blkdev_put_whole+0x41/0x70 bdev_release+0x1a3/0x250 blkdev_release+0x11/0x20 __fput+0x1d7/0x4a0 task_work_run+0xfc/0x180 syscall_exit_to_user_mode+0x1de/0x1f0 do_syscall_64+0x6b/0x170 entry_SYSCALL_64_after_hwframe+0x76/0x7e loop_init() is calling loop_add() after __register_blkdev() succeeds and is ignoring disk_add() failure from loop_add(), for loop_add() failure is not fatal and successfully created disks are already visible to bdev_open(). brd_init() is currently calling brd_alloc() before __register_blkdev() succeeds and is releasing successfully created disks when brd_init() returns an error. This can cause UAF for the latter two case: case 1: T1: modprobe brd brd_init brd_alloc(0) // success add_disk disk_scan_partitions bdev_file_open_by_dev // alloc file fput // won't free until back to userspace brd_alloc(1) // failed since mem alloc error inject // error path for modprobe will release code segment // back to userspace __fput blkdev_release bdev_release blkdev_put_whole bdev->bd_disk->fops->release // fops is freed now, UAF! case 2: T1: T2: modprobe brd brd_init brd_alloc(0) // success open(/dev/ram0) brd_alloc(1) // fail // error path for modprobe close(/dev/ram0) ... /* UAF! */ bdev->bd_disk->fops->release Fix this problem by following what loop_init() does. Besides, reintroduce brd_devices_mutex to help serialize modifications to brd_list.

Reserved 2024-12-27 | Published 2024-12-28 | Updated 2025-01-20 | Assigner Linux

Product status

Default status
unaffected

7f9b348cb5e94259acdcbafbcaed55d3bb515304 before 41219c147df8bbd6591f59af5d695fb6c9a1cbff
affected

7f9b348cb5e94259acdcbafbcaed55d3bb515304 before 259bf925583ec9e3781df778cadf00594095090d
affected

7f9b348cb5e94259acdcbafbcaed55d3bb515304 before 410896624db639500f24f46478b4bfa05c76bf56
affected

7f9b348cb5e94259acdcbafbcaed55d3bb515304 before c0c2744cd2939ec5999c51dbaf2af16886548b7b
affected

7f9b348cb5e94259acdcbafbcaed55d3bb515304 before 63dfd728b30f79495dacc886127695a379805152
affected

7f9b348cb5e94259acdcbafbcaed55d3bb515304 before 826cc42adf44930a633d11a5993676d85ddb0842
affected

Default status
affected

5.14
affected

Any version before 5.14
unaffected

5.15.174
unaffected

6.1.120
unaffected

6.6.64
unaffected

6.11.11
unaffected

6.12.2
unaffected

6.13
unaffected

References

git.kernel.org/...c/41219c147df8bbd6591f59af5d695fb6c9a1cbff

git.kernel.org/...c/259bf925583ec9e3781df778cadf00594095090d

git.kernel.org/...c/410896624db639500f24f46478b4bfa05c76bf56

git.kernel.org/...c/c0c2744cd2939ec5999c51dbaf2af16886548b7b

git.kernel.org/...c/63dfd728b30f79495dacc886127695a379805152

git.kernel.org/...c/826cc42adf44930a633d11a5993676d85ddb0842

cve.org (CVE-2024-56693)

nvd.nist.gov (CVE-2024-56693)

Download JSON

Share this page
https://cve.threatint.com/CVE/CVE-2024-56693

Support options

Helpdesk Chat, Email, Knowledgebase
Subscribe to our newsletter to learn more about our work.