1 // RUN: %libomp-compile-and-run
2 #include <stdio.h>
3
main()4 int main()
5 {
6
7 int i;
8 int i1 = 0;
9 int i2 = 1;
10 int i3 = 2;
11 int i4 = 3;
12 int i5 = 4;
13 int i6 = 6;
14 int i7 = 7;
15 int i8 = 8;
16 int i9 = 9;
17 int i10 = 10;
18 int i11 = 11;
19 int i12 = 12;
20 int i13 = 13;
21 int i14 = 14;
22 int i15 = 15;
23 int i16 = 16;
24
25 int r = 0;
26 #pragma omp parallel for firstprivate(i1, i2, i3, i4, i5, i6, i7, i8, i9, i10, i11, i12, i13, i14, i15, i16) reduction(+:r)
27 for (i = 0; i < i16; i++) {
28 r += i + i1 + i2 + i3 + i4 + i5 + i6 + i7 + i8 + i9 + i10 + i11 + i12 + i13 + i14 + i15 + i16;
29 }
30
31 int rf = 2216;
32 if (r != rf) {
33 fprintf(stderr, "r should be %d but instead equals %d\n", rf, r);
34 return 1;
35 }
36
37 return 0;
38 }
39
40