C cmpxchg-fail-ordered-1 (* * Result: Never * * Demonstrate that a failing cmpxchg() operation will act as a full * barrier when followed by smp_mb__after_atomic(). *) {} P0(int *x, int *y, int *z) { int r0; int r1; WRITE_ONCE(*x, 1); r1 = cmpxchg(z, 1, 0); smp_mb__after_atomic(); r0 = READ_ONCE(*y); } P1(int *x, int *y, int *z) { int r0; int r1; WRITE_ONCE(*y, 1); r1 = cmpxchg(z, 1, 0); smp_mb__after_atomic(); r0 = READ_ONCE(*x); } locations[0:r1;1:r1] exists (0:r0=0 /\ 1:r0=0)