blob: 46b5f06f30837d152fc99d29f912d66c92af184b [file] [log] [blame]
/* { dg-do run } */
/* { dg-require-effective-target avx } */
/* { dg-options "-Ofast -mavx -mno-avx2" } */
#ifndef CHECK_H
#define CHECK_H "avx-check.h"
#define TEST avx_test
#define SRC "avx-vround-1.c"
#endif
#include CHECK_H
#include SRC
static void
TEST (void)
{
union128d a, ae;
union128 b, be;
union256d c, ce;
union256 d, de;
if (f1 (0.5) != 1.0 || f1 (1.5) != 2.0 || f1 (-0.5) != -1.0 || f1 (-1.5) != -2.0)
abort ();
if (f2 (0.5f) != 1.0f || f2 (1.5f) != 2.0f || f2 (-0.5f) != -1.0f || f2 (-1.5f) != -2.0f)
abort ();
a.x = f3 (_mm_set1_pd (7.0), _mm_set1_pd (0.5));
ae.x = _mm_set_pd (7.0, 0.0);
if (check_union128d (a, ae.a))
abort ();
a.x = f3 (_mm_set1_pd (7.0), _mm_set1_pd (1.5));
ae.x = _mm_set_pd (7.0, 2.0);
if (check_union128d (a, ae.a))
abort ();
a.x = f3 (_mm_set1_pd (7.0), _mm_set1_pd (-0.5));
ae.x = _mm_set_pd (7.0, 0.0);
if (check_union128d (a, ae.a))
abort ();
a.x = f3 (_mm_set1_pd (7.0), _mm_set1_pd (-1.5));
ae.x = _mm_set_pd (7.0, -2.0);
if (check_union128d (a, ae.a))
abort ();
b.x = f4 (_mm_set1_ps (7.0f), _mm_set1_ps (0.5f));
be.x = _mm_set_ps (7.0f, 7.0f, 7.0f, 0.0f);
if (check_union128 (b, be.a))
abort ();
b.x = f4 (_mm_set1_ps (7.0f), _mm_set1_ps (1.5f));
be.x = _mm_set_ps (7.0f, 7.0f, 7.0f, 2.0f);
if (check_union128 (b, be.a))
abort ();
b.x = f4 (_mm_set1_ps (7.0f), _mm_set1_ps (-0.5f));
be.x = _mm_set_ps (7.0f, 7.0f, 7.0f, 0.0f);
if (check_union128 (b, be.a))
abort ();
b.x = f4 (_mm_set1_ps (7.0f), _mm_set1_ps (-1.5f));
be.x = _mm_set_ps (7.0f, 7.0f, 7.0f, -2.0f);
if (check_union128 (b, be.a))
abort ();
a.x = f5 (_mm_set_pd (0.5, 1.5));
ae.x = _mm_set_pd (0.0, 2.0);
if (check_union128d (a, ae.a))
abort ();
a.x = f5 (_mm_set_pd (-0.5, -1.5));
ae.x = _mm_set_pd (0.0, -2.0);
if (check_union128d (a, ae.a))
abort ();
b.x = f6 (_mm_set_ps (0.5f, 1.5f, -0.5f, -1.5f));
be.x = _mm_set_ps (0.0f, 2.0f, 0.0f, -2.0f);
if (check_union128 (b, be.a))
abort ();
c.x = f7 (_mm256_set_pd (0.5, 1.5, -0.5, -1.5));
ce.x = _mm256_set_pd (0.0, 2.0, 0.0, -2.0);
if (check_union256d (c, ce.a))
abort ();
d.x = f8 (_mm256_set_ps (0.5f, 1.5f, -0.5f, -1.5f, 0.25f, 1.0f, -16.5f, 0.75f));
de.x = _mm256_set_ps (0.0f, 2.0f, 0.0f, -2.0f, 0.0f, 1.0f, -16.0f, 1.0f);
if (check_union256 (d, de.a))
abort ();
}