diff options
author | Lai Jiangshan <laijs@cn.fujitsu.com> | 2012-02-27 12:29:09 -0500 |
---|---|---|
committer | Paul E. McKenney <paulmck@linux.vnet.ibm.com> | 2012-04-30 13:48:22 -0400 |
commit | b52ce066c55a6a53cf1f8d71308d74f908e31b99 (patch) | |
tree | e814e4e175f2bd8e1c0795247f413d711c7350df /include/linux/srcu.h | |
parent | 18108ebfebe9e871d0a9af830baf8f5df69eb5fc (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.h | 7 |
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 | ||
33 | struct srcu_struct_array { | 33 | struct 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 | |||
42 | struct srcu_struct { | 38 | struct 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 */ |