CVE-2024-26982

Source
https://cve.org/CVERecord?id=CVE-2024-26982
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-26982.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-26982
Downstream
Related
Published
2024-05-01T05:27:11.032Z
Modified
2026-03-13T07:52:01.060675Z
Summary
Squashfs: check the inode number is not the invalid value of zero
Details

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

Squashfs: check the inode number is not the invalid value of zero

Syskiller has produced an out of bounds access in fillmetaindex().

That out of bounds access is ultimately caused because the inode has an inode number with the invalid value of zero, which was not checked.

The reason this causes the out of bounds access is due to following sequence of events:

  1. Fillmetaindex() is called to allocate (via emptymetaindex()) and fill a metadata index. It however suffers a data read error and aborts, invalidating the newly returned empty metadata index. It does this by setting the inode number of the index to zero, which means unused (zero is not a valid inode number).

  2. When fillmetaindex() is subsequently called again on another read operation, locatemetaindex() returns the previous index because it matches the inode number of 0. Because this index has been returned it is expected to have been filled, and because it hasn't been, an out of bounds access is performed.

This patch adds a sanity check which checks that the inode number is not zero when the inode is created and returns -EINVAL if it is.

[phillip@squashfs.org.uk: whitespace fix]

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2024/26xxx/CVE-2024-26982.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
6545b246a2c815a8fcd07d58240effb6ec3481b1
Fixed
32c114a58236fe67141634774559f21f1dc96fd7
Fixed
4a1b6f89825e267e156ccaeba3d235edcac77f94
Fixed
cf46f88b92cfc0e32bd8a21ba1273cff13b8745f
Fixed
5b99dea79650b50909c50aba24fbae00f203f013
Fixed
be383effaee3d89034f0828038f95065b518772e
Fixed
7def00ebc9f2d6a581ddf46ce4541f84a10680e5
Fixed
9253c54e01b6505d348afbc02abaa4d9f8a01395

Database specific

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