CVE-2025-71159

HIGH

Linux Kernel 6.18-6.18.5 - Use-After-Free in btrfs_get_or_create_delayed_node

Title source: llm
STIX 2.1

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.

Scores

CVSS v3 7.8
EPSS 0.0003
EPSS Percentile 7.3%
Attack Vector LOCAL
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H

Details

CWE
CWE-416
Status published
Products (9)
linux/Kernel 6.18.0 - 6.18.6linux
Linux/Linux < 6.18
Linux/Linux 6.18
Linux/Linux 6.18.6 - 6.18.*
Linux/Linux 6.19
Linux/Linux e8513c012de75fd65e2df5499572bc6ef3f6e409 - 83f59076a1ae6f5c6845d6f7ed3a1a373d883684
Linux/Linux e8513c012de75fd65e2df5499572bc6ef3f6e409 - c8385851a5435f4006281828d428e5d0b0bbf8af
linux/linux_kernel 6.19 rc1 (4 CPE variants)
linux/linux_kernel 6.18 - 6.18.6
Published Jan 23, 2026
Tracked Since Feb 18, 2026