Support strtof64x, wcstof64x aliases.
This patch adds support for defining strtof64x, strtof64x_l, wcstof64 and wcstof64x_l function aliases when _Float64x is supported. Tested for x86_64, including in conjunction with _Float64x support patches, and also tested build for other configurations (in conjunction with _Float64x support patches) with build-many-glibcs.py to cover the various different files needing updating to define these aliases. * stdlib/strtold.c [__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x): Define and later undefine as macro. Define as weak alias if [!USE_WIDE_CHAR]. [__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x): Define and later undefine as macro. Define as weak alias if [USE_WIDE_CHAR]. * sysdeps/ieee754/float128/strtof128.c: Include <bits/floatn.h>. [__HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x): Define and later undefine as macro. Define as weak alias if [!USE_WIDE_CHAR]. [__HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x): Define and later undefine as macro. Define as weak alias if [USE_WIDE_CHAR]. * sysdeps/ieee754/float128/strtof128_l.c [__HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x_l): Define and later undefine as macro. Define as weak alias if [!USE_WIDE_CHAR]. [__HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x_l): Define and later undefine as macro. Define as weak alias if [USE_WIDE_CHAR]. * sysdeps/ieee754/ldbl-128/strtold_l.c [__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x_l): Define and later undefine as macro. Define as weak alias if [!USE_WIDE_CHAR]. [__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x_l): Define and later undefine as macro. Define as weak alias if [USE_WIDE_CHAR]. * sysdeps/ieee754/ldbl-64-128/strtold_l.c [__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x_l): Define and later undefine as macro. Define as weak alias if [!USE_WIDE_CHAR]. [__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x_l): Define and later undefine as macro. Define as weak alias if [USE_WIDE_CHAR]. * sysdeps/ieee754/ldbl-96/strtold_l.c [__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x_l): Define and later undefine as macro. Define as weak alias if [!USE_WIDE_CHAR]. [__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x_l): Define and later undefine as macro. Define as weak alias if [USE_WIDE_CHAR].
This commit is contained in:
parent
ae7207d033
commit
0df4fe3557
35
ChangeLog
35
ChangeLog
@ -1,5 +1,40 @@
|
||||
2017-11-24 Joseph Myers <joseph@codesourcery.com>
|
||||
|
||||
* stdlib/strtold.c [__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x):
|
||||
Define and later undefine as macro. Define as weak alias if
|
||||
[!USE_WIDE_CHAR].
|
||||
[__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x): Define and later
|
||||
undefine as macro. Define as weak alias if [USE_WIDE_CHAR].
|
||||
* sysdeps/ieee754/float128/strtof128.c: Include <bits/floatn.h>.
|
||||
[__HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x):
|
||||
Define and later undefine as macro. Define as weak alias if
|
||||
[!USE_WIDE_CHAR].
|
||||
[__HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x):
|
||||
Define and later undefine as macro. Define as weak alias if
|
||||
[USE_WIDE_CHAR].
|
||||
* sysdeps/ieee754/float128/strtof128_l.c
|
||||
[__HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x_l):
|
||||
Define and later undefine as macro. Define as weak alias if
|
||||
[!USE_WIDE_CHAR].
|
||||
[__HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x_l):
|
||||
Define and later undefine as macro. Define as weak alias if
|
||||
[USE_WIDE_CHAR].
|
||||
* sysdeps/ieee754/ldbl-128/strtold_l.c
|
||||
[__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x_l): Define and later
|
||||
undefine as macro. Define as weak alias if [!USE_WIDE_CHAR].
|
||||
[__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x_l): Define and later
|
||||
undefine as macro. Define as weak alias if [USE_WIDE_CHAR].
|
||||
* sysdeps/ieee754/ldbl-64-128/strtold_l.c
|
||||
[__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x_l): Define and later
|
||||
undefine as macro. Define as weak alias if [!USE_WIDE_CHAR].
|
||||
[__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x_l): Define and later
|
||||
undefine as macro. Define as weak alias if [USE_WIDE_CHAR].
|
||||
* sysdeps/ieee754/ldbl-96/strtold_l.c
|
||||
[__HAVE_FLOAT64X_LONG_DOUBLE] (strtof64x_l): Define and later
|
||||
undefine as macro. Define as weak alias if [!USE_WIDE_CHAR].
|
||||
[__HAVE_FLOAT64X_LONG_DOUBLE] (wcstof64x_l): Define and later
|
||||
undefine as macro. Define as weak alias if [USE_WIDE_CHAR].
|
||||
|
||||
* math/test-float64x.h: New file.
|
||||
* math/Makefile (type-float64x-yes): New variable.
|
||||
(test-types): Add $(type-float64x-$(float64x-alias-fcts)).
|
||||
|
@ -27,6 +27,10 @@
|
||||
# define strtof128 __hide_strtof128
|
||||
# define wcstof128 __hide_wcstof128
|
||||
#endif
|
||||
#if __HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# define strtof64x __hide_strtof64x
|
||||
# define wcstof64x __hide_wcstof64x
|
||||
#endif
|
||||
|
||||
#ifdef __LONG_DOUBLE_MATH_OPTIONAL
|
||||
# include <wchar.h>
|
||||
@ -78,3 +82,13 @@ weak_alias (NEW (wcstold), wcstof128)
|
||||
weak_alias (NEW (strtold), strtof128)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#if __HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# undef strtof64x
|
||||
# undef wcstof64x
|
||||
# ifdef USE_WIDE_CHAR
|
||||
weak_alias (NEW (wcstold), wcstof64x)
|
||||
# else
|
||||
weak_alias (NEW (strtold), strtof64x)
|
||||
# endif
|
||||
#endif
|
||||
|
@ -19,6 +19,13 @@
|
||||
/* The actual implementation for all floating point sizes is in strtod.c.
|
||||
These macros tell it to produce the `_Float128' version, `strtof128'. */
|
||||
|
||||
#include <bits/floatn.h>
|
||||
|
||||
#if __HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# define strtof64x __hide_strtof64x
|
||||
# define wcstof64x __hide_wcstof64x
|
||||
#endif
|
||||
|
||||
#define FLOAT _Float128
|
||||
#define FLT FLT128
|
||||
#ifdef USE_WIDE_CHAR
|
||||
@ -32,3 +39,13 @@
|
||||
#include <float128_private.h>
|
||||
|
||||
#include <stdlib/strtod.c>
|
||||
|
||||
#if __HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# undef strtof64x
|
||||
# undef wcstof64x
|
||||
# ifdef USE_WIDE_CHAR
|
||||
weak_alias (wcstof128, wcstof64x)
|
||||
# else
|
||||
weak_alias (strtof128, strtof64x)
|
||||
# endif
|
||||
#endif
|
||||
|
@ -21,6 +21,11 @@
|
||||
/* Bring in potential typedef for _Float128 early for declaration below. */
|
||||
#include <bits/floatn.h>
|
||||
|
||||
#if __HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# define strtof64x_l __hide_strtof64x_l
|
||||
# define wcstof64x_l __hide_wcstof64x_l
|
||||
#endif
|
||||
|
||||
extern _Float128 ____strtof128_l_internal (const char *, char **,
|
||||
int, locale_t);
|
||||
|
||||
@ -41,3 +46,13 @@ extern _Float128 ____strtof128_l_internal (const char *, char **,
|
||||
#include <float128_private.h>
|
||||
|
||||
#include <stdlib/strtod_l.c>
|
||||
|
||||
#if __HAVE_FLOAT64X && !__HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# undef strtof64x_l
|
||||
# undef wcstof64x_l
|
||||
# ifdef USE_WIDE_CHAR
|
||||
weak_alias (wcstof128_l, wcstof64x_l)
|
||||
# else
|
||||
weak_alias (strtof128_l, strtof64x_l)
|
||||
# endif
|
||||
#endif
|
||||
|
@ -39,6 +39,11 @@
|
||||
# define wcstof128_l __hide_wcstof128_l
|
||||
#endif
|
||||
|
||||
#if __HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# define strtof64x_l __hide_strtof64x_l
|
||||
# define wcstof64x_l __hide_wcstof64x_l
|
||||
#endif
|
||||
|
||||
#include <strtod_l.c>
|
||||
|
||||
#if __HAVE_FLOAT128 && !__HAVE_DISTINCT_FLOAT128
|
||||
@ -50,3 +55,13 @@ weak_alias (wcstold_l, wcstof128_l)
|
||||
weak_alias (strtold_l, strtof128_l)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#if __HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# undef strtof64x_l
|
||||
# undef wcstof64x_l
|
||||
# ifdef USE_WIDE_CHAR
|
||||
weak_alias (wcstold_l, wcstof64x_l)
|
||||
# else
|
||||
weak_alias (strtold_l, strtof64x_l)
|
||||
# endif
|
||||
#endif
|
||||
|
@ -22,6 +22,11 @@
|
||||
# define wcstof128_l __hide_wcstof128_l
|
||||
#endif
|
||||
|
||||
#if __HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# define strtof64x_l __hide_strtof64x_l
|
||||
# define wcstof64x_l __hide_wcstof64x_l
|
||||
#endif
|
||||
|
||||
#include <math.h>
|
||||
#include <stdlib.h>
|
||||
#include <wchar.h>
|
||||
@ -74,3 +79,13 @@ weak_alias (____new_wcstold_l, wcstof128_l)
|
||||
weak_alias (____new_strtold_l, strtof128_l)
|
||||
# endif
|
||||
#endif
|
||||
|
||||
#if __HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# undef strtof64x_l
|
||||
# undef wcstof64x_l
|
||||
# ifdef USE_WIDE_CHAR
|
||||
weak_alias (____new_wcstold_l, wcstof64x_l)
|
||||
# else
|
||||
weak_alias (____new_strtold_l, strtof64x_l)
|
||||
# endif
|
||||
#endif
|
||||
|
@ -34,4 +34,19 @@
|
||||
#define MPN2FLOAT __mpn_construct_long_double
|
||||
#define FLOAT_HUGE_VAL HUGE_VALL
|
||||
|
||||
#if __HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# define strtof64x_l __hide_strtof64x_l
|
||||
# define wcstof64x_l __hide_wcstof64x_l
|
||||
#endif
|
||||
|
||||
#include <stdlib/strtod_l.c>
|
||||
|
||||
#if __HAVE_FLOAT64X_LONG_DOUBLE
|
||||
# undef strtof64x_l
|
||||
# undef wcstof64x_l
|
||||
# ifdef USE_WIDE_CHAR
|
||||
weak_alias (wcstold_l, wcstof64x_l)
|
||||
# else
|
||||
weak_alias (strtold_l, strtof64x_l)
|
||||
# endif
|
||||
#endif
|
||||
|
Loading…
x
Reference in New Issue
Block a user