diff options
| author | Aboorva Devarajan <aboorvad@linux.ibm.com> | 2024-10-26 00:20:20 +0530 |
|---|---|---|
| committer | Peter Zijlstra <peterz@infradead.org> | 2024-10-29 13:57:51 +0100 |
| commit | 5db91545ef8150c45a526675ef99e8998b648a41 (patch) | |
| tree | 1a1d0ca5b8ecc76b06cee82fbdd5ba51dd7c95c2 /kernel/sched/syscalls.c | |
| parent | 9c70b2a33cd2aa6a5a59c5523ef053bd42265209 (diff) | |
| download | linux-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.c | 2 |
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); |
