]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
sched/deadline: Use online cpus for validating runtime
authorShrikanth Hegde <sshegde@linux.ibm.com>
Thu, 6 Mar 2025 05:29:53 +0000 (10:59 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 10 Apr 2025 12:37:37 +0000 (14:37 +0200)
[ Upstream commit 14672f059d83f591afb2ee1fff56858efe055e5a ]

The ftrace selftest reported a failure because writing -1 to
sched_rt_runtime_us returns -EBUSY. This happens when the possible
CPUs are different from active CPUs.

Active CPUs are part of one root domain, while remaining CPUs are part
of def_root_domain. Since active cpumask is being used, this results in
cpus=0 when a non active CPUs is used in the loop.

Fix it by looping over the online CPUs instead for validating the
bandwidth calculations.

Signed-off-by: Shrikanth Hegde <sshegde@linux.ibm.com>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Reviewed-by: Juri Lelli <juri.lelli@redhat.com>
Link: https://lore.kernel.org/r/20250306052954.452005-2-sshegde@linux.ibm.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
kernel/sched/deadline.c

index b9e99bc3b1cf24843140a12ef03cae17e843c723..6c639e48e49a9747b625f2d3215819c5cf4feb87 100644 (file)
@@ -2780,7 +2780,7 @@ int sched_dl_global_validate(void)
         * value smaller than the currently allocated bandwidth in
         * any of the root_domains.
         */
-       for_each_possible_cpu(cpu) {
+       for_each_online_cpu(cpu) {
                rcu_read_lock_sched();
 
                if (dl_bw_visited(cpu, gen))