CVE-2024-42105

Source
https://cve.org/CVERecord?id=CVE-2024-42105
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-42105.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-42105
Downstream
Related
Published
2024-07-30T07:46:01.061Z
Modified
2026-03-20T12:38:41.093847Z
Summary
nilfs2: fix inode number range checks
Details

In the Linux kernel, the following vulnerability has been resolved:

nilfs2: fix inode number range checks

Patch series "nilfs2: fix potential issues related to reserved inodes".

This series fixes one use-after-free issue reported by syzbot, caused by nilfs2's internal inode being exposed in the namespace on a corrupted filesystem, and a couple of flaws that cause problems if the starting number of non-reserved inodes written in the on-disk super block is intentionally (or corruptly) changed from its default value.

This patch (of 3):

In the current implementation of nilfs2, "nilfs->nsfirstino", which gives the first non-reserved inode number, is read from the superblock, but its lower limit is not checked.

As a result, if a number that overlaps with the inode number range of reserved inodes such as the root directory or metadata files is set in the super block parameter, the inode number test macros (NILFSMDTINODE and NILFSVALIDINODE) will not function properly.

In addition, these test macros use left bit-shift calculations using with the inode number as the shift count via the BIT macro, but the result of a shift calculation that exceeds the bit width of an integer is undefined in the C specification, so if "nsfirstino" is set to a large value other than the default value NILFSUSERINO (=11), the macros may potentially malfunction depending on the environment.

Fix these issues by checking the lower bound of "nilfs->nsfirstino" and by preventing bit shifts equal to or greater than the NILFSUSERINO constant in the inode number test macros.

Also, change the type of "nsfirstino" from signed integer to unsigned integer to avoid the need for type casting in comparisons such as the lower bound check introduced this time.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2024/42xxx/CVE-2024-42105.json",
    "cna_assigner": "Linux"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
8a9d2191e9f43bbcd256a9a6871bd73434c83f2f
Fixed
57235c3c88bb430043728d0d02f44a4efe386476
Fixed
08cab183a624ba71603f3754643ae11cab34dbc4
Fixed
731011ac6c37cbe97ece229fc6daa486276052c5
Fixed
3be4dcc8d7bea52ea41f87aa4bbf959efe7a5987
Fixed
fae1959d6ab2c52677b113935e36ab4e25df37ea
Fixed
9194f8ca57527958bee207919458e372d638d783
Fixed
1c91058425a01131ea30dda6cf43c67b17884d6a
Fixed
e2fec219a36e0993642844be0f345513507031f4

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-42105.json"