| C cmpxchg-fail-ordered-2 | |
| (* | |
| * Result: Never | |
| * | |
| * Demonstrate use of smp_mb__after_atomic() to make a failing cmpxchg | |
| * operation have acquire ordering. | |
| *) | |
| {} | |
| P0(int *x, int *y) | |
| { | |
| int r1; | |
| WRITE_ONCE(*x, 1); | |
| r1 = cmpxchg(y, 0, 1); | |
| } | |
| P1(int *x, int *y) | |
| { | |
| int r1; | |
| int r2; | |
| r1 = cmpxchg(y, 0, 1); | |
| smp_mb__after_atomic(); | |
| r2 = READ_ONCE(*x); | |
| } | |
| exists (0:r1=0 /\ 1:r1=1 /\ 1:r2=0) |