C S+fencewmbonceonce+poacquireonce | |
(* | |
* Result: Never | |
* | |
* Can a smp_wmb(), instead of a release, and an acquire order a prior | |
* store against a subsequent store? | |
*) | |
{} | |
P0(int *x, int *y) | |
{ | |
WRITE_ONCE(*x, 2); | |
smp_wmb(); | |
WRITE_ONCE(*y, 1); | |
} | |
P1(int *x, int *y) | |
{ | |
int r0; | |
r0 = smp_load_acquire(y); | |
WRITE_ONCE(*x, 1); | |
} | |
exists (x=2 /\ 1:r0=1) |