annotate gcc/testsuite/c-c++-common/goacc/pr70688.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 const int n = 100;
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 int
kono
parents:
diff changeset
4 private_reduction ()
kono
parents:
diff changeset
5 {
kono
parents:
diff changeset
6 int i, r;
kono
parents:
diff changeset
7
kono
parents:
diff changeset
8 #pragma acc parallel
kono
parents:
diff changeset
9 #pragma acc loop private (r) reduction (+:r)
kono
parents:
diff changeset
10 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
11 r += 10;
kono
parents:
diff changeset
12
kono
parents:
diff changeset
13 return r;
kono
parents:
diff changeset
14 }
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 int
kono
parents:
diff changeset
17 parallel_reduction ()
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 int sum = 0;
kono
parents:
diff changeset
20 int dummy = 0;
kono
parents:
diff changeset
21
kono
parents:
diff changeset
22 #pragma acc data copy (dummy)
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 #pragma acc parallel num_gangs (10) copy (sum) reduction (+:sum)
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 int v = 5;
kono
parents:
diff changeset
27 sum += 10 + v;
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 return sum;
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 int
kono
parents:
diff changeset
35 main ()
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 int i, s = 0;
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 #pragma acc parallel num_gangs (10) copy (s) reduction (+:s)
kono
parents:
diff changeset
40 for (i = 0; i < n; i++)
kono
parents:
diff changeset
41 s += i+1;
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 #pragma acc parallel num_gangs (10) reduction (+:s) copy (s)
kono
parents:
diff changeset
44 for (i = 0; i < n; i++)
kono
parents:
diff changeset
45 s += i+1;
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 return 0;
kono
parents:
diff changeset
48 }