CVE-2025-38172 Information
Description
In the Linux kernel the following vulnerability has been resolved:
erofs: avoid using multiple devices with different type
For multiple devices both primary and extra devices should be the
same type. erofs_init_device has already guaranteed that if the
primary is a file-backed device extra devices should also be
regular files.
However if the primary is a block device while the extra device
is a file-backed device erofs_init_device will get an ENOTBLK
which is not treated as an error in erofs_fc_get_tree and that
leads to an UAF:
erofs_fc_get_tree get_tree_bdev_flags(erofs_fc_fill_super) erofs_read_superblock erofs_init_device // sbi->dif0 is not inited yet // return -ENOTBLK deactivate_locked_super free(sbi) if (err is -ENOTBLK) sbi->dif0.file = filp_open() // sbi UAF
So if -ENOTBLK is hitted in erofs_init_device it means the
primary device must be a block device and the extra device
is not a block device. The error can be converted to -EINVAL.
Reference
https://git.kernel.org/stable/c/65115472f741ca000d7ea4a5922214f93cd1516e https://git.kernel.org/stable/c/9748f2f54f66743ac77275c34886a9f890e18409 https://git.kernel.org/stable/c/cd04beb9ce2773a16057248bb4fa424068ae3807
Related CNNVD
CNNVD-202507-259 (Published: 2025-07-03)
Share on: