95782571f3
* gimplify.c (gimplify_adjust_omp_clauses_1): Handle GOVD_FIRSTPRIVATE | GOVD_LASTPRIVATE. (gimplify_adjust_omp_clauses): Simd region is never directly nested in combined parallel. Instead, for linear with copyin/copyout, if in combined for simd loop, make decl firstprivate/lastprivate on OMP_FOR. * omp-low.c (expand_omp_for_generic, expand_omp_for_static_nochunk, expand_omp_for_static_chunk): When setting endvar, also set fd->loop.v to the same value. libgomp/ * testsuite/libgomp.c/simd-10.c: New test. * testsuite/libgomp.c/simd-11.c: New test. * testsuite/libgomp.c/simd-12.c: New test. * testsuite/libgomp.c/simd-13.c: New test. From-SVN: r210009
20 lines
449 B
C
20 lines
449 B
C
/* { dg-do run } */
|
|
/* { dg-options "-O2" } */
|
|
/* { dg-additional-options "-msse2" { target sse2_runtime } } */
|
|
/* { dg-additional-options "-mavx" { target avx_runtime } } */
|
|
|
|
int
|
|
main ()
|
|
{
|
|
int k = 0, i, s = 0;
|
|
#pragma omp parallel
|
|
#pragma omp for simd linear(k : 3) reduction(+: s) schedule (static, 16)
|
|
for (i = 0; i < 128; i++)
|
|
{
|
|
k = k + 3;
|
|
s = s + k;
|
|
}
|
|
if (s != 128 * 129 / 2 * 3) __builtin_abort ();
|
|
return 0;
|
|
}
|