1 /* Copyright (C) 2004 Free Software Foundation.
3 Test for correctness of composite floating-point comparisons.
5 Written by Paolo Bonzini, 26th May 2004. */
7 extern void abort (void);
9 #define TEST(c) if ((c) != ok) abort ();
10 #define ORD(a, b) (!__builtin_isunordered ((a), (b)))
11 #define UNORD(a, b) (__builtin_isunordered ((a), (b)))
12 #define UNEQ(a, b) (__builtin_isunordered ((a), (b)) || ((a) == (b)))
13 #define UNLT(a, b) (__builtin_isunordered ((a), (b)) || ((a) < (b)))
14 #define UNLE(a, b) (__builtin_isunordered ((a), (b)) || ((a) <= (b)))
15 #define UNGT(a, b) (__builtin_isunordered ((a), (b)) || ((a) > (b)))
16 #define UNGE(a, b) (__builtin_isunordered ((a), (b)) || ((a) >= (b)))
17 #define LTGT(a, b) (__builtin_islessgreater ((a), (b)))
23 int iuneq (float x
, float y
, int ok
)
27 TEST (UNLE (x
, y
) && UNGE (x
,y
));
30 int ieq (float x
, float y
, int ok
)
32 TEST (ORD (x
, y
) && UNEQ (x
, y
));
35 int iltgt (float x
, float y
, int ok
)
37 TEST (!UNEQ (x
, y
)); /* Not optimizable. */
38 TEST (LTGT (x
, y
)); /* Same, __builtin_islessgreater does not trap. */
39 TEST (ORD (x
, y
) && (UNLT (x
, y
) || UNGT (x
,y
)));
42 int ine (float x
, float y
, int ok
)
44 TEST (UNLT (x
, y
) || UNGT (x
, y
));
47 int iunlt (float x
, float y
, int ok
)
50 TEST (UNORD (x
, y
) || (x
< y
));
53 int ilt (float x
, float y
, int ok
)
55 TEST (ORD (x
, y
) && UNLT (x
, y
)); /* Not optimized */
56 TEST ((x
<= y
) && (x
!= y
));
57 TEST ((x
<= y
) && (y
!= x
));
58 TEST ((x
!= y
) && (x
<= y
)); /* Not optimized */
59 TEST ((y
!= x
) && (x
<= y
)); /* Not optimized */
62 int iunle (float x
, float y
, int ok
)
65 TEST (UNORD (x
, y
) || (x
<= y
));
68 int ile (float x
, float y
, int ok
)
70 TEST (ORD (x
, y
) && UNLE (x
, y
)); /* Not optimized */
71 TEST ((x
< y
) || (x
== y
));
72 TEST ((y
> x
) || (x
== y
));
73 TEST ((x
== y
) || (x
< y
)); /* Not optimized */
74 TEST ((y
== x
) || (x
< y
)); /* Not optimized */
77 int iungt (float x
, float y
, int ok
)
80 TEST (UNORD (x
, y
) || (x
> y
));
83 int igt (float x
, float y
, int ok
)
85 TEST (ORD (x
, y
) && UNGT (x
, y
)); /* Not optimized */
86 TEST ((x
>= y
) && (x
!= y
));
87 TEST ((x
>= y
) && (y
!= x
));
88 TEST ((x
!= y
) && (x
>= y
)); /* Not optimized */
89 TEST ((y
!= x
) && (x
>= y
)); /* Not optimized */
92 int iunge (float x
, float y
, int ok
)
95 TEST (UNORD (x
, y
) || (x
>= y
));
98 int ige (float x
, float y
, int ok
)
100 TEST (ORD (x
, y
) && UNGE (x
, y
)); /* Not optimized */
101 TEST ((x
> y
) || (x
== y
));
102 TEST ((y
< x
) || (x
== y
));
103 TEST ((x
== y
) || (x
> y
)); /* Not optimized */
104 TEST ((y
== x
) || (x
> y
)); /* Not optimized */
110 pinf
= __builtin_inf ();
111 ninf
= -__builtin_inf ();
112 NaN
= __builtin_nan ("");
114 iuneq (ninf
, pinf
, 0);
116 iuneq (pinf
, ninf
, 0);
125 iltgt (ninf
, pinf
, 1);
127 iltgt (pinf
, ninf
, 1);
136 iunlt (NaN
, ninf
, 1);
137 iunlt (pinf
, NaN
, 1);
138 iunlt (pinf
, ninf
, 0);
139 iunlt (pinf
, pinf
, 0);
140 iunlt (ninf
, ninf
, 0);
149 iunle (NaN
, ninf
, 1);
150 iunle (pinf
, NaN
, 1);
151 iunle (pinf
, ninf
, 0);
152 iunle (pinf
, pinf
, 1);
153 iunle (ninf
, ninf
, 1);
162 iungt (NaN
, ninf
, 1);
163 iungt (pinf
, NaN
, 1);
164 iungt (pinf
, ninf
, 1);
165 iungt (pinf
, pinf
, 0);
166 iungt (ninf
, ninf
, 0);
175 iunge (NaN
, ninf
, 1);
176 iunge (pinf
, NaN
, 1);
177 iunge (ninf
, pinf
, 0);
178 iunge (pinf
, pinf
, 1);
179 iunge (ninf
, ninf
, 1);