Back to overview

CVE-2026-52997

Description
In the Linux kernel, the following vulnerability has been resolved: net/sched: sch_dualpi2: drain both C-queue and L-queue in dualpi2_change() Fix dualpi2_change() to correctly enforce updated limit and memlimit values after a configuration change of the dualpi2 qdisc. Before this patch, dualpi2_change() always attempted to dequeue packets via the root qdisc (C-queue) when reducing backlog or memory usage, and unconditionally assumed that a valid skb will be returned. When traffic classification results in packets being queued in the L-queue while the C-queue is empty, this leads to a NULL skb dereference during limit or memlimit enforcement. This is fixed by first dequeuing from the C-queue path if it is non-empty. Once the C-queue is empty, packets are dequeued directly from the L-queue. Return values from qdisc_dequeue_internal() are checked for both queues. When dequeuing from the L-queue, the parent qdisc qlen and backlog counters are updated explicitly to keep overall qdisc statistics consistent.

Metadata

CVE ID
CVE-2026-52997
State
PUBLISHED
Assigner
Linux
Reserved
2026-06-09 07:44 UTC
Published
2026-06-24 16:29 UTC
Last updated
2026-06-24 16:29 UTC
Vendor / Product
Linux / Linux
Sources
cve.org  ·  NVD

Severity & Metrics

No CVSS data available.

Affected products (2)
VendorProductPlatformVersions
Linux Linux 320d031ad6e4d67e8e1ab08ac71efda02bc85683 < 86cf2eba2056bcf9c41fba260e599bd95bf9943b, 320d031ad6e4d67e8e1ab08ac71efda02bc85683 < 3042add80c2c50bd127d570b83319af612efde65, 320d031ad6e4d67e8e1ab08ac71efda02bc85683 < 478ed6b7d2577439c610f91fa8759a4c878a4264
Linux Linux 6.17, 0 < 6.17, 6.18.33 ≤ 6.18.*, 7.0.10 ≤ 7.0.* …
Back to overview