Commit 284749b0 authored by Alan Stern's avatar Alan Stern Committed by Paul E. McKenney

tools/memory-model: Refactor some RCU relations

In preparation for adding support for SRCU, refactor the definitions
of rcu-fence, rcu-rscsi, rcu-link, and rb by moving the po and po?
terms from the first two to the second two.  An rcu-gp relation is
added; it is equivalent to gp with the po and po? terms removed.

This is necessary because for SRCU, we will have to use the loc
relation to check that the terms at the start and end of each disjunct
in the definition of rcu-fence refer to the same srcu_struct
location.  If these terms are hidden behind po and po?, there's no way
to carry out this check.
Signed-off-by: default avatarAlan Stern <stern@rowland.harvard.edu>
Signed-off-by: default avatarPaul E. McKenney <paulmck@linux.ibm.com>
Tested-by: default avatarAndrea Parri <andrea.parri@amarulasolutions.com>
parent 0172d9e3
...@@ -91,32 +91,37 @@ acyclic pb as propagation ...@@ -91,32 +91,37 @@ acyclic pb as propagation
(*******) (*******)
(* (*
* Effect of read-side critical section proceeds from the rcu_read_lock() * Effects of read-side critical sections proceed from the rcu_read_unlock()
* onward on the one hand and from the rcu_read_unlock() backwards on the * backwards on the one hand, and from the rcu_read_lock() forwards on the
* other hand. * other hand.
*
* In the definition of rcu-fence below, the po term at the left-hand side
* of each disjunct and the po? term at the right-hand end have been factored
* out. They have been moved into the definitions of rcu-link and rb.
*) *)
let rcu-rscsi = po ; rcu-rscs^-1 ; po? let rcu-gp = [Sync-rcu] (* Compare with gp *)
let rcu-rscsi = rcu-rscs^-1
(* (*
* The synchronize_rcu() strong fence is special in that it can order not * The synchronize_rcu() strong fence is special in that it can order not
* one but two non-rf relations, but only in conjunction with an RCU * one but two non-rf relations, but only in conjunction with an RCU
* read-side critical section. * read-side critical section.
*) *)
let rcu-link = hb* ; pb* ; prop let rcu-link = po? ; hb* ; pb* ; prop ; po
(* (*
* Any sequence containing at least as many grace periods as RCU read-side * Any sequence containing at least as many grace periods as RCU read-side
* critical sections (joined by rcu-link) acts as a generalized strong fence. * critical sections (joined by rcu-link) acts as a generalized strong fence.
*) *)
let rec rcu-fence = gp | let rec rcu-fence = rcu-gp |
(gp ; rcu-link ; rcu-rscsi) | (rcu-gp ; rcu-link ; rcu-rscsi) |
(rcu-rscsi ; rcu-link ; gp) | (rcu-rscsi ; rcu-link ; rcu-gp) |
(gp ; rcu-link ; rcu-fence ; rcu-link ; rcu-rscsi) | (rcu-gp ; rcu-link ; rcu-fence ; rcu-link ; rcu-rscsi) |
(rcu-rscsi ; rcu-link ; rcu-fence ; rcu-link ; gp) | (rcu-rscsi ; rcu-link ; rcu-fence ; rcu-link ; rcu-gp) |
(rcu-fence ; rcu-link ; rcu-fence) (rcu-fence ; rcu-link ; rcu-fence)
(* rb orders instructions just as pb does *) (* rb orders instructions just as pb does *)
let rb = prop ; rcu-fence ; hb* ; pb* let rb = prop ; po ; rcu-fence ; po? ; hb* ; pb*
irreflexive rb as rcu irreflexive rb as rcu
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment