Logo
-

Byte Open Security

(ByteOS Network)

Log In

Sign Up

ByteOS

Security
Vulnerability Details
Registries
Custom Views
Weaknesses
Attack Patterns
Filters & Tools
CVE Vulnerability Details :
CVE-2026-45920
PUBLISHED
More InfoOfficial Page
Assigner-Linux
Assigner Org ID-416baaa9-dc9f-4396-8d5f-8c081fb06d67
View Known Exploited Vulnerability (KEV) details
Published At-27 May, 2026 | 12:17
Updated At-27 May, 2026 | 12:17
Rejected At-
▼CVE Numbering Authority (CNA)
ext4: fix dirtyclusters double decrement on fs shutdown

In the Linux kernel, the following vulnerability has been resolved: ext4: fix dirtyclusters double decrement on fs shutdown fstests test generic/388 occasionally reproduces a warning in ext4_put_super() associated with the dirty clusters count: WARNING: CPU: 7 PID: 76064 at fs/ext4/super.c:1324 ext4_put_super+0x48c/0x590 [ext4] Tracing the failure shows that the warning fires due to an s_dirtyclusters_counter value of -1. IOW, this appears to be a spurious decrement as opposed to some sort of leak. Further tracing of the dirty cluster count deltas and an LLM scan of the resulting output identified the cause as a double decrement in the error path between ext4_mb_mark_diskspace_used() and the caller ext4_mb_new_blocks(). First, note that generic/388 is a shutdown vs. fsstress test and so produces a random set of operations and shutdown injections. In the problematic case, the shutdown triggers an error return from the ext4_handle_dirty_metadata() call(s) made from ext4_mb_mark_context(). The changed value is non-zero at this point, so ext4_mb_mark_diskspace_used() does not exit after the error bubbles up from ext4_mb_mark_context(). Instead, the former decrements both cluster counters and returns the error up to ext4_mb_new_blocks(). The latter falls into the !ar->len out path which decrements the dirty clusters counter a second time, creating the inconsistency. To avoid this problem and simplify ownership of the cluster reservation in this codepath, lift the counter reduction to a single place in the caller. This makes it more clear that ext4_mb_new_blocks() is responsible for acquiring cluster reservation (via ext4_claim_free_clusters()) in the !delalloc case as well as releasing it, regardless of whether it ends up consumed or returned due to failure.

Affected Products
Vendor
Linux Kernel Organization, IncLinux
Product
Linux
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Program Files
  • fs/ext4/mballoc-test.c
  • fs/ext4/mballoc.c
Default Status
unaffected
Versions
Affected
  • From 0087d9fb3f29f59e8d42c8b058376d80e5adde4c before 523d5a4df3c649fa305c89efb552ec62a1ce9d3d (git)
  • From 0087d9fb3f29f59e8d42c8b058376d80e5adde4c before ca408af08544d96769c93a3d81a7f63f61129e95 (git)
  • From 0087d9fb3f29f59e8d42c8b058376d80e5adde4c before 55576fa14771d33994c29a9ae960e07bb3f56c20 (git)
  • From 0087d9fb3f29f59e8d42c8b058376d80e5adde4c before dbc4e10619ed87a50e637b96f2e574df36a7a769 (git)
  • From 0087d9fb3f29f59e8d42c8b058376d80e5adde4c before 61e372122b6d95aec940fdaea0a16f988f359897 (git)
  • From 0087d9fb3f29f59e8d42c8b058376d80e5adde4c before 3924aea2c33df3864929c1acd178bfc29d8f005f (git)
  • From 0087d9fb3f29f59e8d42c8b058376d80e5adde4c before 81982a11406c5da6c6e2b188028e7056e16b7128 (git)
  • From 0087d9fb3f29f59e8d42c8b058376d80e5adde4c before 94a8cea54cd935c54fa2fba70354757c0fc245e3 (git)
Vendor
Linux Kernel Organization, IncLinux
Product
Linux
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Program Files
  • fs/ext4/mballoc-test.c
  • fs/ext4/mballoc.c
Default Status
affected
Versions
Affected
  • 2.6.29
Unaffected
  • From 0 before 2.6.29 (semver)
  • From 5.10.253 through 5.10.* (semver)
  • From 5.15.203 through 5.15.* (semver)
  • From 6.1.167 through 6.1.* (semver)
  • From 6.6.130 through 6.6.* (semver)
  • From 6.12.75 through 6.12.* (semver)
  • From 6.18.14 through 6.18.* (semver)
  • From 6.19.4 through 6.19.* (semver)
  • From 7.0 through * (original_commit_for_fix)
Metrics
VersionBase scoreBase severityVector
Metrics Other Info
Impacts
CAPEC IDDescription
Solutions

Configurations

Workarounds

Exploits

Credits

Timeline
EventDate
Replaced By

Rejected Reason

References
HyperlinkResource
https://git.kernel.org/stable/c/523d5a4df3c649fa305c89efb552ec62a1ce9d3d
N/A
https://git.kernel.org/stable/c/ca408af08544d96769c93a3d81a7f63f61129e95
N/A
https://git.kernel.org/stable/c/55576fa14771d33994c29a9ae960e07bb3f56c20
N/A
https://git.kernel.org/stable/c/dbc4e10619ed87a50e637b96f2e574df36a7a769
N/A
https://git.kernel.org/stable/c/61e372122b6d95aec940fdaea0a16f988f359897
N/A
https://git.kernel.org/stable/c/3924aea2c33df3864929c1acd178bfc29d8f005f
N/A
https://git.kernel.org/stable/c/81982a11406c5da6c6e2b188028e7056e16b7128
N/A
https://git.kernel.org/stable/c/94a8cea54cd935c54fa2fba70354757c0fc245e3
N/A
Hyperlink: https://git.kernel.org/stable/c/523d5a4df3c649fa305c89efb552ec62a1ce9d3d
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/ca408af08544d96769c93a3d81a7f63f61129e95
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/55576fa14771d33994c29a9ae960e07bb3f56c20
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/dbc4e10619ed87a50e637b96f2e574df36a7a769
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/61e372122b6d95aec940fdaea0a16f988f359897
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/3924aea2c33df3864929c1acd178bfc29d8f005f
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/81982a11406c5da6c6e2b188028e7056e16b7128
Resource: N/A
Hyperlink: https://git.kernel.org/stable/c/94a8cea54cd935c54fa2fba70354757c0fc245e3
Resource: N/A
Details not found