From: Oleg Nesterov Date: Wed, 20 Aug 2008 23:54:44 +0000 (-0700) Subject: wait_task_inactive: "improve" the returned value for ->nvcsw == 0 X-Git-Tag: v2.6.28-rc1~725^2~2^2~25 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=93dcf55f828b035fc93fc19eb03c1390e1e6d570;p=linux-2.6-omap-h63xx.git wait_task_inactive: "improve" the returned value for ->nvcsw == 0 wait_task_inactive() returns 1 when p->nvcsw == 0 || p->nvcsw == 1. This means that two subsequent calls can return the same number while the task was scheduled in between. Change the code to return "nvcsw | LONG_MIN" instead of "nvcsw ?: 1", now the overlap always needs LONG_MAX schedules. Signed-off-by: Oleg Nesterov Signed-off-by: Andrew Morton Signed-off-by: Ingo Molnar --- diff --git a/kernel/sched.c b/kernel/sched.c index 908670aa215..6a43c8942b0 100644 --- a/kernel/sched.c +++ b/kernel/sched.c @@ -1922,7 +1922,7 @@ unsigned long wait_task_inactive(struct task_struct *p, long match_state) on_rq = p->se.on_rq; ncsw = 0; if (!match_state || p->state == match_state) - ncsw = p->nvcsw ?: 1; + ncsw = p->nvcsw | LONG_MIN; /* sets MSB */ task_rq_unlock(rq, &flags); /*