/* Test the vfms_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 (0x3fe730af8db9e6f7ULL); arg2 = vcreate_f64 (0x3fe6b78680fa29ceULL); arg3 = vcreate_f64 (0x3feea3cbf921fbe0ULL); INHIB_OPT (arg1); INHIB_OPT (arg2); INHIB_OPT (arg3); expected = 4.4964705746355915e-2; actual = vget_lane_f64 (vfms_f64 (arg1, arg2, arg3), 0); if (__builtin_fabs (expected - actual) > EPS) abort (); return 0; } /* { dg-final { scan-assembler-times "fmsub\[ \t\]+\[dD\]\[0-9\]+, ?\[dD\]\[0-9\]+, ?\[dD\]\[0-9\]+, ?\[dD\]\[0-9\]+\n" 1 } } */