aboutsummaryrefslogtreecommitdiffstats
path: root/include/linux/srcu.h
diff options
context:
space:
mode:
authorLai Jiangshan <laijs@cn.fujitsu.com>2012-02-27 12:29:09 -0500
committerPaul E. McKenney <paulmck@linux.vnet.ibm.com>2012-04-30 13:48:22 -0400
commitb52ce066c55a6a53cf1f8d71308d74f908e31b99 (patch)
treee814e4e175f2bd8e1c0795247f413d711c7350df /include/linux/srcu.h
parent18108ebfebe9e871d0a9af830baf8f5df69eb5fc (diff)
rcu: Implement a variant of Peter's SRCU algorithm
This commit implements a variant of Peter's algorithm, which may be found at https://lkml.org/lkml/2012/2/1/119. o Make the checking lock-free to enable parallel checking. Parallel checking is required when (1) the original checking task is preempted for a long time, (2) sychronize_srcu_expedited() starts during an ongoing SRCU grace period, or (3) we wish to avoid acquiring a lock. o Since the checking is lock-free, we avoid a mutex in state machine for call_srcu(). o Remove the SRCU_REF_MASK and remove the coupling with the flipping. This might allow us to remove the preempt_disable() in future versions, though such removal will need great care because it rescinds the one-old-reader-per-CPU guarantee. o Remove a smp_mb(), simplify the comments and make the smp_mb() pairs more intuitive. Inspired-by: Peter Zijlstra <peterz@infradead.org> Signed-off-by: Lai Jiangshan <laijs@cn.fujitsu.com> Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Diffstat (limited to 'include/linux/srcu.h')
-rw-r--r--include/linux/srcu.h7
1 files changed, 1 insertions, 6 deletions
diff --git a/include/linux/srcu.h b/include/linux/srcu.h
index 5b49d41868c8..15354db3e865 100644
--- a/include/linux/srcu.h
+++ b/include/linux/srcu.h
@@ -32,18 +32,13 @@
32 32
33struct srcu_struct_array { 33struct srcu_struct_array {
34 unsigned long c[2]; 34 unsigned long c[2];
35 unsigned long seq[2];
35}; 36};
36 37
37/* Bit definitions for field ->c above and ->snap below. */
38#define SRCU_USAGE_BITS 1
39#define SRCU_REF_MASK (ULONG_MAX >> SRCU_USAGE_BITS)
40#define SRCU_USAGE_COUNT (SRCU_REF_MASK + 1)
41
42struct srcu_struct { 38struct srcu_struct {
43 unsigned completed; 39 unsigned completed;
44 struct srcu_struct_array __percpu *per_cpu_ref; 40 struct srcu_struct_array __percpu *per_cpu_ref;
45 struct mutex mutex; 41 struct mutex mutex;
46 unsigned long snap[NR_CPUS];
47#ifdef CONFIG_DEBUG_LOCK_ALLOC 42#ifdef CONFIG_DEBUG_LOCK_ALLOC
48 struct lockdep_map dep_map; 43 struct lockdep_map dep_map;
49#endif /* #ifdef CONFIG_DEBUG_LOCK_ALLOC */ 44#endif /* #ifdef CONFIG_DEBUG_LOCK_ALLOC */