annotate libgomp/testsuite/libgomp.c/atomic-17.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 // { dg-do run }
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 extern void abort (void);
kono
parents:
diff changeset
4 int x = 6;
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 int
kono
parents:
diff changeset
7 main ()
kono
parents:
diff changeset
8 {
kono
parents:
diff changeset
9 int v, l = 2, s = 1;
kono
parents:
diff changeset
10 #pragma omp atomic seq_cst
kono
parents:
diff changeset
11 x = -3 + x;
kono
parents:
diff changeset
12 #pragma omp atomic read seq_cst
kono
parents:
diff changeset
13 v = x;
kono
parents:
diff changeset
14 if (v != 3)
kono
parents:
diff changeset
15 abort ();
kono
parents:
diff changeset
16 #pragma omp atomic seq_cst update
kono
parents:
diff changeset
17 x = 3 * 2 * 1 + x;
kono
parents:
diff changeset
18 #pragma omp atomic read, seq_cst
kono
parents:
diff changeset
19 v = x;
kono
parents:
diff changeset
20 if (v != 9)
kono
parents:
diff changeset
21 abort ();
kono
parents:
diff changeset
22 #pragma omp atomic seq_cst, capture
kono
parents:
diff changeset
23 v = x = x | 16;
kono
parents:
diff changeset
24 if (v != 25)
kono
parents:
diff changeset
25 abort ();
kono
parents:
diff changeset
26 #pragma omp atomic capture seq_cst
kono
parents:
diff changeset
27 v = x = x + 14 * 2 / 4;
kono
parents:
diff changeset
28 if (v != 32)
kono
parents:
diff changeset
29 abort ();
kono
parents:
diff changeset
30 #pragma omp atomic seq_cst capture
kono
parents:
diff changeset
31 v = x = 5 | x;
kono
parents:
diff changeset
32 if (v != 37)
kono
parents:
diff changeset
33 abort ();
kono
parents:
diff changeset
34 #pragma omp atomic capture, seq_cst
kono
parents:
diff changeset
35 v = x = 40 + 12 - 2 - 7 - x;
kono
parents:
diff changeset
36 if (v != 6)
kono
parents:
diff changeset
37 abort ();
kono
parents:
diff changeset
38 #pragma omp atomic seq_cst read
kono
parents:
diff changeset
39 v = x;
kono
parents:
diff changeset
40 if (v != 6)
kono
parents:
diff changeset
41 abort ();
kono
parents:
diff changeset
42 #pragma omp atomic capture seq_cst
kono
parents:
diff changeset
43 { v = x; x = 3 + x; }
kono
parents:
diff changeset
44 if (v != 6)
kono
parents:
diff changeset
45 abort ();
kono
parents:
diff changeset
46 #pragma omp atomic seq_cst capture
kono
parents:
diff changeset
47 { v = x; x = -1 * -1 * -1 * -1 - x; }
kono
parents:
diff changeset
48 if (v != 9)
kono
parents:
diff changeset
49 abort ();
kono
parents:
diff changeset
50 #pragma omp atomic read seq_cst
kono
parents:
diff changeset
51 v = x;
kono
parents:
diff changeset
52 if (v != -8)
kono
parents:
diff changeset
53 abort ();
kono
parents:
diff changeset
54 #pragma omp atomic capture, seq_cst
kono
parents:
diff changeset
55 { x = 2 * 2 - x; v = x; }
kono
parents:
diff changeset
56 if (v != 12)
kono
parents:
diff changeset
57 abort ();
kono
parents:
diff changeset
58 #pragma omp atomic seq_cst capture
kono
parents:
diff changeset
59 { x = 7 & x; v = x; }
kono
parents:
diff changeset
60 if (v != 4)
kono
parents:
diff changeset
61 abort ();
kono
parents:
diff changeset
62 #pragma omp atomic capture seq_cst
kono
parents:
diff changeset
63 { v = x; x = 6; }
kono
parents:
diff changeset
64 if (v != 4)
kono
parents:
diff changeset
65 abort ();
kono
parents:
diff changeset
66 #pragma omp atomic read, seq_cst
kono
parents:
diff changeset
67 v = x;
kono
parents:
diff changeset
68 if (v != 6)
kono
parents:
diff changeset
69 abort ();
kono
parents:
diff changeset
70 #pragma omp atomic capture seq_cst
kono
parents:
diff changeset
71 { v = x; x = 7 * 8 + 23; }
kono
parents:
diff changeset
72 if (v != 6)
kono
parents:
diff changeset
73 abort ();
kono
parents:
diff changeset
74 #pragma omp atomic seq_cst, read
kono
parents:
diff changeset
75 v = x;
kono
parents:
diff changeset
76 if (v != 79)
kono
parents:
diff changeset
77 abort ();
kono
parents:
diff changeset
78 #pragma omp atomic capture , seq_cst
kono
parents:
diff changeset
79 { v = x; x = 23 + 6 * 4; }
kono
parents:
diff changeset
80 if (v != 79)
kono
parents:
diff changeset
81 abort ();
kono
parents:
diff changeset
82 #pragma omp atomic read seq_cst
kono
parents:
diff changeset
83 v = x;
kono
parents:
diff changeset
84 if (v != 47)
kono
parents:
diff changeset
85 abort ();
kono
parents:
diff changeset
86 #pragma omp atomic seq_cst capture
kono
parents:
diff changeset
87 { v = x; x = l ? 17 : 12; }
kono
parents:
diff changeset
88 if (v != 47)
kono
parents:
diff changeset
89 abort ();
kono
parents:
diff changeset
90 #pragma omp atomic capture seq_cst
kono
parents:
diff changeset
91 { v = x; x = l = s++ + 3; }
kono
parents:
diff changeset
92 if (v != 17 || l != 4 || s != 2)
kono
parents:
diff changeset
93 abort ();
kono
parents:
diff changeset
94 #pragma omp atomic read seq_cst
kono
parents:
diff changeset
95 v = x;
kono
parents:
diff changeset
96 if (v != 4)
kono
parents:
diff changeset
97 abort ();
kono
parents:
diff changeset
98 return 0;
kono
parents:
diff changeset
99 }