summaryrefslogtreecommitdiff
path: root/kernel/sched/syscalls.c
diff options
context:
space:
mode:
authorAboorva Devarajan <aboorvad@linux.ibm.com>2024-10-26 00:20:20 +0530
committerPeter Zijlstra <peterz@infradead.org>2024-10-29 13:57:51 +0100
commit5db91545ef8150c45a526675ef99e8998b648a41 (patch)
tree1a1d0ca5b8ecc76b06cee82fbdd5ba51dd7c95c2 /kernel/sched/syscalls.c
parent9c70b2a33cd2aa6a5a59c5523ef053bd42265209 (diff)
downloadlinux-5db91545ef8150c45a526675ef99e8998b648a41.tar.gz
linux-5db91545ef8150c45a526675ef99e8998b648a41.tar.bz2
linux-5db91545ef8150c45a526675ef99e8998b648a41.zip
sched: Pass correct scheduling policy to __setscheduler_class
Commit 98442f0ccd82 ("sched: Fix delayed_dequeue vs switched_from_fair()") overlooked that __setscheduler_prio(), now __setscheduler_class() relies on p->policy for task_should_scx(), and moved the call before __setscheduler_params() updates it, causing it to be using the old p->policy value. Resolve this by changing task_should_scx() to take the policy itself instead of a task pointer, such that __sched_setscheduler() can pass in the updated policy. Fixes: 98442f0ccd82 ("sched: Fix delayed_dequeue vs switched_from_fair()") Signed-off-by: Aboorva Devarajan <aboorvad@linux.ibm.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Acked-by: Tejun Heo <tj@kernel.org>
Diffstat (limited to 'kernel/sched/syscalls.c')
-rw-r--r--kernel/sched/syscalls.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/kernel/sched/syscalls.c b/kernel/sched/syscalls.c
index 0470bcc3d204..24f9f90b6574 100644
--- a/kernel/sched/syscalls.c
+++ b/kernel/sched/syscalls.c
@@ -707,7 +707,7 @@ change:
}
prev_class = p->sched_class;
- next_class = __setscheduler_class(p, newprio);
+ next_class = __setscheduler_class(policy, newprio);
if (prev_class != next_class && p->se.sched_delayed)
dequeue_task(rq, p, DEQUEUE_SLEEP | DEQUEUE_DELAYED | DEQUEUE_NOCLOCK);