Merge tag 'block-5.11-2021-01-10' of git://git.kernel.dk/linux-block
[linux/fpc-iii.git] / tools / memory-model / litmus-tests / MP+polockonce+poacquiresilsil.litmus
blobaad64397bb8cd4c0e9daa7f429676c9c704b09da
1 C MP+polockonce+poacquiresilsil
3 (*
4  * Result: Sometimes
5  *
6  * Do spinlocks provide order to outside observers using spin_is_locked()
7  * to sense the lock-held state, ordered by acquire?  Note that when the
8  * first spin_is_locked() returns false and the second true, we know that
9  * the smp_load_acquire() executed before the lock was acquired (loosely
10  * speaking).
11  *)
14         spinlock_t lo;
15         int x;
18 P0(spinlock_t *lo, int *x) // Producer
20         spin_lock(lo);
21         WRITE_ONCE(*x, 1);
22         spin_unlock(lo);
25 P1(spinlock_t *lo, int *x) // Consumer
27         int r1;
28         int r2;
29         int r3;
31         r1 = smp_load_acquire(x);
32         r2 = spin_is_locked(lo);
33         r3 = spin_is_locked(lo);
36 exists (1:r1=1 /\ 1:r2=0 /\ 1:r3=1) (* Bad outcome. *)