Vulnerability Description
In the Linux kernel, the following vulnerability has been resolved: ext4: fix delayed allocation bug in ext4_clu_mapped 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 ext4_clu_mapped() calls ext4_find_extent() 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.
CVSS Score
MEDIUM
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| Linux | Linux Kernel | < 5.4.229 |
References
- https://git.kernel.org/stable/c/131294c35ed6f777bd4e79d42af13b5c41bf2775Patch
- https://git.kernel.org/stable/c/6f4200ec76a0d31200c308ec5a71c68df5417004Patch
- https://git.kernel.org/stable/c/81b915181c630ee1cffa052e52874fe4e1ba91acPatch
- https://git.kernel.org/stable/c/9404839e0c9db5a517ea83c0ca3388b39d105fdfPatch
- https://git.kernel.org/stable/c/c0c8edbc8abbe8f16d80a1d794d1ba2c12b6f193Patch
- https://git.kernel.org/stable/c/d440d6427a5e3a877c1c259b8d2b216ddb65e185Patch
- https://git.kernel.org/stable/c/f83391339d8493b9ff24167516aaa5a5e88d8f81
FAQ
What is CVE-2022-50286?
CVE-2022-50286 is a vulnerability with a CVSS score of 5.5 (MEDIUM). In the Linux kernel, the following vulnerability has been resolved: ext4: fix delayed allocation bug in ext4_clu_mapped for bigalloc + inline When converting files with inline data to extents, delay...
How severe is CVE-2022-50286?
CVE-2022-50286 has been rated MEDIUM with a CVSS base score of 5.5/10. Review the CVSS metrics above for detailed severity breakdown.
Is there a patch for CVE-2022-50286?
Check the references section above for vendor advisories and patch information. Affected products include: Linux Linux Kernel.