CVE-2025-39871
Severity CVSS v4.0:
Pending analysis
Type:
CWE-416
Use After Free
Publication date:
23/09/2025
Last modified:
11/01/2026
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
dmaengine: idxd: Remove improper idxd_free<br />
<br />
The call to idxd_free() introduces a duplicate put_device() leading to a<br />
reference count underflow:<br />
refcount_t: underflow; use-after-free.<br />
WARNING: CPU: 15 PID: 4428 at lib/refcount.c:28 refcount_warn_saturate+0xbe/0x110<br />
...<br />
Call Trace:<br />
<br />
idxd_remove+0xe4/0x120 [idxd]<br />
pci_device_remove+0x3f/0xb0<br />
device_release_driver_internal+0x197/0x200<br />
driver_detach+0x48/0x90<br />
bus_remove_driver+0x74/0xf0<br />
pci_unregister_driver+0x2e/0xb0<br />
idxd_exit_module+0x34/0x7a0 [idxd]<br />
__do_sys_delete_module.constprop.0+0x183/0x280<br />
do_syscall_64+0x54/0xd70<br />
entry_SYSCALL_64_after_hwframe+0x76/0x7e<br />
<br />
The idxd_unregister_devices() which is invoked at the very beginning of<br />
idxd_remove(), already takes care of the necessary put_device() through the<br />
following call path:<br />
idxd_unregister_devices() -> device_unregister() -> put_device()<br />
<br />
In addition, when CONFIG_DEBUG_KOBJECT_RELEASE is enabled, put_device() may<br />
trigger asynchronous cleanup via schedule_delayed_work(). If idxd_free() is<br />
called immediately after, it can result in a use-after-free.<br />
<br />
Remove the improper idxd_free() to avoid both the refcount underflow and<br />
potential memory corruption during module unload.
Impact
Base Score 3.x
7.80
Severity 3.x
HIGH
Vulnerable products and versions
| CPE | From | Up to |
|---|---|---|
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.1.140 (including) | 6.2 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.6.92 (including) | 6.6.107 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.12.30 (including) | 6.12.48 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.14.8 (including) | 6.15 (excluding) |
| cpe:2.3:o:linux:linux_kernel:*:*:*:*:*:*:*:* | 6.15.1 (including) | 6.16.8 (excluding) |
| cpe:2.3:o:linux:linux_kernel:6.15:-:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:6.15:rc7:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:6.17:rc1:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:6.17:rc2:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:6.17:rc3:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:6.17:rc4:*:*:*:*:*:* | ||
| cpe:2.3:o:linux:linux_kernel:6.17:rc5:*:*:*:*:*:* |
To consult the complete list of CPE names with products and versions, see this page
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/0e95ee7f532b21206fe3f1c4054002b0d21e3b9c
- https://git.kernel.org/stable/c/24414bbcb37e1af95190af36c21ae51d497e1a9e
- https://git.kernel.org/stable/c/da4fbc1488a4cec6748da685181ee4449a878dac
- https://git.kernel.org/stable/c/dd7a7e43269711d757fc260b0bbdf7138f75de11
- https://git.kernel.org/stable/c/f41c538881eec4dcf5961a242097d447f848cda6



