10a665a83SHal Finkel // RUN: %libomp-compile-and-run
20a665a83SHal Finkel #include <stdio.h>
30a665a83SHal Finkel
main()40a665a83SHal Finkel int main()
50a665a83SHal Finkel {
60a665a83SHal Finkel
7*0af71797SJonathan Peyton int i;
80a665a83SHal Finkel int i1 = 0;
90a665a83SHal Finkel int i2 = 1;
100a665a83SHal Finkel int i3 = 2;
110a665a83SHal Finkel int i4 = 3;
120a665a83SHal Finkel int i5 = 4;
130a665a83SHal Finkel int i6 = 6;
140a665a83SHal Finkel int i7 = 7;
150a665a83SHal Finkel int i8 = 8;
160a665a83SHal Finkel int i9 = 9;
170a665a83SHal Finkel int i10 = 10;
180a665a83SHal Finkel int i11 = 11;
190a665a83SHal Finkel int i12 = 12;
200a665a83SHal Finkel int i13 = 13;
210a665a83SHal Finkel int i14 = 14;
220a665a83SHal Finkel int i15 = 15;
230a665a83SHal Finkel int i16 = 16;
240a665a83SHal Finkel
250a665a83SHal Finkel int r = 0;
260a665a83SHal Finkel #pragma omp parallel for firstprivate(i1, i2, i3, i4, i5, i6, i7, i8, i9, i10, i11, i12, i13, i14, i15, i16) reduction(+:r)
27*0af71797SJonathan Peyton for (i = 0; i < i16; i++) {
280a665a83SHal Finkel r += i + i1 + i2 + i3 + i4 + i5 + i6 + i7 + i8 + i9 + i10 + i11 + i12 + i13 + i14 + i15 + i16;
290a665a83SHal Finkel }
300a665a83SHal Finkel
310a665a83SHal Finkel int rf = 2216;
320a665a83SHal Finkel if (r != rf) {
330a665a83SHal Finkel fprintf(stderr, "r should be %d but instead equals %d\n", rf, r);
340a665a83SHal Finkel return 1;
350a665a83SHal Finkel }
360a665a83SHal Finkel
370a665a83SHal Finkel return 0;
380a665a83SHal Finkel }
390a665a83SHal Finkel
40