C S+poonceonces | |
(* | |
* Result: Sometimes | |
* | |
* Starting with a two-process release-acquire chain ordering P0()'s | |
* first store against P1()'s final load, if the smp_store_release() | |
* is replaced by WRITE_ONCE() and the smp_load_acquire() replaced by | |
* READ_ONCE(), is ordering preserved? | |
*) | |
{} | |
P0(int *x, int *y) | |
{ | |
WRITE_ONCE(*x, 2); | |
WRITE_ONCE(*y, 1); | |
} | |
P1(int *x, int *y) | |
{ | |
int r0; | |
r0 = READ_ONCE(*y); | |
WRITE_ONCE(*x, 1); | |
} | |
exists (x=2 /\ 1:r0=1) |