blob: d8cec84f149e8d2340b23420f389a557e5249f1e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
/* { dg-do run } */
/* { dg-options "-O3 -fcilkplus" } */
/* FIXME: This test has been xfailed until reductions are fixed. */
int argc = 1;
/* This is a simple vectorization test. It tests if reduction works
and if it can vectorize the loop in func correctly. */
#define N 1000
int func (int *p, int *q) {
int x = 0;
#pragma simd reduction (+:x)
for (int ii = 0; ii < N; ii++) {
x += (q[ii] + p[ii]);
}
return x;
}
int main ()
{
int ii = 0, x;
int Array[N], Array2[N];
for (ii = 0; ii < N; ii++)
{
Array[ii] = 5 + argc;
Array2[ii] = argc;
}
x = func (Array, Array2);
if (x != N * 7)
return 1;
return 0;
}
|