diff options
author | Paul E. McKenney <paul.mckenney@linaro.org> | 2012-08-21 18:00:05 -0400 |
---|---|---|
committer | Paul E. McKenney <paulmck@linux.vnet.ibm.com> | 2012-09-23 10:41:56 -0400 |
commit | d7d6a11e8609f0319d4a2d8ede348f8b3374b652 (patch) | |
tree | 64a2e3260690a85fe637a3e34c94e8ca540e8fc6 /kernel/rcutree_plugin.h | |
parent | 1943c89de700248d68385300a9b5588a1e314f90 (diff) |
rcu: Simplify quiescent-state detection
The current quiescent-state detection algorithm is needlessly
complex. It records the grace-period number corresponding to
the quiescent state at the time of the quiescent state, which
works, but it seems better to simply erase any record of previous
quiescent states at the time that the CPU notices the new grace
period. This has the further advantage of removing another piece
of RCU for which lockless reasoning is required.
Therefore, this commit makes this change.
Signed-off-by: Paul E. McKenney <paul.mckenney@linaro.org>
Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Reviewed-by: Josh Triplett <josh@joshtriplett.org>
Diffstat (limited to 'kernel/rcutree_plugin.h')
-rw-r--r-- | kernel/rcutree_plugin.h | 2 |
1 files changed, 0 insertions, 2 deletions
diff --git a/kernel/rcutree_plugin.h b/kernel/rcutree_plugin.h index b4e8eb24a5f1..4734afbea73a 100644 --- a/kernel/rcutree_plugin.h +++ b/kernel/rcutree_plugin.h | |||
@@ -137,8 +137,6 @@ static void rcu_preempt_qs(int cpu) | |||
137 | { | 137 | { |
138 | struct rcu_data *rdp = &per_cpu(rcu_preempt_data, cpu); | 138 | struct rcu_data *rdp = &per_cpu(rcu_preempt_data, cpu); |
139 | 139 | ||
140 | rdp->passed_quiesce_gpnum = rdp->gpnum; | ||
141 | barrier(); | ||
142 | if (rdp->passed_quiesce == 0) | 140 | if (rdp->passed_quiesce == 0) |
143 | trace_rcu_grace_period("rcu_preempt", rdp->gpnum, "cpuqs"); | 141 | trace_rcu_grace_period("rcu_preempt", rdp->gpnum, "cpuqs"); |
144 | rdp->passed_quiesce = 1; | 142 | rdp->passed_quiesce = 1; |