From: Gabriel F. T. Gomes Date: Fri, 9 Dec 2016 13:41:55 +0000 (-0200) Subject: float128: Extend __MATH_TG for float128 support X-Git-Tag: glibc-2.26~497 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=477bf19a590b6e6de65f326cb00dcb8999fa8b26;p=thirdparty%2Fglibc.git float128: Extend __MATH_TG for float128 support * math/math.h (__MATH_TG): Extend the conditions to add _Float128 support. * misc/sys/cdefs.h (__HAVE_GENERIC_SELECTION): New macro. --- diff --git a/ChangeLog b/ChangeLog index 6c03b363a26..d1b4523888d 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,10 @@ +2017-05-17 Gabriel F. T. Gomes + Tulio Magno Quites Machado Filho + + * math/math.h (__MATH_TG): Extend the conditions to add + _Float128 support. + * misc/sys/cdefs.h (__HAVE_GENERIC_SELECTION): New macro. + 2017-05-17 Paul A. Clarke * sysdeps/powerpc/powerpc64/fpu/multiarch/Makefile diff --git a/math/math.h b/math/math.h index 3b0bcadb00c..5f006a8358d 100644 --- a/math/math.h +++ b/math/math.h @@ -340,6 +340,27 @@ extern int signgam; #ifdef __NO_LONG_DOUBLE_MATH # define __MATH_TG(TG_ARG, FUNC, ARGS) \ (sizeof (TG_ARG) == sizeof (float) ? FUNC ## f ARGS : FUNC ARGS) +#elif __HAVE_DISTINCT_FLOAT128 +# if __HAVE_GENERIC_SELECTION +# define __MATH_TG(TG_ARG, FUNC, ARGS) \ + _Generic ((TG_ARG), \ + float: FUNC ## f ARGS, \ + default: FUNC ARGS, \ + long double: FUNC ## l ARGS, \ + _Float128: FUNC ## f128 ARGS) +# else +# define __MATH_TG(TG_ARG, FUNC, ARGS) \ + __builtin_choose_expr \ + (__builtin_types_compatible_p (__typeof (TG_ARG), float), \ + FUNC ## f ARGS, \ + __builtin_choose_expr \ + (__builtin_types_compatible_p (__typeof (TG_ARG), double), \ + FUNC ARGS, \ + __builtin_choose_expr \ + (__builtin_types_compatible_p (__typeof (TG_ARG), long double), \ + FUNC ## l ARGS, \ + FUNC ## f128 ARGS))) +# endif #else # define __MATH_TG(TG_ARG, FUNC, ARGS) \ (sizeof (TG_ARG) == sizeof (float) \ diff --git a/misc/sys/cdefs.h b/misc/sys/cdefs.h index 74f9a49b058..06523bfe9c6 100644 --- a/misc/sys/cdefs.h +++ b/misc/sys/cdefs.h @@ -464,4 +464,20 @@ # define __glibc_macro_warning(msg) #endif +/* Support for generic selection (ISO C11) is available in GCC since + version 4.9. Previous versions do not provide generic selection, + even though they might set __STDC_VERSION__ to 201112L, when in + -std=c11 mode. Thus, we must check for !defined __GNUC__ when + testing __STDC_VERSION__ for generic selection support. + On the other hand, Clang also defines __GNUC__, so a clang-specific + check is required to enable the use of generic selection. */ +#if __GNUC_PREREQ (4, 9) \ + || __glibc_clang_has_extension (c_generic_selections) \ + || (!defined __GNUC__ && defined __STDC_VERSION__ \ + && __STDC_VERSION__ >= 201112L) +# define __HAVE_GENERIC_SELECTION 1 +#else +# define __HAVE_GENERIC_SELECTION 0 +#endif + #endif /* sys/cdefs.h */