aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.9/gcc/testsuite/gcc.target/aarch64/vect-fcm.x
blob: 614f0dec066b17c09dc1cee66a5ee846a6f02e62 (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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#include <stdlib.h>
#define N 16

FTYPE input1[N] =
{2.0, 4.0, 8.0, 16.0,
 2.125, 4.25, 8.5, 17.0,
 -2.0, -4.0, -8.0, -16.0,
 -2.125, -4.25, -8.5, -17.0};

FTYPE input2[N] =
{-2.0, 4.0, -8.0, 16.0,
 2.125, -4.25, 8.5, -17.0,
 2.0, -4.0, 8.0, -16.0,
 -2.125, 4.25, -8.5, 17.0};

/* Float comparisons, float results.  */

void
foo (FTYPE *in1, FTYPE *in2, FTYPE *output)
{
  int i = 0;
  /* Vectorizable.  */
  for (i = 0; i < N; i++)
    output[i] = (in1[i] OP in2[i]) ? 2.0 : 4.0;
}

void
bar (FTYPE *in1, FTYPE *in2, FTYPE *output)
{
  int i = 0;
  /* Vectorizable.  */
  for (i = 0; i < N; i++)
    output[i] = (in1[i] INV_OP in2[i]) ? 4.0 : 2.0;
}

void
foobar (FTYPE *in1, FTYPE *in2, FTYPE *output)
{
  int i = 0;
  /* Vectorizable.  */
  for (i = 0; i < N; i++)
    output[i] = (in1[i] OP 0.0) ? 4.0 : 2.0;
}

void
foobarbar (FTYPE *in1, FTYPE *in2, FTYPE *output)
{
  int i = 0;
  /* Vectorizable.  */
  for (i = 0; i < N; i++)
    output[i] = (in1[i] INV_OP 0.0) ? 4.0 : 2.0;
}

/* Float comparisons, int results.  */

void
foo_int (FTYPE *in1, FTYPE *in2, ITYPE *output)
{
  int i = 0;
  /* Vectorizable.  */
  for (i = 0; i < N; i++)
    output[i] = (in1[i] OP in2[i]) ? 2 : 4;
}

void
bar_int (FTYPE *in1, FTYPE *in2, ITYPE *output)
{
  int i = 0;
  /* Vectorizable.  */
  for (i = 0; i < N; i++)
    output[i] = (in1[i] INV_OP in2[i]) ? 4 : 2;
}

void
foobar_int (FTYPE *in1, FTYPE *in2, ITYPE *output)
{
  int i = 0;
  /* Vectorizable.  */
  for (i = 0; i < N; i++)
    output[i] = (in1[i] OP 0.0) ? 4 : 2;
}

void
foobarbar_int (FTYPE *in1, FTYPE *in2, ITYPE *output)
{
  int i = 0;
  /* Vectorizable.  */
  for (i = 0; i < N; i++)
    output[i] = (in1[i] INV_OP 0.0) ? 4 : 2;
}

int
main (int argc, char **argv)
{
  FTYPE out1[N];
  FTYPE out2[N];
  ITYPE outi1[N];
  ITYPE outi2[N];

  int i = 0;
  foo (input1, input2, out1);
  bar (input1, input2, out2);
  for (i = 0; i < N; i++)
    if (out1[i] != out2[i])
      abort ();
  foobar (input1, input2, out1);
  foobarbar (input1, input2, out2);
  for (i = 0; i < N; i++)
    if (out1[i] == out2[i])
      abort ();

  foo_int (input1, input2, outi1);
  bar_int (input1, input2, outi2);
  for (i = 0; i < N; i++)
    if (outi1[i] != outi2[i])
      abort ();
  foobar_int (input1, input2, outi1);
  foobarbar_int (input1, input2, outi2);
  for (i = 0; i < N; i++)
    if (outi1[i] == outi2[i])
      abort ();
  return 0;
}