summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/gcc-have-sync-compare-and-swap.c
blob: 5affeba19f23ea88bd3418378227967acf358f58 (plain)
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/* { dg-do link } */
/* MIPS only supports these built-in functions for non-MIPS16 mode, and
   -mflip-mips16 will change the mode of some functions to be different
   from the command-line setting.  */
/* { dg-skip-if "" { mips*-*-* } { "-mflip-mips16" } { "" } } */

void f1()
{
#ifdef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1
  typedef int __attribute__  ((__mode__ (__QI__))) qi_int_type;
  qi_int_type qi_int;
  __sync_bool_compare_and_swap (&qi_int, (qi_int_type)0, (qi_int_type)1);
#endif
}

void f2()
{
#ifdef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2
  typedef int __attribute__ ((__mode__ (__HI__))) hi_int_type;
  hi_int_type hi_int;
  __sync_bool_compare_and_swap (&hi_int, (hi_int_type)0, (hi_int_type)1);
#endif
}

void f4()
{
#ifdef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4
  typedef int __attribute__ ((__mode__ (__SI__))) si_int_type;
  si_int_type si_int;
  __sync_bool_compare_and_swap (&si_int, (si_int_type)0, (si_int_type)1);
#endif
}

void f8()
{
#ifdef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8
  typedef int __attribute__ ((__mode__ (__DI__))) di_int_type;
  di_int_type di_int;
  __sync_bool_compare_and_swap (&di_int, (di_int_type)0, (di_int_type)1);
#endif
}

/* aligned (16): On S/390 16 byte compare and swap operations are only
   available if the memory operand resides on a 16 byte boundary.  */
void f16()
{
#ifdef __GCC_HAVE_SYNC_COMPARE_AND_SWAP_16
  typedef int __attribute__ ((__mode__ (__TI__), aligned (16))) ti_int_type;
  ti_int_type ti_int;
  __sync_bool_compare_and_swap (&ti_int, (ti_int_type)0, (ti_int_type)1);
#endif
}

int main()
{
  f1();
  f2();
  f4();
  f8();
  f16();  
  return 0;
}