From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752197Ab1HPUUQ (ORCPT ); Tue, 16 Aug 2011 16:20:16 -0400 Received: from e2.ny.us.ibm.com ([32.97.182.142]:59638 "EHLO e2.ny.us.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751887Ab1HPUUO (ORCPT ); Tue, 16 Aug 2011 16:20:14 -0400 Date: Tue, 16 Aug 2011 13:20:05 -0700 From: "Paul E. McKenney" To: Frederic Weisbecker Cc: LKML , Andrew Morton , Anton Blanchard , Avi Kivity , Ingo Molnar , Lai Jiangshan , Paul Menage , Peter Zijlstra , Stephen Hemminger , Thomas Gleixner , Tim Pepper Subject: Re: [PATCH 22/32] rcu: Restart tick if we enqueue a callback in a nohz/cpuset CPU Message-ID: <20110816202005.GH2404@linux.vnet.ibm.com> Reply-To: paulmck@linux.vnet.ibm.com References: <1313423549-27093-1-git-send-email-fweisbec@gmail.com> <1313423549-27093-23-git-send-email-fweisbec@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1313423549-27093-23-git-send-email-fweisbec@gmail.com> User-Agent: Mutt/1.5.20 (2009-06-14) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Aug 15, 2011 at 05:52:19PM +0200, Frederic Weisbecker wrote: > If we enqueue an rcu callback, we need the CPU tick to stay > alive until we take care of those by completing the appropriate > grace period. > > Thus, when we call_rcu(), send a self IPI that checks rcu_needs_cpu() > so that we restore a periodic tick behaviour that can take care of > everything. One question below. Thanx, Paul > Signed-off-by: Frederic Weisbecker > Cc: Andrew Morton > Cc: Anton Blanchard > Cc: Avi Kivity > Cc: Ingo Molnar > Cc: Lai Jiangshan > Cc: Paul E . McKenney > Cc: Paul Menage > Cc: Peter Zijlstra > Cc: Stephen Hemminger > Cc: Thomas Gleixner > Cc: Tim Pepper > --- > kernel/rcutree.c | 8 ++++++++ > 1 files changed, 8 insertions(+), 0 deletions(-) > > diff --git a/kernel/rcutree.c b/kernel/rcutree.c > index d496c70..b5643ce2 100644 > --- a/kernel/rcutree.c > +++ b/kernel/rcutree.c > @@ -51,6 +51,7 @@ > #include > #include > #include > +#include > > #include "rcutree.h" > > @@ -1546,6 +1547,13 @@ __call_rcu(struct rcu_head *head, void (*func)(struct rcu_head *rcu), > rdp->nxttail[RCU_NEXT_TAIL] = &head->next; > rdp->qlen++; > > + /* Restart the timer if needed to handle the callbacks */ > + if (tick_nohz_adaptive_mode()) { > + /* Make updates on nxtlist visible to self IPI */ > + barrier(); > + smp_cpuset_update_nohz(smp_processor_id()); > + } > + But this must be happening in a system call or interrupt handler, right? If so, won't we get a chance to check things on exit from the system call or interrupt? Or are you hooking only into syscall entry? > /* If interrupts were disabled, don't dive into RCU core. */ > if (irqs_disabled_flags(flags)) { > local_irq_restore(flags); > -- > 1.7.5.4 >