CVE-2025-40209

Source
https://nvd.nist.gov/vuln/detail/CVE-2025-40209
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2025-40209.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2025-40209
Downstream
Published
2025-11-21T10:19:44.757Z
Modified
2025-11-28T02:35:02.732560Z
Summary
btrfs: fix memory leak of qgroup_list in btrfs_add_qgroup_relation
Details

In the Linux kernel, the following vulnerability has been resolved:

btrfs: fix memory leak of qgrouplist in btrfsaddqgrouprelation

When btrfsaddqgrouprelation() is called with invalid qgroup levels (src >= dst), the function returns -EINVAL directly without freeing the preallocated qgrouplist structure passed by the caller. This causes a memory leak because the caller unconditionally sets the pointer to NULL after the call, preventing any cleanup.

The issue occurs because the level validation check happens before the mutex is acquired and before any error handling path that would free the prealloc pointer. On this early return, the cleanup code at the 'out' label (which includes kfree(prealloc)) is never reached.

In btrfsioctlqgroup_assign(), the code pattern is:

prealloc = kzalloc(sizeof(*prealloc), GFP_KERNEL);
ret = btrfs_add_qgroup_relation(trans, sa->src, sa->dst, prealloc);
prealloc = NULL;  // Always set to NULL regardless of return value
...
kfree(prealloc);  // This becomes kfree(NULL), does nothing

When the level check fails, 'prealloc' is never freed by either the callee or the caller, resulting in a 64-byte memory leak per failed operation. This can be triggered repeatedly by an unprivileged user with access to a writable btrfs mount, potentially exhausting kernel memory.

Fix this by freeing prealloc before the early return, ensuring prealloc is always freed on all error paths.

Database specific
{
    "cna_assigner": "Linux",
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2025/40xxx/CVE-2025-40209.json"
}
References

Affected packages

Git / git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git

Affected ranges

Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
4addc1ffd67ad34394674dc91379dc04cfdd2537
Fixed
3412d0e973e8f8381747d69033eda809a57a2581
Fixed
a4d9ebe23bcb79d9d057e3c995db73b7b3aae414
Fixed
f260c6aff0b8af236084012d14f9f1bf792ea883

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
6.11.0
Fixed
6.12.58
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.17.8