acb6c96c52
The names on the first line of the litmus tests are arbitrary, but the convention is that they be the filename without the trailing ".litmus". This commit therefore removes the stray trailing ".litmus" from ISA2+pooncelock+pooncelock+pombonce.litmus's name. Reported-by: Andrea Parri <andrea.parri@amarulasolutions.com> Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com> Acked-by: Alan Stern <stern@rowland.harvard.edu> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: akiyks@gmail.com Cc: boqun.feng@gmail.com Cc: dhowells@redhat.com Cc: j.alglave@ucl.ac.uk Cc: linux-arch@vger.kernel.org Cc: luc.maranget@inria.fr Cc: npiggin@gmail.com Cc: parri.andrea@gmail.com Cc: will.deacon@arm.com Link: http://lkml.kernel.org/r/20180716180605.16115-2-paulmck@linux.vnet.ibm.com Signed-off-by: Ingo Molnar <mingo@kernel.org>
41 lines
645 B
Text
41 lines
645 B
Text
C ISA2+pooncelock+pooncelock+pombonce
|
|
|
|
(*
|
|
* Result: Sometimes
|
|
*
|
|
* This test shows that the ordering provided by a lock-protected S
|
|
* litmus test (P0() and P1()) are not visible to external process P2().
|
|
* This is likely to change soon.
|
|
*)
|
|
|
|
{}
|
|
|
|
P0(int *x, int *y, spinlock_t *mylock)
|
|
{
|
|
spin_lock(mylock);
|
|
WRITE_ONCE(*x, 1);
|
|
WRITE_ONCE(*y, 1);
|
|
spin_unlock(mylock);
|
|
}
|
|
|
|
P1(int *y, int *z, spinlock_t *mylock)
|
|
{
|
|
int r0;
|
|
|
|
spin_lock(mylock);
|
|
r0 = READ_ONCE(*y);
|
|
WRITE_ONCE(*z, 1);
|
|
spin_unlock(mylock);
|
|
}
|
|
|
|
P2(int *x, int *z)
|
|
{
|
|
int r1;
|
|
int r2;
|
|
|
|
r2 = READ_ONCE(*z);
|
|
smp_mb();
|
|
r1 = READ_ONCE(*x);
|
|
}
|
|
|
|
exists (1:r0=1 /\ 2:r2=1 /\ 2:r1=0)
|