CVE-2025-40256

Source
https://cve.org/CVERecord?id=CVE-2025-40256
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2025-40256.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2025-40256
Downstream
Published
2025-12-04T16:08:17.756Z
Modified
2026-01-19T20:16:16.395128Z
Summary
xfrm: also call xfrm_state_delete_tunnel at destroy time for states that were never added
Details

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

xfrm: also call xfrmstatedelete_tunnel at destroy time for states that were never added

In commit b441cf3f8c4b ("xfrm: delete x->tunnel as we delete x"), I missed the case where state creation fails between full initialization (->init_state has been called) and being inserted on the lists.

In this situation, ->initstate has been called, so for IPcomp tunnels, the fallback tunnel has been created and added onto the lists, but the user state never gets added, because we fail before that. The user state doesn't go through _xfrmstatedelete, so we don't call xfrmstatedelete_tunnel for those states, and we end up leaking the FB tunnel.

There are several codepaths affected by this: the add/update paths, in both net/key and xfrm, and the migrate code (xfrmmigrate, xfrmstatemigrate). A "proper" rollback of the initstate work would probably be doable in the add/update code, but for migrate it gets more complicated as multiple states may be involved.

At some point, the new (not-inserted) state will be destroyed, so call xfrmstatedeletetunnel during xfrmstategcdestroy. Most states will have their fallback tunnel cleaned up during _xfrmstatedelete, which solves the issue that b441cf3f8c4b (and other patches before it) aimed at. All states (including FB tunnels) will be removed from the lists once xfrmstatefini has called flushwork(&xfrmstategc_work).

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2025/40xxx/CVE-2025-40256.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
1b28a7fae0128fa140a7dccd995182ff6cd1c67b
Fixed
57b72d74d4651dc19d046308a8304eb9abfe66ac
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
4b2c17d0f9be8b58bb30468bc81a4b61c985b04e
Fixed
1dad653643f28ccc89be93f9440b8804cded85b2
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
0da961fa46da1b37ef868d9b603bd202136f8f8e
Fixed
64441724387b4ac92f67ef51caaaeffe99c950d1
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
d0e0d1097118461463b76562c7ebaabaa5b90b13
Fixed
763e5c351206c1e4d910db4a1159053f6263689c
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
dc3636912d41770466543623cb76e7b88fdb42c7
Fixed
f7d879c19d306512c2e260f37e8a3e5c85e37c50
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
b441cf3f8c4b8576639d20c8eb4aa32917602ecd
Fixed
d6fe5c740c573af10943b8353992e1325cdb2715
Fixed
10deb69864840ccf96b00ac2ab3a2055c0c04721

Affected versions

v6.*

v6.16
v6.16-rc1
v6.16-rc2
v6.16-rc3
v6.16-rc4
v6.16-rc5
v6.16-rc6
v6.16-rc7
v6.17
v6.17-rc1
v6.17-rc2
v6.17-rc3
v6.17-rc4
v6.17-rc5
v6.17-rc6
v6.17-rc7
v6.17.1
v6.17.2
v6.17.3
v6.17.4
v6.17.5
v6.17.6
v6.17.7
v6.17.8
v6.17.9
v6.18-rc1

Database specific

source

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

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
6.16.0
Fixed
6.17.10

Database specific

source

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