On Tue, Dec 17, 2013 at 03:34:54PM -0800, Paul E. McKenney wrote: > On Tue, Dec 17, 2013 at 11:51:30PM +0100, Frederic Weisbecker wrote: > > When a full dynticks CPU wakes up from sysidle state, which means that > > all full dynticks CPUs were previously sleeping, it's possible that > > all the potential timekeeping CPUs are sleeping as well and nobody > > maintains the associated duty. > > > > But full dynticks CPUs don't run the tick by definition so we need > > to wake up a timekeeper such that it can handle the timekeeping > > duty on behalf of the freshly awoken full dyntick CPU. > > > > To achieve this and ensure that this CPU won't deal with stale > > jiffies values, lets wake up the default timekeeper using the right > > API. > > > > Signed-off-by: Frederic Weisbecker <fweis...@gmail.com> > > Cc: Thomas Gleixner <t...@linutronix.de> > > Cc: Ingo Molnar <mi...@kernel.org> > > Cc: Peter Zijlstra <pet...@infradead.org> > > Cc: Steven Rostedt <rost...@goodmis.org> > > Cc: Paul E. McKenney <paul...@linux.vnet.ibm.com> > > Cc: John Stultz <john.stu...@linaro.org> > > Cc: Alex Shi <alex....@linaro.org> > > Cc: Kevin Hilman <khil...@linaro.org> > > --- > > kernel/rcu/tree_plugin.h | 2 +- > > kernel/time/tick-sched.c | 3 ++- > > 2 files changed, 3 insertions(+), 2 deletions(-) > > > > diff --git a/kernel/rcu/tree_plugin.h b/kernel/rcu/tree_plugin.h > > index 1795265..b43e32d 100644 > > --- a/kernel/rcu/tree_plugin.h > > +++ b/kernel/rcu/tree_plugin.h > > @@ -2488,7 +2488,7 @@ void rcu_sysidle_force_exit(void) > > oldstate, RCU_SYSIDLE_NOT); > > if (oldstate == newoldstate && > > oldstate == RCU_SYSIDLE_FULL_NOTED) { > > - smp_send_reschedule(tick_timekeeping_default_cpu()); > > + tick_nohz_full_kick_timekeeping(); > > OK, I guess I should look at the patches in order. So yes, it is no > longer safe to just kick tick_do_timer_cpu. ;-)
Hehe, I do linear reviews as well ;) Indeed it's no longer safe, especially since tick_do_timer_cpu can be TICK_DO_TIMER_NONE. So this always kick CPU 0 instead (for now). -- 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/