From: Dmitry Adamushko Date: Mon, 15 Oct 2007 15:00:14 +0000 (+0200) Subject: sched: fix group scheduling for SCHED_BATCH X-Git-Tag: v2.6.24-rc1~1289^2~31 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=e62dd02ed0af35631c6ca473e50758c9594773cf;p=linux-2.6-omap-h63xx.git sched: fix group scheduling for SCHED_BATCH The following patch (sched: disable sleeper_fairness on SCHED_BATCH) seems to break GROUP_SCHED. Although, it may be 'oops'-less due to the possibility of 'p' being always a valid address. Signed-off-by: Dmitry Adamushko Signed-off-by: Ingo Molnar --- diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c index 410b77aea21..3ac096e74fa 100644 --- a/kernel/sched_fair.c +++ b/kernel/sched_fair.c @@ -485,9 +485,8 @@ place_entity(struct cfs_rq *cfs_rq, struct sched_entity *se, int initial) vruntime += sched_vslice_add(cfs_rq, se); if (!initial) { - struct task_struct *p = container_of(se, struct task_struct, se); - - if (sched_feat(NEW_FAIR_SLEEPERS) && p->policy != SCHED_BATCH) + if (sched_feat(NEW_FAIR_SLEEPERS) && entity_is_task(se) && + task_of(se)->policy != SCHED_BATCH) vruntime -= sysctl_sched_latency; vruntime = max_t(s64, vruntime, se->vruntime);