blob: efbe79728a9ea6f731310b216133121fd59f9d28 [file] [log] [blame]
/* { dg-do compile } */
/* { dg-require-effective-target arm_neon_ok } */
/* { dg-options "-O1 -ftree-vectorize -funsafe-math-optimizations" } */
/* { dg-add-options arm_neon } */
#define ult(a, b) (!__builtin_isgreaterequal (a, b))
#define ule(a, b) (!__builtin_isgreater (a, b))
#define ugt(a, b) (!__builtin_islessequal (a, b))
#define uge(a, b) (!__builtin_isless (a, b))
int x[16];
float a[16];
float b[16];
#define COMPARE(NAME) \
void \
cmp_##NAME##_reg (void) \
{ \
for (int i = 0; i < 16; ++i) \
x[i] = NAME (a[i], b[i]) ? 2 : 0; \
} \
\
void \
cmp_##NAME##_zero (void) \
{ \
for (int i = 0; i < 16; ++i) \
x[i] = NAME (a[i], 0) ? 2 : 0; \
}
typedef int int_vec __attribute__((vector_size(16)));
typedef float vec __attribute__((vector_size(16)));
COMPARE (ult)
COMPARE (ule)
COMPARE (ugt)
COMPARE (uge)
/* { dg-final { scan-assembler-times {\tvcgt.f32\tq[0-9]+, q[0-9]+, q[0-9]+\n} 2 } } */
/* { dg-final { scan-assembler-times {\tvcgt.f32\tq[0-9]+, q[0-9]+, #0\n} 1 } } */
/* { dg-final { scan-assembler-times {\tvclt.f32\tq[0-9]+, q[0-9]+, #0\n} 1 } } */
/* { dg-final { scan-assembler-times {\tvcge.f32\tq[0-9]+, q[0-9]+, q[0-9]+\n} 2 } } */
/* { dg-final { scan-assembler-times {\tvcge.f32\tq[0-9]+, q[0-9]+, #0\n} 1 } } */
/* { dg-final { scan-assembler-times {\tvcle.f32\tq[0-9]+, q[0-9]+, #0\n} 1 } } */