CVE-2024-37078

Source
https://nvd.nist.gov/vuln/detail/CVE-2024-37078
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-37078.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-37078
Downstream
Related
Published
2024-06-25T14:22:35.558Z
Modified
2025-11-27T02:33:28.820644Z
Summary
nilfs2: fix potential kernel bug due to lack of writeback flag waiting
Details

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

nilfs2: fix potential kernel bug due to lack of writeback flag waiting

Destructive writes to a block device on which nilfs2 is mounted can cause a kernel bug in the folio/page writeback start routine or writeback end routine (_foliostart_writeback in the log below):

kernel BUG at mm/page-writeback.c:3070! Oops: invalid opcode: 0000 [#1] PREEMPT SMP KASAN PTI ... RIP: 0010:_foliostartwriteback+0xbaa/0x10e0 Code: 25 ff 0f 00 00 0f 84 18 01 00 00 e8 40 ca c6 ff e9 17 f6 ff ff e8 36 ca c6 ff 4c 89 f7 48 c7 c6 80 c0 12 84 e8 e7 b3 0f 00 90 <0f> 0b e8 1f ca c6 ff 4c 89 f7 48 c7 c6 a0 c6 12 84 e8 d0 b3 0f 00 ... Call Trace: <TASK> nilfssegctordoconstruct+0x4654/0x69d0 [nilfs2] nilfssegctorconstruct+0x181/0x6b0 [nilfs2] nilfssegctorthread+0x548/0x11c0 [nilfs2] kthread+0x2f0/0x390 retfromfork+0x4b/0x80 retfromfork_asm+0x1a/0x30 </TASK>

This is because when the log writer starts a writeback for segment summary blocks or a super root block that use the backing device's page cache, it does not wait for the ongoing folio/page writeback, resulting in an inconsistent writeback state.

Fix this issue by waiting for ongoing writebacks when putting folios/pages on the backing device into writeback state.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/blob/cc431b3424123d84bcd7afd4de150b33f117a8ef/cves/2024/37xxx/CVE-2024-37078.json"
}
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
9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453
Fixed
95f6f81e50d858a7c9aa7c795ec14a0ac3819118
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453
Fixed
a75b8f493dfc48aa38c518430bd9e03b53bffebe
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453
Fixed
0ecfe3a92869a59668d27228dabbd7965e83567f
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453
Fixed
33900d7eae616647e179eee1c66ebe654ee39627
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453
Fixed
271dcd977ccda8c7a26e360425ae7b4db7d2ecc0
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453
Fixed
614d397be0cf43412b3f94a0f6460eddced8ce92
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453
Fixed
1f3bff69f1214fe03a02bc650d5bbfaa6e65ae7d
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
9ff05123e3bfbb1d2b68ba1d9bf1f7d1dffc1453
Fixed
a4ca369ca221bb7e06c725792ac107f0e48e82e7

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
2.6.30
Fixed
4.19.317
Type
ECOSYSTEM
Events
Introduced
4.20.0
Fixed
5.4.279
Type
ECOSYSTEM
Events
Introduced
5.5.0
Fixed
5.10.221
Type
ECOSYSTEM
Events
Introduced
5.11.0
Fixed
5.15.162
Type
ECOSYSTEM
Events
Introduced
5.16.0
Fixed
6.1.95
Type
ECOSYSTEM
Events
Introduced
6.2.0
Fixed
6.6.35
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.9.5