CVE-2026-23413

Source
https://cve.org/CVERecord?id=CVE-2026-23413
Import Source
https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-23413.json
JSON Data
https://api.test.osv.dev/v1/vulns/CVE-2026-23413
Downstream
Published
2026-04-02T11:40:54.384Z
Modified
2026-04-14T03:47:56.830153Z
Summary
clsact: Fix use-after-free in init/destroy rollback asymmetry
Details

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

clsact: Fix use-after-free in init/destroy rollback asymmetry

Fix a use-after-free in the clsact qdisc upon init/destroy rollback asymmetry. The latter is achieved by first fully initializing a clsact instance, and then in a second step having a replacement failure for the new clsact qdisc instance. clsactinit() initializes ingress first and then takes care of the egress part. This can fail midway, for example, via tcfblockgetext(). Upon failure, the kernel will trigger the clsact_destroy() callback.

Commit 1cb6f0bae504 ("bpf: Fix too early release of tcxentry") details the way how the transition is happening. If tcfblockgetext on the q->ingressblock ends up failing, we took the tcxminiqinc reference count on the ingress side, but not yet on the egress side. clsactdestroy() tests whether the {ingress,egress}entry was non-NULL. However, even in midway failure on the replacement, both are in fact non-NULL with a valid egressentry from the previous clsact instance.

What we really need to test for is whether the qdisc instance-specific ingress or egress side previously got initialized. This adds a small helper for checking the miniq initialization called miniqdiscpairinited, and utilizes that upon clsactdestroy() in order to fix the use-after-free scenario. Convert the ingress_destroy() side as well so both are consistent to each other.

Database specific
{
    "osv_generated_from": "https://github.com/CVEProject/cvelistV5/tree/main/cves/2026/23xxx/CVE-2026-23413.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
230bb13650b0f186f540500fd5f5f7096a822a2a
Fixed
a73d95b57bf9faebdfed591bcb7ed9292062a84c
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
1cb6f0bae50441f4b4b32a28315853b279c7404e
Fixed
37bef86e5428d59f70a4da82b80f9a8f252fecbe
Fixed
4c9af67f99aa3e51b522c54968ab3ac8272be41c
Fixed
0509b762bc5e8ea7b8391130730c6d8502fc6e69
Fixed
a0671125d4f55e1e98d9bde8a0b671941987e208
Type
GIT
Repo
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
Events
Introduced
0 Unknown introduced commit / All previous commits are affected
Last affected
f61ecf1bd5b562ebfd7d430ccb31619857e80857

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-23413.json"

Linux / Kernel

Package

Name
Kernel

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
6.6.130
Type
ECOSYSTEM
Events
Introduced
6.7.0
Fixed
6.12.78
Type
ECOSYSTEM
Events
Introduced
6.10.0
Fixed
6.18.20
Type
ECOSYSTEM
Events
Introduced
6.13.0
Fixed
6.19.10

Database specific

source
"https://storage.googleapis.com/osv-test-cve-osv-conversion/osv-output/CVE-2026-23413.json"