1 /* Test various type-generic builtins by calling "main_tests()". */
8 #define fpclassify(X) __builtin_fpclassify(FP_NAN, FP_INFINITE, FP_NORMAL, FP_SUBNORMAL, FP_ZERO, (X))
10 void __attribute__ ((__noinline__
))
11 foo_1 (float f
, double d
, long double ld
,
12 int res_unord
, int res_isnan
, int res_isinf
,
13 int res_isinf_sign
, int res_isfin
, int res_isnorm
,
14 int res_signbit
, int classification
)
16 if (__builtin_isunordered (f
, 0) != res_unord
)
18 if (__builtin_isunordered (0, f
) != res_unord
)
20 if (__builtin_isunordered (d
, 0) != res_unord
)
22 if (__builtin_isunordered (0, d
) != res_unord
)
24 if (__builtin_isunordered (ld
, 0) != res_unord
)
26 if (__builtin_isunordered (0, ld
) != res_unord
)
29 if (__builtin_isnan (f
) != res_isnan
)
31 if (__builtin_isnan (d
) != res_isnan
)
33 if (__builtin_isnan (ld
) != res_isnan
)
35 if (__builtin_isnanf (f
) != res_isnan
)
37 if (__builtin_isnanl (ld
) != res_isnan
)
40 if (__builtin_isinf (f
) != res_isinf
)
42 if (__builtin_isinf (d
) != res_isinf
)
44 if (__builtin_isinf (ld
) != res_isinf
)
46 if (__builtin_isinff (f
) != res_isinf
)
48 if (__builtin_isinfl (ld
) != res_isinf
)
51 if (__builtin_isinf_sign (f
) != res_isinf_sign
)
53 if (__builtin_isinf_sign (d
) != res_isinf_sign
)
55 if (__builtin_isinf_sign (ld
) != res_isinf_sign
)
58 if (__builtin_isnormal (f
) != res_isnorm
)
60 if (__builtin_isnormal (d
) != res_isnorm
)
62 if (__builtin_isnormal (ld
) != res_isnorm
)
65 if (__builtin_isfinite (f
) != res_isfin
)
67 if (__builtin_isfinite (d
) != res_isfin
)
69 if (__builtin_isfinite (ld
) != res_isfin
)
72 if (__builtin_finitef (f
) != res_isfin
)
74 if (__builtin_finite (f
) != res_isfin
)
76 if (__builtin_finite (d
) != res_isfin
)
78 if (__builtin_finitel (d
) != res_isfin
)
80 if (__builtin_finitel (ld
) != res_isfin
)
83 /* Sign bit of zeros and nans is not preserved in unsafe math mode. */
85 if (!res_isnan
&& f
!= 0 && d
!= 0 && ld
!= 0)
88 if ((__builtin_signbit (f
) ? 1 : 0) != res_signbit
)
90 if ((__builtin_signbit (d
) ? 1 : 0) != res_signbit
)
92 if ((__builtin_signbit (ld
) ? 1 : 0) != res_signbit
)
94 if ((__builtin_signbitf (f
) ? 1 : 0) != res_signbit
)
96 if ((__builtin_signbitl (ld
) ? 1 : 0) != res_signbit
)
100 /* Subnormals can abruptly underflow to zero in unsafe math
101 mode, so bypass testing these numbers if necessary. */
103 if (classification
!= FP_SUBNORMAL
)
106 if (fpclassify(f
) != classification
)
108 if (fpclassify(d
) != classification
)
110 if (fpclassify(ld
) != classification
)
115 void __attribute__ ((__noinline__
))
116 foo (float f
, double d
, long double ld
,
117 int res_unord
, int res_isnan
, int res_isinf
,
118 int res_isfin
, int res_isnorm
, int classification
)
120 foo_1 (f
, d
, ld
, res_unord
, res_isnan
, res_isinf
, res_isinf
, res_isfin
, res_isnorm
, 0, classification
);
121 /* Try all the values negated as well. All will have the sign bit set,
122 except for the nan. */
123 foo_1 (-f
, -d
, -ld
, res_unord
, res_isnan
, res_isinf
, -res_isinf
, res_isfin
, res_isnorm
, 1, classification
);
126 int __attribute__ ((__noinline__
))
131 volatile long double ld
;
134 f
= __builtin_nanf(""); d
= __builtin_nan(""); ld
= __builtin_nanl("");
135 foo(f
, d
, ld
, /*unord=*/ 1, /*isnan=*/ 1, /*isinf=*/ 0, /*isfin=*/ 0, /*isnorm=*/ 0, FP_NAN
);
138 f
= __builtin_inff(); d
= __builtin_inf(); ld
= __builtin_infl();
139 foo(f
, d
, ld
, /*unord=*/ 0, /*isnan=*/ 0, /*isinf=*/ 1, /*isfin=*/ 0, /*isnorm=*/ 0, FP_INFINITE
);
142 f
= 0; d
= 0; ld
= 0;
143 foo(f
, d
, ld
, /*unord=*/ 0, /*isnan=*/ 0, /*isinf=*/ 0, /*isfin=*/ 1, /*isnorm=*/ 0, FP_ZERO
);
146 f
= 1; d
= 1; ld
= 1;
147 foo(f
, d
, ld
, /*unord=*/ 0, /*isnan=*/ 0, /*isinf=*/ 0, /*isfin=*/ 1, /*isnorm=*/ 1, FP_NORMAL
);
149 /* Test minimum values. */
150 f
= __FLT_MIN__
; d
= __DBL_MIN__
; ld
= __LDBL_MIN__
;
151 foo(f
, d
, ld
, /*unord=*/ 0, /*isnan=*/ 0, /*isinf=*/ 0, /*isfin=*/ 1, /*isnorm=*/ 1, FP_NORMAL
);
153 /* Test subnormal values. */
154 f
= __FLT_MIN__
/2; d
= __DBL_MIN__
/2; ld
= __LDBL_MIN__
/2;
155 foo(f
, d
, ld
, /*unord=*/ 0, /*isnan=*/ 0, /*isinf=*/ 0, /*isfin=*/ 1, /*isnorm=*/ 0, FP_SUBNORMAL
);
157 /* Test maximum values. */
158 f
= __FLT_MAX__
; d
= __DBL_MAX__
; ld
= __LDBL_MAX__
;
159 foo(f
, d
, ld
, /*unord=*/ 0, /*isnan=*/ 0, /*isinf=*/ 0, /*isfin=*/ 1, /*isnorm=*/ 1, FP_NORMAL
);
161 /* Test overflow values. */
162 f
= __FLT_MAX__
*2; d
= __DBL_MAX__
*2; ld
= __LDBL_MAX__
*2;
163 foo(f
, d
, ld
, /*unord=*/ 0, /*isnan=*/ 0, /*isinf=*/ 1, /*isfin=*/ 0, /*isnorm=*/ 0, FP_INFINITE
);