On Fri, 28 Feb 2014 14:50:43 +0400 Kirill Tkhai <ktk...@parallels.com> wrote:
> Thomas, have you seen this? > > Nothing works at the moment: > Noticed the same once rebased on tip/master as of today. > now > > 21 root 20 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/3 > > > 16 root 20 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/2 > > > 11 root 20 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/1 > > > 10 root 20 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0 > > 22 root 20 0 0 0 0 S 0.0 0.0 0:00.00 migration/3 > > > 17 root 20 0 0 0 0 S 0.0 0.0 0:00.00 migration/2 > > > 12 root 20 0 0 0 0 S 0.0 0.0 0:00.04 migration/1 > > > 9 root 20 0 0 0 0 S 0.0 0.0 0:00.20 migration/0 > > with fix > > 21 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/3 > > 16 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/2 > > 11 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/1 > > 10 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0 > > 22 root RT 0 0 0 0 S 0.0 0.0 0:00.00 migration/3 > > > 17 root RT 0 0 0 0 S 0.0 0.0 0:00.03 migration/2 > > > 12 root RT 0 0 0 0 S 0.0 0.0 0:00.00 migration/1 > > > 9 root RT 0 0 0 0 S 0.0 0.0 0:00.24 migration/0 > > В Чт, 27/02/2014 в 14:24 +0400, Kirill Tkhai пишет: > > [PATCH]sched/core: Return possibility to set RT and DL classes back > > > > I found that it's impossible to set RT policy for tasks at the moment. > > > > This is regression after commit [sched: Consider pi boosting in > > setscheduler()] > > [c365c292d05908c6ea6f32708f331e21033fe71d ] > > Fix that. > > > > Signed-off-by: Kirill Tkhai <ktk...@parallels.com> > > CC: Thomas Gleixner <t...@linutronix.de> > > CC: Peter Zijlstra <pet...@infradead.org> > > CC: Ingo Molnar <mi...@redhat.com> > > --- > > kernel/sched/core.c | 4 ++++ > > 1 file changed, 4 insertions(+) > > diff --git a/kernel/sched/core.c b/kernel/sched/core.c > > index 84b23ce..30cf9ad 100644 > > --- a/kernel/sched/core.c > > +++ b/kernel/sched/core.c > > @@ -3193,6 +3193,10 @@ static void __setscheduler_params(struct task_struct > > *p, > > * getparam()/getattr() don't report silly values for !rt tasks. > > */ > > p->rt_priority = attr->sched_priority; > > + > > + p->normal_prio = normal_prio(p); > > + p->prio = rt_mutex_getprio(p); > > + > > set_load_weight(p); > > } > > > > I'd propose what follows, so that we can still use __setscheduler_params() as it is. Regards, - Juri >From 73bae0ad978db6e75f492eea9adff12ec9d6d2a3 Mon Sep 17 00:00:00 2001 From: Juri Lelli <juri.le...@gmail.com> Date: Sat, 1 Mar 2014 16:43:30 +0100 Subject: [PATCH] sched/core: restore __setscheduler() behavior Commit c365c29 introduced __setscheduler_params(), that is now used to only store a task's new scheduling parameters in the case it is priority boosted. Before this change, __setscheduler() was in charge of changing tasks normal_prio and prio, and the latter is used to actually perform sched_class change. Unfortunately, the commit above broke this behavior, causing tasks to remain in fair_sched_class. Restore the old behaviour setting normal_prio and prio to the right values after the __setscheduler_params() call. Signed-off-by: Juri Lelli <juri.le...@gmail.com> --- kernel/sched/core.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/kernel/sched/core.c b/kernel/sched/core.c index ee8004c..04ae20d 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -3206,6 +3206,13 @@ static void __setscheduler(struct rq *rq, struct task_struct *p, { __setscheduler_params(p, attr); + /* + * Since we checked before with rt_mutex_check_prio(), + * we don't have pi waiters or our top waiter has lower + * priority (user space view) than what we got. + */ + p->prio = p->normal_prio = normal_prio(p); + if (dl_prio(p->prio)) p->sched_class = &dl_sched_class; else if (rt_prio(p->prio)) -- 1.7.9.5 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/