CVE-2022-50286

Source
https://cve.org/CVERecord?id=CVE-2022-50286
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2022-50286.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2022-50286
Downstream
Related
Published
2025-09-15T14:21:22.489Z
Modified
2026-03-12T03:26:21.848502Z
Summary
ext4: fix delayed allocation bug in ext4_clu_mapped for bigalloc + inline
Details

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

ext4: fix delayed allocation bug in ext4clumapped for bigalloc + inline

When converting files with inline data to extents, delayed allocations made on a file system created with both the bigalloc and inline options can result in invalid extent status cache content, incorrect reserved cluster counts, kernel memory leaks, and potential kernel panics.

With bigalloc, the code that determines whether a block must be delayed allocated searches the extent tree to see if that block maps to a previously allocated cluster. If not, the block is delayed allocated, and otherwise, it isn't. However, if the inline option is also used, and if the file containing the block is marked as able to store data inline, there isn't a valid extent tree associated with the file. The current code in ext4clumapped() calls ext4findextent() to search the non-existent tree for a previously allocated cluster anyway, which typically finds nothing, as desired. However, a side effect of the search can be to cache invalid content from the non-existent tree (garbage) in the extent status tree, including bogus entries in the pending reservation tree.

To fix this, avoid searching the extent tree when allocating blocks for bigalloc + inline files that are being converted from inline to extent mapped.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2022/50xxx/CVE-2022-50286.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
d40e09f701cf7a44e595a558b067b2b4f67fbf87
Fixed
f83391339d8493b9ff24167516aaa5a5e88d8f81
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
0b02f4c0d6d9e2c611dfbdd4317193e9dca740e6
Fixed
6f4200ec76a0d31200c308ec5a71c68df5417004
Fixed
9404839e0c9db5a517ea83c0ca3388b39d105fdf
Fixed
d440d6427a5e3a877c1c259b8d2b216ddb65e185
Fixed
c0c8edbc8abbe8f16d80a1d794d1ba2c12b6f193
Fixed
81b915181c630ee1cffa052e52874fe4e1ba91ac
Fixed
131294c35ed6f777bd4e79d42af13b5c41bf2775

Database specific

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