CVE-2026-31422 PUBLISHED

net/sched: cls_flow: fix NULL pointer dereference on shared blocks

Assigner: Linux
Reserved: 09.03.2026 Published: 13.04.2026 Updated: 13.04.2026

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

net/sched: cls_flow: fix NULL pointer dereference on shared blocks

flow_change() calls tcf_block_q() and dereferences q->handle to derive a default baseclass. Shared blocks leave block->q NULL, causing a NULL deref when a flow filter without a fully qualified baseclass is created on a shared block.

Check tcf_block_shared() before accessing block->q and return -EINVAL for shared blocks. This avoids the null-deref shown below:

======================================================================= KASAN: null-ptr-deref in range [0x0000000000000038-0x000000000000003f] RIP: 0010:flow_change (net/sched/cls_flow.c:508) Call Trace: tc_new_tfilter (net/sched/cls_api.c:2432) rtnetlink_rcv_msg (net/core/rtnetlink.c:6980) [...] =======================================================================

Product Status

Vendor Linux
Product Linux
Versions Default: unaffected
  • affected from 1abf272022cf1d18469405f47b4ec49c6a3125db to cc707a4fd4c3b6ab2722e06bc359aa010e13d408 (excl.)
  • affected from 1abf272022cf1d18469405f47b4ec49c6a3125db to 4a09f72007201c9f667dc47f64517ec23eea65e5 (excl.)
  • affected from 1abf272022cf1d18469405f47b4ec49c6a3125db to 9bf5fc36a43f7b8b5507c96e74fb81f1e8b4957e (excl.)
  • affected from 1abf272022cf1d18469405f47b4ec49c6a3125db to a208c3e1232997e9317887294c20008dfcb75449 (excl.)
  • affected from 1abf272022cf1d18469405f47b4ec49c6a3125db to 415ea0c973c754b9f375225807810eb9045f4293 (excl.)
  • affected from 1abf272022cf1d18469405f47b4ec49c6a3125db to 1a280dd4bd1d616a01d6ffe0de284c907b555504 (excl.)
Vendor Linux
Product Linux
Versions Default: affected
  • Version 4.15 is affected
  • unaffected from 0 to 4.15 (excl.)
  • unaffected from 6.1.168 to 6.1.* (incl.)
  • unaffected from 6.6.134 to 6.6.* (incl.)
  • unaffected from 6.12.81 to 6.12.* (incl.)
  • unaffected from 6.18.22 to 6.18.* (incl.)
  • unaffected from 6.19.12 to 6.19.* (incl.)
  • unaffected from 7.0 to * (incl.)

References