nohz: Move idle balancer registration to the idle path
authorFrederic Weisbecker <fweisbec@gmail.com>
Mon, 19 Jun 2017 02:12:01 +0000 (04:12 +0200)
committerIngo Molnar <mingo@kernel.org>
Thu, 22 Jun 2017 09:30:01 +0000 (11:30 +0200)
The idle load balancing registration path assumes that we only stop the
tick when the CPU is idle, ignoring the nohz full case. As a result, a
nohz full CPU that is running a task may be chosen to perform idle load
balancing.

Lets make sure that only CPUs in dynticks idle mode can be picked as
idle load balancers.

Signed-off-by: Frederic Weisbecker <fweisbec@gmail.com>
Acked-by: Rik van Riel <riel@redhat.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Link: http://lkml.kernel.org/r/1497838322-10913-3-git-send-email-fweisbec@gmail.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
kernel/time/tick-sched.c

index b1b58a07e04218b10e26539e7285ca53cd7026e6..db023e9cbb254dc0d90c54b03a91ca0021987512 100644 (file)
@@ -782,7 +782,6 @@ static ktime_t tick_nohz_stop_sched_tick(struct tick_sched *ts,
         * the scheduler tick in nohz_restart_sched_tick.
         */
        if (!ts->tick_stopped) {
-               nohz_balance_enter_idle(cpu);
                calc_load_nohz_start();
                cpu_load_update_nohz_start();
 
@@ -923,8 +922,10 @@ static void __tick_nohz_idle_enter(struct tick_sched *ts)
                        ts->idle_expires = expires;
                }
 
-               if (!was_stopped && ts->tick_stopped)
+               if (!was_stopped && ts->tick_stopped) {
                        ts->idle_jiffies = ts->last_jiffies;
+                       nohz_balance_enter_idle(cpu);
+               }
        }
 }