CVE-2025-38682

Source
https://cve.org/CVERecord?id=CVE-2025-38682
Import Source
https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2025-38682.json
JSON Data
https://api.osv.dev/v1/vulns/CVE-2025-38682
Downstream
Published
2025-09-04T15:32:37.403Z
Modified
2026-04-02T12:48:05.031240Z
Summary
i2c: core: Fix double-free of fwnode in i2c_unregister_device()
Details

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

i2c: core: Fix double-free of fwnode in i2cunregisterdevice()

Before commit df6d7277e552 ("i2c: core: Do not dereference fwnode in struct device"), i2cunregisterdevice() only called fwnodehandleput() on ofnode-s in the form of calling ofnodeput(client->dev.ofnode).

But after this commit the i2cclient's fwnode now unconditionally gets fwnodehandle_put() on it.

When the i2cclient has no primary (ACPI / OF) fwnode but it does have a software fwnode, the software-node will be the primary node and fwnodehandle_put() will put() it.

But for the software fwnode deviceremovesoftware_node() will also put() it leading to a double free:

[ 82.665598] ------------[ cut here ]------------ [ 82.665609] refcountt: underflow; use-after-free. [ 82.665808] WARNING: CPU: 3 PID: 1502 at lib/refcount.c:28 refcountwarnsaturate+0xba/0x11 ... [ 82.666830] RIP: 0010:refcountwarnsaturate+0xba/0x110 ... [ 82.666962] <TASK> [ 82.666971] i2cunregister_device+0x60/0x90

Fix this by not calling fwnodehandleput() when the primary fwnode is a software-node.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2025/38xxx/CVE-2025-38682.json",
    "cna_assigner": "Linux"
}
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
df6d7277e5525d6cce63127dd93ebec4c6354fa0
Fixed
ffe02f7c4e36090154646612e67d331832f92037
Fixed
1c24e5fc0c7096e00c202a6a3e0c342c1afb47c2

Database specific

source
"https://storage.googleapis.com/cve-osv-conversion/osv-output/CVE-2025-38682.json"