diff options
author | Peter Zijlstra <peterz@infradead.org> | 2009-11-10 14:12:01 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-11-10 14:22:31 -0500 |
commit | ffd44db5f02af32bcc25a8eb5981bf02a141cdab (patch) | |
tree | 75716dc543821a79a1dff0739b43bb0283d400cf /kernel/sched.c | |
parent | eae0c9dfb534cb3449888b9601228efa6480fdb5 (diff) |
sched: Make sure task has correct sched_class after policy change
From the code in rt_mutex_setprio(), it is evident that the
intention is that task's with a RT 'prio' value as a consequence
of receiving a PI boost also have their 'sched_class' field set
to '&rt_sched_class'.
However, Peter noticed that the code in __setscheduler() could
result in this intention being frustrated. Fix it.
Reported-by: Peter Williams <pwil3058@bigpond.net.au>
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Mike Galbraith <efault@gmx.de>
LKML-Reference: <1257880321.4108.457.camel@laptop>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/sched.c')
-rw-r--r-- | kernel/sched.c | 16 |
1 files changed, 4 insertions, 12 deletions
diff --git a/kernel/sched.c b/kernel/sched.c index ad37776cc39b..43e61fa04dc7 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
@@ -6159,22 +6159,14 @@ __setscheduler(struct rq *rq, struct task_struct *p, int policy, int prio) | |||
6159 | BUG_ON(p->se.on_rq); | 6159 | BUG_ON(p->se.on_rq); |
6160 | 6160 | ||
6161 | p->policy = policy; | 6161 | p->policy = policy; |
6162 | switch (p->policy) { | ||
6163 | case SCHED_NORMAL: | ||
6164 | case SCHED_BATCH: | ||
6165 | case SCHED_IDLE: | ||
6166 | p->sched_class = &fair_sched_class; | ||
6167 | break; | ||
6168 | case SCHED_FIFO: | ||
6169 | case SCHED_RR: | ||
6170 | p->sched_class = &rt_sched_class; | ||
6171 | break; | ||
6172 | } | ||
6173 | |||
6174 | p->rt_priority = prio; | 6162 | p->rt_priority = prio; |
6175 | p->normal_prio = normal_prio(p); | 6163 | p->normal_prio = normal_prio(p); |
6176 | /* we are holding p->pi_lock already */ | 6164 | /* we are holding p->pi_lock already */ |
6177 | p->prio = rt_mutex_getprio(p); | 6165 | p->prio = rt_mutex_getprio(p); |
6166 | if (rt_prio(p->prio)) | ||
6167 | p->sched_class = &rt_sched_class; | ||
6168 | else | ||
6169 | p->sched_class = &fair_sched_class; | ||
6178 | set_load_weight(p); | 6170 | set_load_weight(p); |
6179 | } | 6171 | } |
6180 | 6172 | ||