CVE-2024-43914

Source
https://cve.org/CVERecord?id=CVE-2024-43914
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2024-43914.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2024-43914
Downstream
Related
Published
2024-08-26T10:11:19.763Z
Modified
2026-03-20T12:37:47.534609Z
Summary
md/raid5: avoid BUG_ON() while continue reshape after reassembling
Details

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

md/raid5: avoid BUG_ON() while continue reshape after reassembling

Currently, mdadm support --revert-reshape to abort the reshape while reassembling, as the test 07revert-grow. However, following BUG_ON() can be triggerred by the test:

kernel BUG at drivers/md/raid5.c:6278! invalid opcode: 0000 [#1] PREEMPT SMP PTI irq event stamp: 158985 CPU: 6 PID: 891 Comm: md0reshape Not tainted 6.9.0-03335-g7592a0b0049a #94 RIP: 0010:reshaperequest+0x3f1/0xe60 Call Trace: <TASK> raid5syncrequest+0x43d/0x550 mddosync+0xb7a/0x2110 mdthread+0x294/0x2b0 kthread+0x147/0x1c0 retfromfork+0x59/0x70 retfromforkasm+0x1a/0x30 </TASK>

Root cause is that --revert-reshape update the raid_disks from 5 to 4, while reshape position is still set, and after reassembling the array, reshape position will be read from super block, then during reshape the checking of 'writepos' that is caculated by old reshape position will fail.

Fix this panic the easy way first, by converting the BUGON() to WARNON(), and stop the reshape if checkings fail.

Noted that mdadm must fix --revert-shape as well, and probably md/raid should enhance metadata validation as well, however this means reassemble will fail and there must be user tools to fix the wrong metadata.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2024/43xxx/CVE-2024-43914.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
ec32a2bd35bd6b933a5db6542c48210ce069a376
Fixed
2c92f8c1c456d556f15cbf51667b385026b2e6a0
Fixed
6b33c468d543f6a83de2d61f09fec74b27e19fd2
Fixed
c384dd4f1fb3b14a2fd199360701cc163ea88705
Fixed
bf0ff69a42a3d2d46876d0514ecf13dffc516666
Fixed
3b33740c1750a39e046339ff9240e954f0156707
Fixed
775a9ba16c9ffe98fe54ebf14e55d5660f2bf600
Fixed
4811d6e5d9f4090c3e0ff9890eb24077108046ab
Fixed
305a5170dc5cf3d395bb4c4e9239bca6d0b54b49

Database specific

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