1 // { dg-require-effective-target size32plus }
2 // { dg-additional-options "-O2 -fopenmp -fdump-tree-vect-details" }
3 // { dg-additional-options "-msse2" { target sse2_runtime } }
4 // { dg-additional-options "-mavx" { target avx_runtime } }
5 // { dg-final { scan-tree-dump-times "vectorized \[2-6] loops" 2 "vect" { target sse2_runtime } } }
7 extern "C" void abort ();
8 int r, a[1024], b[1024], q;
10 #pragma omp declare reduction (foo: int: omp_out += omp_in) initializer (omp_priv = 0)
12 __attribute__((noipa)) void
13 foo (int *a, int *b, int &r)
15 #pragma omp for simd reduction (inscan, foo:r)
16 for (int i = 0; i < 1024; i++)
19 #pragma omp scan inclusive(r)
24 __attribute__((noipa)) int
30 #pragma omp for simd reduction (inscan, foo:s) if (0)
31 for (int i = 0; i < 1024; i++)
34 #pragma omp scan inclusive(s)
40 __attribute__((noipa)) void
41 baz (int *a, int *b, int &r)
43 #pragma omp parallel for simd simdlen (1) reduction (inscan, foo:r)
44 for (int i = 0; i < 1024; i++)
47 #pragma omp scan inclusive(r)
52 __attribute__((noipa)) int
57 #pragma omp parallel for simd reduction (inscan, foo:s)
58 for (int i = 0; i < 1024; i++)
61 #pragma omp scan inclusive(s)
71 for (int i = 0; i < 1024; ++i)
79 if (r != 1024 * 1023 / 2)
81 for (int i = 0; i < 1024; ++i)
89 if (bar () != 1024 * 1023)
92 for (int i = 0; i < 1024; ++i)
102 if (r != 1024 * 1023 / 2)
105 for (int i = 0; i < 1024; ++i)
113 if (qux () != 1024 * 1023)
116 for (int i = 0; i < 1024; ++i)