diff options
author | Alan Stern <stern@rowland.harvard.edu> | 2018-11-15 11:19:44 -0500 |
---|---|---|
committer | Paul E. McKenney <paulmck@linux.ibm.com> | 2019-03-18 13:23:22 -0400 |
commit | 0172d9e322035bf7bb66a7dfdd795c38d71dbba9 (patch) | |
tree | 5ff3936ecfaa5a837dca01d296f72741b2f36b77 /tools/memory-model | |
parent | 9e98c678c2d6ae3a17cb2de55d17f69dddaa231b (diff) |
tools/memory-model: Rename some RCU relations
In preparation for adding support for SRCU, rename "crit" to
"rcu-rscs", rename "rscs" to "rcu-rscsi", and remove the restriction
to only the outermost level of nesting.
The name change is needed for disambiguating RCU read-side critical
sections from SRCU read-side critical sections. Adding the "i" at the
end of "rcu-rscsi" emphasizes that the relation is inverted; it links
rcu_read_unlock() events to their corresponding preceding
rcu_read_lock() events.
The restriction to outermost nesting levels was never essential; it
was included mostly to show that it could be done. Rather than add
equivalent unnecessary code for SRCU lock nesting, it seemed better to
remove the existing code.
Signed-off-by: Alan Stern <stern@rowland.harvard.edu>
Signed-off-by: Paul E. McKenney <paulmck@linux.ibm.com>
Tested-by: Andrea Parri <andrea.parri@amarulasolutions.com>
Diffstat (limited to 'tools/memory-model')
-rw-r--r-- | tools/memory-model/linux-kernel.bell | 9 | ||||
-rw-r--r-- | tools/memory-model/linux-kernel.cat | 10 |
2 files changed, 8 insertions, 11 deletions
diff --git a/tools/memory-model/linux-kernel.bell b/tools/memory-model/linux-kernel.bell index 796513362c05..353c8d68e030 100644 --- a/tools/memory-model/linux-kernel.bell +++ b/tools/memory-model/linux-kernel.bell | |||
@@ -34,7 +34,7 @@ enum Barriers = 'wmb (*smp_wmb*) || | |||
34 | instructions F[Barriers] | 34 | instructions F[Barriers] |
35 | 35 | ||
36 | (* Compute matching pairs of nested Rcu-lock and Rcu-unlock *) | 36 | (* Compute matching pairs of nested Rcu-lock and Rcu-unlock *) |
37 | let matched = let rec | 37 | let rcu-rscs = let rec |
38 | unmatched-locks = Rcu-lock \ domain(matched) | 38 | unmatched-locks = Rcu-lock \ domain(matched) |
39 | and unmatched-unlocks = Rcu-unlock \ range(matched) | 39 | and unmatched-unlocks = Rcu-unlock \ range(matched) |
40 | and unmatched = unmatched-locks | unmatched-unlocks | 40 | and unmatched = unmatched-locks | unmatched-unlocks |
@@ -46,8 +46,5 @@ let matched = let rec | |||
46 | in matched | 46 | in matched |
47 | 47 | ||
48 | (* Validate nesting *) | 48 | (* Validate nesting *) |
49 | flag ~empty Rcu-lock \ domain(matched) as unbalanced-rcu-locking | 49 | flag ~empty Rcu-lock \ domain(rcu-rscs) as unbalanced-rcu-locking |
50 | flag ~empty Rcu-unlock \ range(matched) as unbalanced-rcu-locking | 50 | flag ~empty Rcu-unlock \ range(rcu-rscs) as unbalanced-rcu-locking |
51 | |||
52 | (* Outermost level of nesting only *) | ||
53 | let crit = matched \ (po^-1 ; matched ; po^-1) | ||
diff --git a/tools/memory-model/linux-kernel.cat b/tools/memory-model/linux-kernel.cat index 8f23c74a96fd..ab9de9c1234b 100644 --- a/tools/memory-model/linux-kernel.cat +++ b/tools/memory-model/linux-kernel.cat | |||
@@ -95,7 +95,7 @@ acyclic pb as propagation | |||
95 | * onward on the one hand and from the rcu_read_unlock() backwards on the | 95 | * onward on the one hand and from the rcu_read_unlock() backwards on the |
96 | * other hand. | 96 | * other hand. |
97 | *) | 97 | *) |
98 | let rscs = po ; crit^-1 ; po? | 98 | let rcu-rscsi = po ; rcu-rscs^-1 ; po? |
99 | 99 | ||
100 | (* | 100 | (* |
101 | * The synchronize_rcu() strong fence is special in that it can order not | 101 | * The synchronize_rcu() strong fence is special in that it can order not |
@@ -109,10 +109,10 @@ let rcu-link = hb* ; pb* ; prop | |||
109 | * critical sections (joined by rcu-link) acts as a generalized strong fence. | 109 | * critical sections (joined by rcu-link) acts as a generalized strong fence. |
110 | *) | 110 | *) |
111 | let rec rcu-fence = gp | | 111 | let rec rcu-fence = gp | |
112 | (gp ; rcu-link ; rscs) | | 112 | (gp ; rcu-link ; rcu-rscsi) | |
113 | (rscs ; rcu-link ; gp) | | 113 | (rcu-rscsi ; rcu-link ; gp) | |
114 | (gp ; rcu-link ; rcu-fence ; rcu-link ; rscs) | | 114 | (gp ; rcu-link ; rcu-fence ; rcu-link ; rcu-rscsi) | |
115 | (rscs ; rcu-link ; rcu-fence ; rcu-link ; gp) | | 115 | (rcu-rscsi ; rcu-link ; rcu-fence ; rcu-link ; gp) | |
116 | (rcu-fence ; rcu-link ; rcu-fence) | 116 | (rcu-fence ; rcu-link ; rcu-fence) |
117 | 117 | ||
118 | (* rb orders instructions just as pb does *) | 118 | (* rb orders instructions just as pb does *) |