CVE-2025-68780
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
13/01/2026
Last modified:
19/01/2026
Description
In the Linux kernel, the following vulnerability has been resolved:<br />
<br />
sched/deadline: only set free_cpus for online runqueues<br />
<br />
Commit 16b269436b72 ("sched/deadline: Modify cpudl::free_cpus<br />
to reflect rd->online") introduced the cpudl_set/clear_freecpu<br />
functions to allow the cpu_dl::free_cpus mask to be manipulated<br />
by the deadline scheduler class rq_on/offline callbacks so the<br />
mask would also reflect this state.<br />
<br />
Commit 9659e1eeee28 ("sched/deadline: Remove cpu_active_mask<br />
from cpudl_find()") removed the check of the cpu_active_mask to<br />
save some processing on the premise that the cpudl::free_cpus<br />
mask already reflected the runqueue online state.<br />
<br />
Unfortunately, there are cases where it is possible for the<br />
cpudl_clear function to set the free_cpus bit for a CPU when the<br />
deadline runqueue is offline. When this occurs while a CPU is<br />
connected to the default root domain the flag may retain the bad<br />
state after the CPU has been unplugged. Later, a different CPU<br />
that is transitioning through the default root domain may push a<br />
deadline task to the powered down CPU when cpudl_find sees its<br />
free_cpus bit is set. If this happens the task will not have the<br />
opportunity to run.<br />
<br />
One example is outlined here:<br />
https://lore.kernel.org/lkml/20250110233010.2339521-1-opendmb@gmail.com<br />
<br />
Another occurs when the last deadline task is migrated from a<br />
CPU that has an offlined runqueue. The dequeue_task member of<br />
the deadline scheduler class will eventually call cpudl_clear<br />
and set the free_cpus bit for the CPU.<br />
<br />
This commit modifies the cpudl_clear function to be aware of the<br />
online state of the deadline runqueue so that the free_cpus mask<br />
can be updated appropriately.<br />
<br />
It is no longer necessary to manage the mask outside of the<br />
cpudl_set/clear functions so the cpudl_set/clear_freecpu<br />
functions are removed. In addition, since the free_cpus mask is<br />
now only updated under the cpudl lock the code was changed to<br />
use the non-atomic __cpumask functions.
Impact
References to Advisories, Solutions, and Tools
- https://git.kernel.org/stable/c/382748c05e58a9f1935f5a653c352422375566ea
- https://git.kernel.org/stable/c/3ed049fbfb4d75b4e0b8ab54c934f485129d5dc8
- https://git.kernel.org/stable/c/9019e399684e3cc68c4a3f050e268f74d69c1317
- https://git.kernel.org/stable/c/91e448e69aca4bb0ba2e998eb3e555644db7322b
- https://git.kernel.org/stable/c/dbc61834b0412435df21c71410562d933e4eba49
- https://git.kernel.org/stable/c/fb36846cbcc936954f2ad2bffdff13d16c0be08a



