annotate libgomp/testsuite/libgomp.c/cancel-for-2.c @ 138:fc828634a951

merge
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Thu, 08 Nov 2018 14:17:14 +0900
parents 04ced10e8804
children 1830386684a0
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 /* { dg-set-target-env-var OMP_CANCELLATION "true" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 #include <stdlib.h>
kono
parents:
diff changeset
5 #include <omp.h>
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 __attribute__((noinline, noclone)) int
kono
parents:
diff changeset
8 foo (int *x)
kono
parents:
diff changeset
9 {
kono
parents:
diff changeset
10 int v = 0, w = 0;
kono
parents:
diff changeset
11 #pragma omp parallel num_threads (32) shared (v, w)
kono
parents:
diff changeset
12 {
kono
parents:
diff changeset
13 int i;
kono
parents:
diff changeset
14 #pragma omp for
kono
parents:
diff changeset
15 for (i = 0; i < 1000; ++i)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 #pragma omp cancel for if (x[0])
kono
parents:
diff changeset
18 abort ();
kono
parents:
diff changeset
19 }
kono
parents:
diff changeset
20 #pragma omp for
kono
parents:
diff changeset
21 for (i = 0; i < 1000; ++i)
kono
parents:
diff changeset
22 {
kono
parents:
diff changeset
23 #pragma omp cancel for if (x[1])
kono
parents:
diff changeset
24 #pragma omp atomic
kono
parents:
diff changeset
25 v++;
kono
parents:
diff changeset
26 }
kono
parents:
diff changeset
27 #pragma omp for
kono
parents:
diff changeset
28 for (i = 0; i < 1000; ++i)
kono
parents:
diff changeset
29 {
kono
parents:
diff changeset
30 #pragma omp cancel for if (x[2])
kono
parents:
diff changeset
31 #pragma omp atomic
kono
parents:
diff changeset
32 w += 8;
kono
parents:
diff changeset
33 }
kono
parents:
diff changeset
34 #pragma omp for
kono
parents:
diff changeset
35 for (i = 0; i < 1000; ++i)
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 #pragma omp cancel for if (x[3])
kono
parents:
diff changeset
38 #pragma omp atomic
kono
parents:
diff changeset
39 v += 2;
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42 if (v != 3000 || w != 0)
kono
parents:
diff changeset
43 abort ();
kono
parents:
diff changeset
44 #pragma omp parallel num_threads (32) shared (v, w)
kono
parents:
diff changeset
45 {
kono
parents:
diff changeset
46 int i;
kono
parents:
diff changeset
47 /* None of these cancel directives should actually cancel anything,
kono
parents:
diff changeset
48 but the compiler shouldn't know that and thus should use cancellable
kono
parents:
diff changeset
49 barriers at the end of all the workshares. */
kono
parents:
diff changeset
50 #pragma omp cancel parallel if (omp_get_thread_num () == 1 && x[4])
kono
parents:
diff changeset
51 #pragma omp for
kono
parents:
diff changeset
52 for (i = 0; i < 1000; ++i)
kono
parents:
diff changeset
53 {
kono
parents:
diff changeset
54 #pragma omp cancel for if (x[0])
kono
parents:
diff changeset
55 abort ();
kono
parents:
diff changeset
56 }
kono
parents:
diff changeset
57 #pragma omp cancel parallel if (omp_get_thread_num () == 2 && x[4])
kono
parents:
diff changeset
58 #pragma omp for
kono
parents:
diff changeset
59 for (i = 0; i < 1000; ++i)
kono
parents:
diff changeset
60 {
kono
parents:
diff changeset
61 #pragma omp cancel for if (x[1])
kono
parents:
diff changeset
62 #pragma omp atomic
kono
parents:
diff changeset
63 v++;
kono
parents:
diff changeset
64 }
kono
parents:
diff changeset
65 #pragma omp cancel parallel if (omp_get_thread_num () == 3 && x[4])
kono
parents:
diff changeset
66 #pragma omp for
kono
parents:
diff changeset
67 for (i = 0; i < 1000; ++i)
kono
parents:
diff changeset
68 {
kono
parents:
diff changeset
69 #pragma omp cancel for if (x[2])
kono
parents:
diff changeset
70 #pragma omp atomic
kono
parents:
diff changeset
71 w += 8;
kono
parents:
diff changeset
72 }
kono
parents:
diff changeset
73 #pragma omp cancel parallel if (omp_get_thread_num () == 4 && x[4])
kono
parents:
diff changeset
74 #pragma omp for
kono
parents:
diff changeset
75 for (i = 0; i < 1000; ++i)
kono
parents:
diff changeset
76 {
kono
parents:
diff changeset
77 #pragma omp cancel for if (x[3])
kono
parents:
diff changeset
78 #pragma omp atomic
kono
parents:
diff changeset
79 v += 2;
kono
parents:
diff changeset
80 }
kono
parents:
diff changeset
81 #pragma omp cancel parallel if (omp_get_thread_num () == 5 && x[4])
kono
parents:
diff changeset
82 }
kono
parents:
diff changeset
83 if (v != 6000 || w != 0)
kono
parents:
diff changeset
84 abort ();
kono
parents:
diff changeset
85 return 0;
kono
parents:
diff changeset
86 }
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 int
kono
parents:
diff changeset
89 main ()
kono
parents:
diff changeset
90 {
kono
parents:
diff changeset
91 int x[] = { 1, 0, 1, 0, 0 };
kono
parents:
diff changeset
92 if (omp_get_cancellation ())
kono
parents:
diff changeset
93 foo (x);
kono
parents:
diff changeset
94 return 0;
kono
parents:
diff changeset
95 }