blob: df8f537b29f3c0e42a40082eebb96c937f2d763c [file] [log] [blame]
/* { dg-do compile } */
/* { dg-options "-O2 -ffast-math" } */
/* { dg-prune-output "non-standard ABI extension" } */
/* { dg-additional-options "-fno-common" { target hppa*-*-hpux* } } */
/* { dg-additional-options "-msse" { target { i?86-*-* x86_64-*-* } } } */
/* { dg-require-effective-target int32plus } */
typedef float __m128 __attribute__ ((__vector_size__ (16)));
__m128 a, d, e;
int b;
struct dt_interpolation c;
__m128
fn1 (float p1)
{
return (__attribute__ ((__vector_size__ (4 * sizeof 0))) float){ p1 };
}
__m128
fn2 (float p1)
{
return fn1 (p1);
}
struct dt_interpolation
{
int width;
};
void
fn3 (struct dt_interpolation *p1, int *p2)
{
int i = 0, n = 0;
while (i < 2 * p1->width)
n = i++;
*p2 = n;
}
void
fn4 ()
{
__m128 f;
fn3 (&c, &b);
__m128 g = fn2 (1.f / b);
e = (__m128){};
__m128 h = e;
for (int i = 0; i < 2 * c.width; i++)
{
for (; c.width;)
f = a;
h = f;
}
d = h * g;
}