blob: 5b88e893fa1dcc5cf5bb595a42fd84851435c16d [file] [log] [blame]
/* Test the vmuls_laneq_f32 AArch64 SIMD intrinsic. */
/* { dg-do run } */
/* { dg-options " -O3" } */
#include "arm_neon.h"
extern void abort (void);
int
main (void)
{
volatile float32_t minus_e, pi, ln2, sqrt2, phi;
float32_t expected, actual;
float32x4_t arg2;
float32_t arr[4];
pi = 3.14159265359;
arr[0] = minus_e = -2.71828;
arr[1] = ln2 = 0.69314718056;
arr[2] = sqrt2 = 1.41421356237;
arr[3] = phi = 1.61803398874;
arg2 = vld1q_f32 (arr);
actual = vmuls_laneq_f32 (pi, arg2, 0);
expected = pi * minus_e;
if (expected != actual)
abort ();
expected = pi * ln2;
actual = vmuls_laneq_f32 (pi, arg2, 1);
if (expected != actual)
abort ();
expected = pi * sqrt2;
actual = vmuls_laneq_f32 (pi, arg2, 2);
if (expected != actual)
abort ();
expected = pi * phi;
actual = vmuls_laneq_f32 (pi, arg2, 3);
if (expected != actual)
abort ();
return 0;
}