blob: 47afd22d93e5ed8fbfff034cd2a03d8d70f7e422 (
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
|
/* PR middle-end/64421 */
/* { dg-require-effective-target vect_simd_clones } */
/* { dg-additional-options "-fopenmp-simd" } */
/* { dg-additional-options "-mavx" { target avx_runtime } } */
#include "tree-vect.h"
#pragma omp declare simd linear (y) notinbranch
int foo (int x, int y) __asm ("bar");
#pragma omp declare simd linear (y) notinbranch
int
foo (int x, int y)
{
return x + y;
}
int a[1024] = { 1, 2 };
int
main ()
{
int i;
check_vect ();
#pragma omp simd
for (i = 0; i < 1024; i++)
a[i] = foo (a[i], i);
if (a[0] != 1 || a[1] != 3)
abort ();
#pragma GCC novector
for (i = 2; i < 1024; i++)
if (a[i] != i)
abort ();
return 0;
}
|