annotate gcc/testsuite/c-c++-common/gomp/pr81887.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 /* PR c/81887 */
kono
parents:
diff changeset
2 /* { dg-do compile } */
kono
parents:
diff changeset
3 /* { dg-options "-fno-openmp -fopenmp-simd -fdump-tree-gimple" } */
kono
parents:
diff changeset
4 /* { dg-final { scan-tree-dump-times "#pragma omp simd" 2 "gimple" } } */
kono
parents:
diff changeset
5 /* { dg-final { scan-tree-dump-times "#pragma omp ordered simd\[ \t]*\[\n\r]" 2 "gimple" } } */
kono
parents:
diff changeset
6 /* { dg-final { scan-tree-dump-times "#pragma omp" 4 "gimple" } } */
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 void
kono
parents:
diff changeset
9 f1 (int *x)
kono
parents:
diff changeset
10 {
kono
parents:
diff changeset
11 int i;
kono
parents:
diff changeset
12 #pragma omp simd
kono
parents:
diff changeset
13 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
14 #pragma omp ordered simd
kono
parents:
diff changeset
15 x[i / 2] = i;
kono
parents:
diff changeset
16 }
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 void
kono
parents:
diff changeset
19 f2 (int *x)
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 int i;
kono
parents:
diff changeset
22 #pragma omp parallel for simd ordered
kono
parents:
diff changeset
23 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
24 #pragma omp ordered threads simd
kono
parents:
diff changeset
25 x[i / 2] = i;
kono
parents:
diff changeset
26 }
kono
parents:
diff changeset
27
kono
parents:
diff changeset
28 void
kono
parents:
diff changeset
29 f3 (int *x)
kono
parents:
diff changeset
30 {
kono
parents:
diff changeset
31 int i;
kono
parents:
diff changeset
32 #pragma omp parallel for ordered
kono
parents:
diff changeset
33 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
34 #pragma omp ordered
kono
parents:
diff changeset
35 x[i / 2] = i;
kono
parents:
diff changeset
36 }
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 void
kono
parents:
diff changeset
39 f4 (int *x)
kono
parents:
diff changeset
40 {
kono
parents:
diff changeset
41 int i;
kono
parents:
diff changeset
42 #pragma omp parallel for ordered
kono
parents:
diff changeset
43 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
44 #pragma omp ordered threads
kono
parents:
diff changeset
45 x[i / 2] = i;
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 void
kono
parents:
diff changeset
49 f5 (int n, int ***x)
kono
parents:
diff changeset
50 {
kono
parents:
diff changeset
51 int i, j, k;
kono
parents:
diff changeset
52 #pragma omp parallel for ordered(3)
kono
parents:
diff changeset
53 for (i=0; i < n; i++)
kono
parents:
diff changeset
54 for (j=0; j < n; ++j)
kono
parents:
diff changeset
55 for (k=0; k < n; ++k)
kono
parents:
diff changeset
56 {
kono
parents:
diff changeset
57 #pragma omp ordered depend(sink:i-8,j-2,k+2) depend(sink:i, j-1,k) depend(sink:i-4,j-3,k+6) depend(sink:i-6,j-4,k-6)
kono
parents:
diff changeset
58 x[i][j][k] = i + j + k;
kono
parents:
diff changeset
59 #pragma omp ordered depend(source)
kono
parents:
diff changeset
60 }
kono
parents:
diff changeset
61 }