Commit c5c18dd1 by James Greenhalgh

Fix to commit 193651.

gcc/testsuite/
	* gcc.target/aarch64/atomic-comp-swap-release-acquire.c:
	Actually add this file.
	* gcc.target/aarch64/atomic-op-acq_rel.c: Likewise.
	* gcc.target/aarch64/atomic-op-acquire.c: Likewise.
	* gcc.target/aarch64/atomic-op-char.c: Likewise.
	* gcc.target/aarch64/atomic-op-consume.c: Likewise.
	* gcc.target/aarch64/atomic-op-imm.c: Likewise.
	* gcc.target/aarch64/atomic-op-int.c: Likewise.
	* gcc.target/aarch64/atomic-op-long.c: Likewise.
	* gcc.target/aarch64/atomic-op-relaxed.c: Likewise.
	* gcc.target/aarch64/atomic-op-release.c: Likewise.
	* gcc.target/aarch64/atomic-op-seq_cst.c: Likewise.
	* gcc.target/aarch64/atomic-op-short.c: Likewise.

From-SVN: r193654
parent 86c818c2
/* { dg-do compile } */
/* { dg-options "-O2" } */
#define STRONG 0
#define WEAK 1
int v = 0;
int
atomic_compare_exchange_STRONG_RELEASE_ACQUIRE (int a, int b)
{
return __atomic_compare_exchange (&v, &a, &b,
STRONG, __ATOMIC_RELEASE,
__ATOMIC_ACQUIRE);
}
int
atomic_compare_exchange_WEAK_RELEASE_ACQUIRE (int a, int b)
{
return __atomic_compare_exchange (&v, &a, &b,
WEAK, __ATOMIC_RELEASE,
__ATOMIC_ACQUIRE);
}
int
atomic_compare_exchange_n_STRONG_RELEASE_ACQUIRE (int a, int b)
{
return __atomic_compare_exchange_n (&v, &a, b,
STRONG, __ATOMIC_RELEASE,
__ATOMIC_ACQUIRE);
}
int
atomic_compare_exchange_n_WEAK_RELEASE_ACQUIRE (int a, int b)
{
return __atomic_compare_exchange_n (&v, &a, b,
WEAK, __ATOMIC_RELEASE,
__ATOMIC_ACQUIRE);
}
/* { dg-final { scan-assembler-times "ldaxr\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 4 } } */
/* { dg-final { scan-assembler-times "stlxr\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 4 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
int v = 0;
int
atomic_fetch_add_ACQ_REL (int a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_ACQ_REL);
}
int
atomic_fetch_sub_ACQ_REL (int a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_ACQ_REL);
}
int
atomic_fetch_and_ACQ_REL (int a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_ACQ_REL);
}
int
atomic_fetch_nand_ACQ_REL (int a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_ACQ_REL);
}
int
atomic_fetch_xor_ACQ_REL (int a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_ACQ_REL);
}
int
atomic_fetch_or_ACQ_REL (int a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_ACQ_REL);
}
/* { dg-final { scan-assembler-times "ldaxr\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stlxr\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
int v = 0;
int
atomic_fetch_add_ACQUIRE (int a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_ACQUIRE);
}
int
atomic_fetch_sub_ACQUIRE (int a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_ACQUIRE);
}
int
atomic_fetch_and_ACQUIRE (int a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_ACQUIRE);
}
int
atomic_fetch_nand_ACQUIRE (int a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_ACQUIRE);
}
int
atomic_fetch_xor_ACQUIRE (int a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_ACQUIRE);
}
int
atomic_fetch_or_ACQUIRE (int a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_ACQUIRE);
}
/* { dg-final { scan-assembler-times "ldaxr\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stxr\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
char v = 0;
char
atomic_fetch_add_RELAXED (char a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_RELAXED);
}
char
atomic_fetch_sub_RELAXED (char a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_RELAXED);
}
char
atomic_fetch_and_RELAXED (char a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_RELAXED);
}
char
atomic_fetch_nand_RELAXED (char a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_RELAXED);
}
char
atomic_fetch_xor_RELAXED (char a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_RELAXED);
}
char
atomic_fetch_or_RELAXED (char a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_RELAXED);
}
/* { dg-final { scan-assembler-times "ldxrb\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stxrb\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
int v = 0;
int
atomic_fetch_add_CONSUME (int a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_CONSUME);
}
int
atomic_fetch_sub_CONSUME (int a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_CONSUME);
}
int
atomic_fetch_and_CONSUME (int a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_CONSUME);
}
int
atomic_fetch_nand_CONSUME (int a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_CONSUME);
}
int
atomic_fetch_xor_CONSUME (int a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_CONSUME);
}
int
atomic_fetch_or_CONSUME (int a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_CONSUME);
}
/* { dg-final { scan-assembler-times "ldxr\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stxr\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
int v = 0;
int
atomic_fetch_add_RELAXED ()
{
return __atomic_fetch_add (&v, 4096, __ATOMIC_RELAXED);
}
int
atomic_fetch_sub_ACQUIRE ()
{
return __atomic_fetch_sub (&v, 4096, __ATOMIC_ACQUIRE);
}
int
atomic_fetch_and_SEQ_CST ()
{
return __atomic_fetch_and (&v, 4096, __ATOMIC_SEQ_CST);
}
int
atomic_fetch_nand_ACQ_REL ()
{
return __atomic_fetch_nand (&v, 4096, __ATOMIC_ACQ_REL);
}
int
atomic_fetch_xor_CONSUME ()
{
return __atomic_fetch_xor (&v, 4096, __ATOMIC_CONSUME);
}
int
atomic_fetch_or_RELAXED ()
{
return __atomic_fetch_or (&v, 4096, __ATOMIC_RELAXED);
}
int
atomic_add_fetch_ACQUIRE ()
{
return __atomic_add_fetch (&v, 4096, __ATOMIC_ACQUIRE);
}
int
atomic_sub_fetch_RELAXED ()
{
return __atomic_sub_fetch (&v, 4096, __ATOMIC_RELAXED);
}
int
atomic_and_fetch_SEQ_CST ()
{
return __atomic_and_fetch (&v, 4096, __ATOMIC_SEQ_CST);
}
int
atomic_nand_fetch_ACQUIRE ()
{
return __atomic_nand_fetch (&v, 4096, __ATOMIC_ACQUIRE);
}
int
atomic_xor_fetch_RELEASE ()
{
return __atomic_xor_fetch (&v, 4096, __ATOMIC_RELEASE);
}
int
atomic_or_fetch_CONSUME ()
{
return __atomic_or_fetch (&v, 4096, __ATOMIC_CONSUME);
}
/* { dg-final { scan-assembler-times "\tw\[0-9\]+, w\[0-9\]+, #*4096" 12 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
int v = 0;
int
atomic_fetch_add_RELAXED (int a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_sub_RELAXED (int a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_and_RELAXED (int a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_nand_RELAXED (int a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_xor_RELAXED (int a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_or_RELAXED (int a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_RELAXED);
}
/* { dg-final { scan-assembler-times "ldxr\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stxr\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
long v = 0;
long
atomic_fetch_add_RELAXED (long a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_RELAXED);
}
long
atomic_fetch_sub_RELAXED (long a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_RELAXED);
}
long
atomic_fetch_and_RELAXED (long a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_RELAXED);
}
long
atomic_fetch_nand_RELAXED (long a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_RELAXED);
}
long
atomic_fetch_xor_RELAXED (long a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_RELAXED);
}
long
atomic_fetch_or_RELAXED (long a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_RELAXED);
}
/* { dg-final { scan-assembler-times "ldxr\tx\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stxr\tw\[0-9\]+, x\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
int v = 0;
int
atomic_fetch_add_RELAXED (int a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_sub_RELAXED (int a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_and_RELAXED (int a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_nand_RELAXED (int a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_xor_RELAXED (int a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_RELAXED);
}
int
atomic_fetch_or_RELAXED (int a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_RELAXED);
}
/* { dg-final { scan-assembler-times "ldxr\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stxr\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
int v = 0;
int
atomic_fetch_add_RELEASE (int a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_RELEASE);
}
int
atomic_fetch_sub_RELEASE (int a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_RELEASE);
}
int
atomic_fetch_and_RELEASE (int a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_RELEASE);
}
int
atomic_fetch_nand_RELEASE (int a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_RELEASE);
}
int
atomic_fetch_xor_RELEASE (int a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_RELEASE);
}
int
atomic_fetch_or_RELEASE (int a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_RELEASE);
}
/* { dg-final { scan-assembler-times "ldxr\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stlxr\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
int v = 0;
int
atomic_fetch_add_SEQ_CST (int a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_SEQ_CST);
}
int
atomic_fetch_sub_SEQ_CST (int a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_SEQ_CST);
}
int
atomic_fetch_and_SEQ_CST (int a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_SEQ_CST);
}
int
atomic_fetch_nand_SEQ_CST (int a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_SEQ_CST);
}
int
atomic_fetch_xor_SEQ_CST (int a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_SEQ_CST);
}
int
atomic_fetch_or_SEQ_CST (int a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_SEQ_CST);
}
/* { dg-final { scan-assembler-times "ldaxr\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stlxr\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-do compile } */
/* { dg-options "-O2" } */
short v = 0;
short
atomic_fetch_add_RELAXED (short a)
{
return __atomic_fetch_add (&v, a, __ATOMIC_RELAXED);
}
short
atomic_fetch_sub_RELAXED (short a)
{
return __atomic_fetch_sub (&v, a, __ATOMIC_RELAXED);
}
short
atomic_fetch_and_RELAXED (short a)
{
return __atomic_fetch_and (&v, a, __ATOMIC_RELAXED);
}
short
atomic_fetch_nand_RELAXED (short a)
{
return __atomic_fetch_nand (&v, a, __ATOMIC_RELAXED);
}
short
atomic_fetch_xor_RELAXED (short a)
{
return __atomic_fetch_xor (&v, a, __ATOMIC_RELAXED);
}
short
atomic_fetch_or_RELAXED (short a)
{
return __atomic_fetch_or (&v, a, __ATOMIC_RELAXED);
}
/* { dg-final { scan-assembler-times "ldxrh\tw\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
/* { dg-final { scan-assembler-times "stxrh\tw\[0-9\]+, w\[0-9\]+, \\\[x\[0-9\]+\\\]" 6 } } */
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment