blob: ef414f1b2fc2b37770567df853cb096aeefd015b [file] [log] [blame]
/* Test the vfma_f64 AArch64 SIMD intrinsic. */
/* { dg-do run } */
/* { dg-options "-save-temps -O3" } */
#include "arm_neon.h"
#define EPS 1.0e-15
#define INHIB_OPT(x) asm volatile ("mov %d0, %1.d[0]" \
: "=w"(x) \
: "w"(x) \
: /* No clobbers. */);
extern void abort (void);
int
main (void)
{
float64x1_t arg1;
float64x1_t arg2;
float64x1_t arg3;
float64_t expected;
float64_t actual;
arg1 = vcreate_f64 (0x3fe3955382d35b0eULL);
arg2 = vcreate_f64 (0x3fa88480812d6670ULL);
arg3 = vcreate_f64 (0x3fd5791ae2a92572ULL);
INHIB_OPT (arg1);
INHIB_OPT (arg2);
INHIB_OPT (arg3);
expected = 0.6280448184360076;
actual = vget_lane_f64 (vfma_f64 (arg1, arg2, arg3), 0);
if (__builtin_fabs (expected - actual) > EPS)
abort ();
return 0;
}
/* { dg-final { scan-assembler-times "fmadd\[ \t\]+\[dD\]\[0-9\]+, ?\[dD\]\[0-9\]+, ?\[dD\]\[0-9\]+, ?\[dD\]\[0-9\]+\n" 1 } } */