CVE-2024-40943

Source
https://cve.org/CVERecord?id=CVE-2024-40943
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2024-40943.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2024-40943
Downstream
Related
Published
2024-07-12T12:25:17.813Z
Modified
2026-03-14T12:35:03.132223Z
Summary
ocfs2: fix races between hole punching and AIO+DIO
Details

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

ocfs2: fix races between hole punching and AIO+DIO

After commit "ocfs2: return real error code in ocfs2diowrgetblock", fstests/generic/300 become from always failed to sometimes failed:

======================================================================== [ 473.293420 ] run fstests generic/300

[ 475.296983 ] JBD2: Ignoring recovery information on journal [ 475.302473 ] ocfs2: Mounting device (253,1) on (node local, slot 0) with ordered data mode. [ 494.290998 ] OCFS2: ERROR (device dm-1): ocfs2changeextentflag: Owner 5668 has an extent at cpos 78723 which can no longer be found [ 494.291609 ] On-disk corruption discovered. Please run fsck.ocfs2 once the filesystem is unmounted. [ 494.292018 ] OCFS2: File system is now read-only. [ 494.292224 ] (kworker/19:11,2628,19):ocfs2markextentwritten:5272 ERROR: status = -30 [ 494.292602 ] (kworker/19:11,2628,19):ocfs2dioendiowrite:2374 ERROR: status = -3

fio: io_u error on file /mnt/scratch/racer: Read-only file system: write offset=460849152, buflen=131072

In __blockdevdirectIO, ocfs2diowrgetblock is called to add unwritten extents to a list. extents are also inserted into extent tree in ocfs2writebeginnolock. Then another thread call fallocate to puch a hole at one of the unwritten extent. The extent at cpos was removed by ocfs2removeextent(). At end io worker thread, ocfs2searchextentlist found there is no such extent at the cpos.

T1                        T2                T3
                          inode lock
                            ...
                            insert extents
                            ...
                          inode unlock

ocfs2_fallocate _ocfs2changefilespace inode lock lock ipallocsem ocfs2removeinoderange inode ocfs2removebtreerange ocfs2removeextent ^---remove the extent at cpos 78723 ... unlock ipallocsem inode unlock ocfs2dioendio ocfs2dioendiowrite lock ipallocsem ocfs2markextentwritten ocfs2changeextentflag ocfs2searchextentlist ^---failed to find extent ... unlock ipallocsem

In most filesystems, fallocate is not compatible with racing with AIO+DIO, so fix it by adding to wait for all dio before fallocate/punch_hole like ext4.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2024/40xxx/CVE-2024-40943.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
b25801038da5823bba1b5440a57ca68afc51b6bd
Fixed
3c26b5d21b1239e9c7fd31ba7d9b2d7bdbaa68d9
Fixed
e8e2db1adac47970a6a9225f3858e9aa0e86287f
Fixed
050ce8af6838c71e872e982b50d3f1bec21da40e
Fixed
38825ff9da91d2854dcf6d9ac320a7e641e10f25
Fixed
ea042dc2bea19d72e37c298bf65a9c341ef3fff3
Fixed
3c361f313d696df72f9bccf058510e9ec737b9b1
Fixed
117b9c009b72a6c2ebfd23484354dfee2d9570d2
Fixed
952b023f06a24b2ad6ba67304c4c84d45bea2f18

Database specific

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