HOMEVULNERABILITIESCVE-2026-31733
MEDIUM

CVE-2026-31733

Published: May 1, 2026· Updated: May 7, 2026

5.5
CVSS v3.1
EPSS:0.02%probability of exploitation in 30 daysPercentile:4.6th

Official Description

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

sched_ext: Fix stale direct dispatch state in ddsp_dsq_id

@p->scx.ddsp_dsq_id can be left set (non-SCX_DSQ_INVALID) triggering a

spurious warning in mark_direct_dispatch() when the next wakeup's

ops.select_cpu() calls scx_bpf_dsq_insert(), such as:

WARNING: kernel/sched/ext.c:1273 at scx_dsq_insert_commit+0xcd/0x140

The root cause is that ddsp_dsq_id was only cleared in dispatch_enqueue(),

which is not reached in all paths that consume or cancel a direct dispatch

verdict.

Fix it by clearing it at the right places:

- direct_dispatch(): cache the direct dispatch state in local variables

and clear it before dispatch_enqueue() on the synchronous path. For

the deferred path, the direct dispatch state must remain set until

process_ddsp_deferred_locals() consumes them.

- process_ddsp_deferred_locals(): cache the dispatch state in local

variables and clear it before calling dispatch_to_local_dsq(), which

may migrate the task to another rq.

- do_enqueue_task(): clear the dispatch state on the enqueue path

(local/global/bypass fallbacks), where the direct dispatch verdict is

ignored.

- dequeue_task_scx(): clear the dispatch state after dispatch_dequeue()

to handle both the deferred dispatch cancellation and the holding_cpu

race, covering all cases where a pending direct dispatch is

cancelled.

- scx_disable_task(): clear the direct dispatch state when

transitioning a task out of the current scheduler. Waking tasks may

have had the direct dispatch state set by the outgoing scheduler's

ops.select_cpu() and then been queued on a wake_list via

ttwu_queue_wakelist(), when SCX_OPS_ALLOW_QUEUED_WAKEUP is set. Such

tasks are not on the runqueue and are not iterated by scx_bypass(),

so their direct dispatch state won't be cleared. Without this clear,

any subsequent SCX scheduler that tries to direct dispatch the task

will trigger the WARN_ON_ONCE() in mark_direct_dispatch().

NVD Source

Technical Analysis

CVE-2026-31733 requires local access, meaning attackers must already have a foothold on the target system.

Exploitation requires low privileges, which limits the exposure to scenarios where an attacker has already gained initial access.

A successful exploit results in availability disruption (denial of service), with a CVSS base score of 5.5.

CVSS v3.1 Vector Breakdown

Exploitability
Attack VectorLocal
Attack ComplexityLow
Privileges Req.Low
User InteractionNone
ScopeUnchanged
Impact
ConfidentialityNone
IntegrityNone
AvailabilityHigh
CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H

Affected Vendors & Products

Linux1 product
linux kernel
Source: NVD CPE · 2 total CPE entries

Exploit & PoC Resources

NO KNOWN EXPLOITNo public exploit confirmed at this time
External links open in a new tab. Always verify in a controlled environment before use.

Official Patches & Advisories

All References (4)

Quick Facts

CVE IDCVE-2026-31733
CVSS Score5.5 / 10
SeverityMEDIUM
CISA KEVNo
EPSS (30d)0.02%
Affected1 vendor
PublishedMay 1, 2026

Recommended Actions

  • Apply vendor patches immediately
  • Monitor CVE-2026-31733 in threat intel feeds
  • Review IDS/IPS signatures for exploitation attempts
Data sourced from NVD (NIST), CISA KEV, and EPSS (FIRST). Analysis generated by CTIWATCH.COM. CVE data is provided under the NVD usage policy.