Chuck Ebbert 69a476b
From: Suresh Siddha <suresh.b.siddha@intel.com>
Chuck Ebbert 69a476b
Date: Mon, 13 Sep 2010 18:02:21 +0000 (-0700)
Chuck Ebbert 69a476b
Subject: sched: Fix nohz balance kick
Chuck Ebbert 69a476b
X-Git-Url: http://git.kernel.org/?p=linux%2Fkernel%2Fgit%2Ftorvalds%2Flinux-2.6.git;a=commitdiff_plain;h=f6c3f1686e7ec1dd8725a9a3dcb857dfd0c7a5bf
Chuck Ebbert 69a476b
Chuck Ebbert 69a476b
sched: Fix nohz balance kick
Chuck Ebbert 69a476b
Chuck Ebbert 69a476b
There's a situation where the nohz balancer will try to wake itself:
Chuck Ebbert 69a476b
Chuck Ebbert 69a476b
cpu-x is idle which is also ilb_cpu
Chuck Ebbert 69a476b
got a scheduler tick during idle
Chuck Ebbert 69a476b
and the nohz_kick_needed() in trigger_load_balance() checks for
Chuck Ebbert 69a476b
rq_x->nr_running which might not be zero (because of someone waking a
Chuck Ebbert 69a476b
task on this rq etc) and this leads to the situation of the cpu-x
Chuck Ebbert 69a476b
sending a kick to itself.
Chuck Ebbert 69a476b
Chuck Ebbert 69a476b
And this can cause a lockup.
Chuck Ebbert 69a476b
Chuck Ebbert 69a476b
Avoid this by not marking ourself eligible for kicking.
Chuck Ebbert 69a476b
Chuck Ebbert 69a476b
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Chuck Ebbert 69a476b
Signed-off-by: Peter Zijlstra <a.p.zijlstra@chello.nl>
Chuck Ebbert 69a476b
LKML-Reference: <1284400941.2684.19.camel@sbsiddha-MOBL3.sc.intel.com>
Chuck Ebbert 69a476b
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Chuck Ebbert 69a476b
---
Chuck Ebbert 69a476b
Chuck Ebbert 69a476b
diff --git a/kernel/sched_fair.c b/kernel/sched_fair.c
Chuck Ebbert 69a476b
index a171138..db3f674 100644
Chuck Ebbert 69a476b
--- a/kernel/sched_fair.c
Chuck Ebbert 69a476b
+++ b/kernel/sched_fair.c
Chuck Ebbert 69a476b
@@ -3630,7 +3630,7 @@ static inline int nohz_kick_needed(struct rq *rq, int cpu)
Chuck Ebbert 69a476b
 	if (time_before(now, nohz.next_balance))
Chuck Ebbert 69a476b
 		return 0;
Chuck Ebbert 69a476b
 
Chuck Ebbert 69a476b
-	if (!rq->nr_running)
Chuck Ebbert 69a476b
+	if (rq->idle_at_tick)
Chuck Ebbert 69a476b
 		return 0;
Chuck Ebbert 69a476b
 
Chuck Ebbert 69a476b
 	first_pick_cpu = atomic_read(&nohz.first_pick_cpu);