CVE-2024-38598

Source
https://cve.org/CVERecord?id=CVE-2024-38598
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-38598.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-38598
Downstream
Related
Published
2024-06-19T13:45:47.309Z
Modified
2026-03-13T07:56:55.963663Z
Summary
md: fix resync softlockup when bitmap size is less than array size
Details

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

md: fix resync softlockup when bitmap size is less than array size

Is is reported that for dm-raid10, lvextend + lvchange --syncaction will trigger following softlockup:

kernel:watchdog: BUG: soft lockup - CPU#3 stuck for 26s! [mdXresync:6976] CPU: 7 PID: 3588 Comm: mdXresync Kdump: loaded Not tainted 6.9.0-rc4-next-20240419 #1 RIP: 0010:rawspinunlockirq+0x13/0x30 Call Trace: <TASK> mdbitmapstartsync+0x6b/0xf0 raid10syncrequest+0x25c/0x1b40 [raid10] mddosync+0x64b/0x1020 mdthread+0xa7/0x170 kthread+0xcf/0x100 retfromfork+0x30/0x50 retfromfork_asm+0x1a/0x30

And the detailed process is as follows:

mddosync j = mddev->resyncmin while (j < maxsectors) sectors = raid10syncrequest(mddev, j, &skipped) if (!mdbitmapstartsync(..., &syncblocks)) // mdbitmapstartsync set syncblocks to 0 return syncblocks + sectorsskippe; // sectors = 0; j += sectors; // j never change

Root cause is that commit 301867b1c168 ("md/raid10: check slab-out-of-bounds in mdbitmapgetcounter") return early from mdbitmapgetcounter(), without setting returned blocks.

Fix this problem by always set returned blocks from mdbitmapget_counter"(), as it used to be.

Noted that this patch just fix the softlockup problem in kernel, the case that bitmap size doesn't match array size still need to be fixed.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2024/38xxx/CVE-2024-38598.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
374fb914304d9b500721007f3837ea8f1f9a2418
Fixed
d4b9c764d48fa41caa24cfb4275f3aa9fb4bd798
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
b0b971fe7d61411ede63c3291764dbde1577ef2c
Fixed
43771597feba89a839c5f893716df88ae5c237ce
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
39fa14e824acfd470db4f42c354297456bd82b53
Fixed
3f5b73ef8fd6268cbc968b308d8eafe56fda97f3
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
a134dd582c0d5b6068efa308bd485cf1d00b3f65
Fixed
69296914bfd508c85935bf5f711cad9b0fe78492
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
be1a3ec63a840cc9e59a033acf154f56255699a1
Fixed
71e8e4f288e74a896b6d9cd194f3bab12bd7a10f
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
301867b1c16805aebbc306aafa6ecdc68b73c7e5
Fixed
c9566b812c8f66160466cc1e29df6d3646add0b1
Fixed
5817f43ae1a118855676f57ef7ab50e37eac7482
Fixed
8bbc71315e0ae4bb7e37f8d43b915e1cb01a481b
Fixed
f0e729af2eb6bee9eb58c4df1087f14ebaefe26b
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Last affected
152bb26796ff054af50b2ee1b3ca56e364e4f61b
Last affected
bea301c046110bf421a3ce153fb868cb8d618e90

Database specific

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