diff options
author | Ingo Molnar <mingo@elte.hu> | 2011-05-27 06:38:52 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2011-05-28 11:41:05 -0400 |
commit | 29f742f88a32c9ab8cf6d9ba69e1ea918be5aa58 (patch) | |
tree | a38aa38c8025e050ec82a7e64d02dca07f90ffc7 /kernel/rcutree_plugin.h | |
parent | f62508f68d04adefc4cf9b0177ba02c8818b3eec (diff) | |
parent | 23b5c8fa01b723c70a20d6e4ef4ff54c7656d6e1 (diff) |
Merge branch 'rcu/urgent' of git://git.kernel.org/pub/scm/linux/kernel/git/paulmck/linux-2.6-rcu into core/urgent
Diffstat (limited to 'kernel/rcutree_plugin.h')
-rw-r--r-- | kernel/rcutree_plugin.h | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/kernel/rcutree_plugin.h b/kernel/rcutree_plugin.h index 3f6559a5f5cd..ed339702481d 100644 --- a/kernel/rcutree_plugin.h +++ b/kernel/rcutree_plugin.h | |||
@@ -1520,7 +1520,6 @@ int rcu_needs_cpu(int cpu) | |||
1520 | { | 1520 | { |
1521 | int c = 0; | 1521 | int c = 0; |
1522 | int snap; | 1522 | int snap; |
1523 | int snap_nmi; | ||
1524 | int thatcpu; | 1523 | int thatcpu; |
1525 | 1524 | ||
1526 | /* Check for being in the holdoff period. */ | 1525 | /* Check for being in the holdoff period. */ |
@@ -1531,10 +1530,10 @@ int rcu_needs_cpu(int cpu) | |||
1531 | for_each_online_cpu(thatcpu) { | 1530 | for_each_online_cpu(thatcpu) { |
1532 | if (thatcpu == cpu) | 1531 | if (thatcpu == cpu) |
1533 | continue; | 1532 | continue; |
1534 | snap = per_cpu(rcu_dynticks, thatcpu).dynticks; | 1533 | snap = atomic_add_return(0, &per_cpu(rcu_dynticks, |
1535 | snap_nmi = per_cpu(rcu_dynticks, thatcpu).dynticks_nmi; | 1534 | thatcpu).dynticks); |
1536 | smp_mb(); /* Order sampling of snap with end of grace period. */ | 1535 | smp_mb(); /* Order sampling of snap with end of grace period. */ |
1537 | if (((snap & 0x1) != 0) || ((snap_nmi & 0x1) != 0)) { | 1536 | if ((snap & 0x1) != 0) { |
1538 | per_cpu(rcu_dyntick_drain, cpu) = 0; | 1537 | per_cpu(rcu_dyntick_drain, cpu) = 0; |
1539 | per_cpu(rcu_dyntick_holdoff, cpu) = jiffies - 1; | 1538 | per_cpu(rcu_dyntick_holdoff, cpu) = jiffies - 1; |
1540 | return rcu_needs_cpu_quick_check(cpu); | 1539 | return rcu_needs_cpu_quick_check(cpu); |