annotate gcc/testsuite/gcc.dg/atomic-load-2.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Test __atomic routines for existence and proper execution on 2 byte
kono
parents:
diff changeset
2 values with each valid memory model. */
kono
parents:
diff changeset
3 /* { dg-do run } */
kono
parents:
diff changeset
4 /* { dg-require-effective-target sync_char_short } */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 /* Test the execution of the __atomic_load_n builtin for a short. */
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 extern void abort(void);
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 short v, count;
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 int
kono
parents:
diff changeset
15 main ()
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 v = 0;
kono
parents:
diff changeset
18 count = 0;
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 if (__atomic_load_n (&v, __ATOMIC_RELAXED) != count++)
kono
parents:
diff changeset
21 abort();
kono
parents:
diff changeset
22 else
kono
parents:
diff changeset
23 v++;
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 if (__atomic_load_n (&v, __ATOMIC_ACQUIRE) != count++)
kono
parents:
diff changeset
26 abort();
kono
parents:
diff changeset
27 else
kono
parents:
diff changeset
28 v++;
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 if (__atomic_load_n (&v, __ATOMIC_CONSUME) != count++)
kono
parents:
diff changeset
31 abort();
kono
parents:
diff changeset
32 else
kono
parents:
diff changeset
33 v++;
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 if (__atomic_load_n (&v, __ATOMIC_SEQ_CST) != count++)
kono
parents:
diff changeset
36 abort();
kono
parents:
diff changeset
37 else
kono
parents:
diff changeset
38 v++;
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 /* Now test the generic variants. */
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 __atomic_load (&v, &count, __ATOMIC_RELAXED);
kono
parents:
diff changeset
43 if (count != v)
kono
parents:
diff changeset
44 abort();
kono
parents:
diff changeset
45 else
kono
parents:
diff changeset
46 v++;
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 __atomic_load (&v, &count, __ATOMIC_ACQUIRE);
kono
parents:
diff changeset
49 if (count != v)
kono
parents:
diff changeset
50 abort();
kono
parents:
diff changeset
51 else
kono
parents:
diff changeset
52 v++;
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 __atomic_load (&v, &count, __ATOMIC_CONSUME);
kono
parents:
diff changeset
55 if (count != v)
kono
parents:
diff changeset
56 abort();
kono
parents:
diff changeset
57 else
kono
parents:
diff changeset
58 v++;
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 __atomic_load (&v, &count, __ATOMIC_SEQ_CST);
kono
parents:
diff changeset
61 if (count != v)
kono
parents:
diff changeset
62 abort();
kono
parents:
diff changeset
63 else
kono
parents:
diff changeset
64 v++;
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 return 0;
kono
parents:
diff changeset
68 }
kono
parents:
diff changeset
69