CVE-2025-71237
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
18/02/2026
Last modified:
23/02/2026
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
nilfs2: Fix potential block overflow that cause system hang<br />
<br />
When a user executes the FITRIM command, an underflow can occur when<br />
calculating nblocks if end_block is too small. Since nblocks is of<br />
type sector_t, which is u64, a negative nblocks value will become a<br />
very large positive integer. This ultimately leads to the block layer<br />
function __blkdev_issue_discard() taking an excessively long time to<br />
process the bio chain, and the ns_segctor_sem lock remains held for a<br />
long period. This prevents other tasks from acquiring the ns_segctor_sem<br />
lock, resulting in the hang reported by syzbot in [1].<br />
<br />
If the ending block is too small, typically if it is smaller than 4KiB<br />
range, depending on the usage of the segment 0, it may be possible to<br />
attempt a discard request beyond the device size causing the hang.<br />
<br />
Exiting successfully and assign the discarded size (0 in this case)<br />
to range->len.<br />
<br />
Although the start and len values in the user input range are too small,<br />
a conservative strategy is adopted here to safely ignore them, which is<br />
equivalent to a no-op; it will not perform any trimming and will not<br />
throw an error.<br />
<br />
[1]<br />
task:segctord state:D stack:28968 pid:6093 tgid:6093 ppid:2 task_flags:0x200040 flags:0x00080000<br />
Call Trace:<br />
rwbase_write_lock+0x3dd/0x750 kernel/locking/rwbase_rt.c:272<br />
nilfs_transaction_lock+0x253/0x4c0 fs/nilfs2/segment.c:357<br />
nilfs_segctor_thread_construct fs/nilfs2/segment.c:2569 [inline]<br />
nilfs_segctor_thread+0x6ec/0xe00 fs/nilfs2/segment.c:2684<br />
<br />
[ryusuke: corrected part of the commit message about the consequences]
Impact
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/2438982f635e6cc2009be68ba2efb2998727d8d4
- https://git.kernel.org/stable/c/4aa45f841413cca81882602b4042c53502f34cad
- https://git.kernel.org/stable/c/6457d3ee41a4c15082ac49c5aa7fb933b4a043f3
- https://git.kernel.org/stable/c/b8c5ee234bd54f1447c846101fdaef2cf70c2149
- https://git.kernel.org/stable/c/ba18e5f22f26aa4ef78bc3e81f639d1d4f3845e6
- https://git.kernel.org/stable/c/df1e20796c9f3d541cca47fb72e4369ea135642d
- https://git.kernel.org/stable/c/ea2278657ad0d62596589fbe2caf995e189e65e7
- https://git.kernel.org/stable/c/ed527ef0c264e4bed6c7b2a158ddf516b17f5f66



