Based on kernel version 6.11
. Page generated on 2024-09-24 08:21 EST
.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 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) |