Home

Description

In the Linux kernel, the following vulnerability has been resolved: btrfs: fix use-after-free warning in btrfs_get_or_create_delayed_node() Previously, btrfs_get_or_create_delayed_node() set the delayed_node's refcount before acquiring the root->delayed_nodes lock. Commit e8513c012de7 ("btrfs: implement ref_tracker for delayed_nodes") moved refcount_set inside the critical section, which means there is no longer a memory barrier between setting the refcount and setting btrfs_inode->delayed_node. Without that barrier, the stores to node->refs and btrfs_inode->delayed_node may become visible out of order. Another thread can then read btrfs_inode->delayed_node and attempt to increment a refcount that hasn't been set yet, leading to a refcounting bug and a use-after-free warning. The fix is to move refcount_set back to where it was to take advantage of the implicit memory barrier provided by lock acquisition. Because the allocations now happen outside of the lock's critical section, they can use GFP_NOFS instead of GFP_ATOMIC.

PUBLISHED Reserved 2026-01-13 | Published 2026-01-23 | Updated 2026-02-09 | Assigner Linux

Product status

Default status
unaffected

e8513c012de75fd65e2df5499572bc6ef3f6e409 (git) before c8385851a5435f4006281828d428e5d0b0bbf8af
affected

e8513c012de75fd65e2df5499572bc6ef3f6e409 (git) before 83f59076a1ae6f5c6845d6f7ed3a1a373d883684
affected

Default status
affected

6.18
affected

Any version before 6.18
unaffected

6.18.6 (semver)
unaffected

6.19 (original_commit_for_fix)
unaffected

References

git.kernel.org/...c/c8385851a5435f4006281828d428e5d0b0bbf8af

git.kernel.org/...c/83f59076a1ae6f5c6845d6f7ed3a1a373d883684

cve.org (CVE-2025-71159)

nvd.nist.gov (CVE-2025-71159)

Download JSON