diff options
author | Paul E. McKenney <paulmck@linux.vnet.ibm.com> | 2010-02-26 19:38:56 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2010-02-27 03:53:52 -0500 |
commit | a47cd880b50e14b0b6f5e9d426ae9a2676c9c474 (patch) | |
tree | c134dcec52450ec92ea853f4aeeef8e3967a36cb /kernel/rcutree.c | |
parent | f5f654096487c6d526c47bb66308f9de81f091cf (diff) |
rcu: Fix accelerated grace periods for last non-dynticked CPU
It is invalid to invoke __rcu_process_callbacks() with irqs
disabled, so do it indirectly via raise_softirq(). This
requires a state-machine implementation to cycle through the
grace-period machinery the required number of times.
Located-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Cc: laijs@cn.fujitsu.com
Cc: dipankar@in.ibm.com
Cc: mathieu.desnoyers@polymtl.ca
Cc: josh@joshtriplett.org
Cc: dvhltc@us.ibm.com
Cc: niv@us.ibm.com
Cc: peterz@infradead.org
Cc: rostedt@goodmis.org
Cc: Valdis.Kletnieks@vt.edu
Cc: dhowells@redhat.com
LKML-Reference: <1267231138-27856-1-git-send-email-paulmck@linux.vnet.ibm.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/rcutree.c')
-rw-r--r-- | kernel/rcutree.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/kernel/rcutree.c b/kernel/rcutree.c index 335bfe4f007..3ec8160fc75 100644 --- a/kernel/rcutree.c +++ b/kernel/rcutree.c | |||
@@ -1341,6 +1341,9 @@ static void rcu_process_callbacks(struct softirq_action *unused) | |||
1341 | * grace-period manipulations above. | 1341 | * grace-period manipulations above. |
1342 | */ | 1342 | */ |
1343 | smp_mb(); /* See above block comment. */ | 1343 | smp_mb(); /* See above block comment. */ |
1344 | |||
1345 | /* If we are last CPU on way to dyntick-idle mode, accelerate it. */ | ||
1346 | rcu_needs_cpu_flush(); | ||
1344 | } | 1347 | } |
1345 | 1348 | ||
1346 | static void | 1349 | static void |