This is the mail archive of the
gcc-bugs@gcc.gnu.org
mailing list for the GCC project.
[Bug tree-optimization/70729] Loop marked with omp simd pragma is not vectorized
- From: "jakub at gcc dot gnu.org" <gcc-bugzilla at gcc dot gnu dot org>
- To: gcc-bugs at gcc dot gnu dot org
- Date: Mon, 04 Jul 2016 17:17:29 +0000
- Subject: [Bug tree-optimization/70729] Loop marked with omp simd pragma is not vectorized
- Auto-submitted: auto-generated
- References: <bug-70729-4@http.gcc.gnu.org/bugzilla/>
https://gcc.gnu.org/bugzilla/show_bug.cgi?id=70729
--- Comment #38 from Jakub Jelinek <jakub at gcc dot gnu.org> ---
Sorry, make that
__attribute__((noinline, noclone)) void
baz (int *p, int *q, int *r, int *s)
{
#pragma omp simd
for (int i = 0; i < 1024; i++)
{
p[i] += q[0] * 6;
r[i] += s[0] * 9;
}
}
int v[2048];
int
main ()
{
v[1023] = 5;
baz (v, v + 1023, v + 1024, v + 1023);
int i;
for (i = 0; i < 1023; i++)
if (v[i] != 5 * 6 || v[1024 + i] != 5 * 9)
__builtin_abort ();
if (v[i] != 5 * 6 + 5 || v[2047] != (5 * 6 + 5) * 9)
__builtin_abort ();
return 0;
}
This passes without -fopenmp/-fopenmp-simd. Anyway, I've raised it on
omp-lang.