to evaluate `float' expressions
double_t floating-point type at least as wide as `double' used
to evaluate `double' expressions
+
+ TS 18661-3 and C23 additionally define long_double_t and _FloatN_t.
*/
-# if __GLIBC_FLT_EVAL_METHOD == 0 || __GLIBC_FLT_EVAL_METHOD == 16
+# if __GLIBC_FLT_EVAL_METHOD == 0
typedef float float_t;
typedef double double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+typedef long double long_double_t;
+# if __HAVE_FLOAT16
+typedef float _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32 _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
# elif __GLIBC_FLT_EVAL_METHOD == 1
typedef double float_t;
typedef double double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+typedef long double long_double_t;
+# if __HAVE_FLOAT16
+typedef double _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef double _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
# elif __GLIBC_FLT_EVAL_METHOD == 2
typedef long double float_t;
typedef long double double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+typedef long double long_double_t;
+# if __HAVE_FLOAT16
+typedef long double _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef long double _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+# ifdef __NO_LONG_DOUBLE_MATH
+typedef _Float64 _Float64_t;
+# else
+typedef long double _Float64_t;
+# endif
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
+# elif __GLIBC_FLT_EVAL_METHOD == 16
+typedef float float_t;
+typedef double double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+typedef long double long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float16 _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32 _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
# elif __GLIBC_FLT_EVAL_METHOD == 32
-typedef _Float32 float_t;
+typedef float float_t;
typedef double double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+typedef long double long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float32 _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32 _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
# elif __GLIBC_FLT_EVAL_METHOD == 33
typedef _Float32x float_t;
-typedef _Float32x double_t;
+typedef double double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+typedef long double long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float32x _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32x _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
# elif __GLIBC_FLT_EVAL_METHOD == 64
typedef _Float64 float_t;
-typedef _Float64 double_t;
+typedef double double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+typedef long double long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float64 _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float64 _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
# elif __GLIBC_FLT_EVAL_METHOD == 65
typedef _Float64x float_t;
typedef _Float64x double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+typedef long double long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float64x _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float64x _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64x _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
# elif __GLIBC_FLT_EVAL_METHOD == 128
typedef _Float128 float_t;
typedef _Float128 double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+# if __HAVE_FLOAT128_UNLIKE_LDBL && __LDBL_MANT_DIG__ != 106
+typedef _Float128 long_double_t;
+# else
+typedef long double long_double_t;
+# endif
+# if __HAVE_FLOAT16
+typedef _Float128 _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float128 _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float128 _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 _Float128_t;
+# endif
+# endif
# elif __GLIBC_FLT_EVAL_METHOD == 129
typedef _Float128x float_t;
typedef _Float128x double_t;
+# if __GLIBC_USE (IEC_60559_TYPES_EXT)
+# if __LDBL_MANT_DIG__ != 106
+typedef _Float128x long_double_t;
+# else
+typedef long double long_double_t;
+# endif
+# if __HAVE_FLOAT16
+typedef _Float128x _Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float128x _Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float128x _Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128x _Float128_t;
+# endif
+# endif
# else
# error "Unknown __GLIBC_FLT_EVAL_METHOD"
# endif
License along with the GNU C Library; if not, see
<https://www.gnu.org/licenses/>. */
+#define __STDC_WANT_IEC_60559_TYPES_EXT__
#include <float.h>
#include <math.h>
/* Cannot test. */
typedef float_t my_float_t;
typedef double_t my_double_t;
-#elif FLT_EVAL_METHOD == 0 || FLT_EVAL_METHOD == 16
+typedef long_double_t my_long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float16_t my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32_t my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64_t my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128_t my_Float128_t;
+# endif
+#elif FLT_EVAL_METHOD == 0
typedef float my_float_t;
typedef double my_double_t;
+typedef long double my_long_double_t;
+# if __HAVE_FLOAT16
+typedef float my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32 my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
#elif FLT_EVAL_METHOD == 1
typedef double my_float_t;
typedef double my_double_t;
+typedef long double my_long_double_t;
+# if __HAVE_FLOAT16
+typedef double my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef double my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
#elif FLT_EVAL_METHOD == 2
typedef long double my_float_t;
typedef long double my_double_t;
+typedef long double my_long_double_t;
+# if __HAVE_FLOAT16
+typedef long double my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef long double my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+# ifdef __NO_LONG_DOUBLE_MATH
+typedef _Float64 my_Float64_t;
+# else
+typedef long double my_Float64_t;
+# endif
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
+#elif FLT_EVAL_METHOD == 16
+typedef float my_float_t;
+typedef double my_double_t;
+typedef long double my_long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float16 my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32 my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
#elif FLT_EVAL_METHOD == 32
-typedef _Float32 my_float_t;
+typedef float my_float_t;
typedef double my_double_t;
+typedef long double my_long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float32 my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32 my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
#elif FLT_EVAL_METHOD == 33
typedef _Float32x my_float_t;
-typedef _Float32x my_double_t;
+typedef double my_double_t;
+typedef long double my_long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float32x my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float32x my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
#elif FLT_EVAL_METHOD == 64
typedef _Float64 my_float_t;
-typedef _Float64 my_double_t;
+typedef double my_double_t;
+typedef long double my_long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float64 my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float64 my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64 my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
#elif FLT_EVAL_METHOD == 65
typedef _Float64x my_float_t;
typedef _Float64x my_double_t;
+typedef long double my_long_double_t;
+# if __HAVE_FLOAT16
+typedef _Float64x my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float64x my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float64x my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
#elif FLT_EVAL_METHOD == 128
typedef _Float128 my_float_t;
typedef _Float128 my_double_t;
+# if __HAVE_FLOAT128_UNLIKE_LDBL && __LDBL_MANT_DIG__ != 106
+typedef _Float128 my_long_double_t;
+# else
+typedef long double my_long_double_t;
+# endif
+# if __HAVE_FLOAT16
+typedef _Float128 my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float128 my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float128 my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128 my_Float128_t;
+# endif
#elif FLT_EVAL_METHOD == 129
typedef _Float128x my_float_t;
typedef _Float128x my_double_t;
+# if __LDBL_MANT_DIG__ != 106
+typedef _Float128x my_long_double_t;
+# else
+typedef long double my_long_double_t;
+# endif
+# if __HAVE_FLOAT16
+typedef _Float128x my_Float16_t;
+# endif
+# if __HAVE_FLOAT32
+typedef _Float128x my_Float32_t;
+# endif
+# if __HAVE_FLOAT64
+typedef _Float128x my_Float64_t;
+# endif
+# if __HAVE_FLOAT128
+typedef _Float128x my_Float128_t;
+# endif
#else
# error "Unknown FLT_EVAL_METHOD"
#endif
extern double_t test_double_t;
extern my_double_t test_double_t;
+extern long_double_t test_long_double_t;
+extern my_long_double_t test_long_double_t;
+
+#if __HAVE_FLOAT16
+extern _Float16_t test_Float16_t;
+extern my_Float16_t test_Float16_t;
+#endif
+
+#if __HAVE_FLOAT32
+extern _Float32_t test_Float32_t;
+extern my_Float32_t test_Float32_t;
+#endif
+
+#if __HAVE_FLOAT64
+extern _Float64_t test_Float64_t;
+extern my_Float64_t test_Float64_t;
+#endif
+
+#if __HAVE_FLOAT128
+extern _Float128_t test_Float128_t;
+extern my_Float128_t test_Float128_t;
+#endif
+
/* This is a compilation test. */
#define TEST_FUNCTION 0
#include "../test-skeleton.c"