aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/arm/neon-compare-4.c
blob: 3f8cc906c6699b00d94fb0f574fc85f221576b26 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/* { dg-do compile } */
/* { dg-require-effective-target arm_neon_ok } */
/* { dg-options "-O1 -ftree-vectorize -funsafe-math-optimizations" }  */
/* { dg-add-options arm_neon } */

#define ordered(a, b) (!__builtin_isunordered (a, b))
#define unordered(a, b) (__builtin_isunordered (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 (ordered)
COMPARE (unordered)

/* { 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} 2 } } */

/* { dg-final { scan-assembler-times {\tvcge.f32\tq[0-9]+, q[0-9]+, q[0-9]+\n} 2 } } */
/* { dg-final { scan-assembler-times {\tvcle.f32\tq[0-9]+, q[0-9]+, #0\n} 2 } } */