CVE-2022-50668
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
09/12/2025
Last modified:
09/12/2025
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
ext4: fix deadlock due to mbcache entry corruption<br />
<br />
When manipulating xattr blocks, we can deadlock infinitely looping<br />
inside ext4_xattr_block_set() where we constantly keep finding xattr<br />
block for reuse in mbcache but we are unable to reuse it because its<br />
reference count is too big. This happens because cache entry for the<br />
xattr block is marked as reusable (e_reusable set) although its<br />
reference count is too big. When this inconsistency happens, this<br />
inconsistent state is kept indefinitely and so ext4_xattr_block_set()<br />
keeps retrying indefinitely.<br />
<br />
The inconsistent state is caused by non-atomic update of e_reusable bit.<br />
e_reusable is part of a bitfield and e_reusable update can race with<br />
update of e_referenced bit in the same bitfield resulting in loss of one<br />
of the updates. Fix the problem by using atomic bitops instead.<br />
<br />
This bug has been around for many years, but it became *much* easier<br />
to hit after commit 65f8b80053a1 ("ext4: fix race when reusing xattr<br />
blocks").
Impact
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/127b80cefb941a81255c72f11081123f3a705369
- https://git.kernel.org/stable/c/1be16a0c2f10186df505e28b0cc92d7f3366e2a8
- https://git.kernel.org/stable/c/5bc0b2fda4b47c86278f7c6d30c211f425bf51cf
- https://git.kernel.org/stable/c/a44e84a9b7764c72896f7241a0ec9ac7e7ef38dd
- https://git.kernel.org/stable/c/af53065276376750dfac35a7248af18806404c5d
- https://git.kernel.org/stable/c/cc1538c693d25e282bed8c54b65c914a04023a78
- https://git.kernel.org/stable/c/efaa0ca678f56d47316a08030b2515678cebbc50



