CVE-2024-42104

high

Description

In the Linux kernel, the following vulnerability has been resolved: nilfs2: add missing check for inode numbers on directory entries Syzbot reported that mounting and unmounting a specific pattern of corrupted nilfs2 filesystem images causes a use-after-free of metadata file inodes, which triggers a kernel bug in lru_add_fn(). As Jan Kara pointed out, this is because the link count of a metadata file gets corrupted to 0, and nilfs_evict_inode(), which is called from iput(), tries to delete that inode (ifile inode in this case). The inconsistency occurs because directories containing the inode numbers of these metadata files that should not be visible in the namespace are read without checking. Fix this issue by treating the inode numbers of these internal files as errors in the sanity check helper when reading directory folios/pages. Also thanks to Hillf Danton and Matthew Wilcox for their initial mm-layer analysis.

References

https://git.kernel.org/stable/c/c33c2b0d92aa1c2262d999b2598ad6fbd53bd479

https://git.kernel.org/stable/c/bb76c6c274683c8570ad788f79d4b875bde0e458

https://git.kernel.org/stable/c/b11e8fb93ea5eefb2e4e719497ea177a58ff6131

https://git.kernel.org/stable/c/3ab40870edb883b9633dc5cd55f5a2a11afa618d

https://git.kernel.org/stable/c/2f2fa9cf7c3537958a82fbe8c8595a5eb0861ad7

https://git.kernel.org/stable/c/265fff1a01cdc083aeaf0d934c929db5cc64aebf

https://git.kernel.org/stable/c/1b7d549ed2c1fa202c751b69423a0d3a6bd5a180

https://git.kernel.org/stable/c/07c176e7acc5579c133bb923ab21316d192d0a95

Details

Source: Mitre, NVD

Published: 2024-07-30

Updated: 2024-08-27

Risk Information

CVSS v2

Base Score: 6.8

Vector: CVSS2#AV:L/AC:L/Au:S/C:C/I:C/A:C

Severity: Medium

CVSS v3

Base Score: 7.8

Vector: CVSS:3.0/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

Severity: High