Refactor strtod parsing of NaN payloads.
commite02cabecf0d025ec4f4ddee290bdf7aadb873bb3
authorJoseph Myers <joseph@codesourcery.com>
Tue, 24 Nov 2015 22:24:52 +0000 (24 22:24 +0000)
committerJoseph Myers <joseph@codesourcery.com>
Tue, 24 Nov 2015 22:24:52 +0000 (24 22:24 +0000)
treeaf7aa7390dbc613f881677122a888946d294d333
parenta7f0c5ae4184916f0e145de3aefc794bf2e280ad
Refactor strtod parsing of NaN payloads.

The nan* functions handle their string argument by constructing a
NAN(...) string on the stack as a VLA and passing it to strtod
functions.

This approach has problems discussed in bug 16961 and bug 16962: the
stack usage is unbounded, and it gives incorrect results in certain
cases where the argument is not a valid n-char-sequence.

The natural fix for both issues is to refactor the NaN payload parsing
out of strtod into a separate function that the nan* functions can
call directly, so that no temporary string needs constructing on the
stack at all.  This patch does that refactoring in preparation for
fixing those bugs (but without actually using the new functions from
nan* - which will also require exporting them from libc at version
GLIBC_PRIVATE).  This patch is not intended to change any user-visible
behavior, so no tests are added (fixes for the above bugs will of
course add tests for them).

This patch builds on my recent fixes for strtol and strtod issues in
Turkish locales.  Given those fixes, the parsing of NaN payloads is
locale-independent; thus, the new functions do not need to take a
locale_t argument.

Tested for x86_64, x86, mips64 and powerpc.

* stdlib/strtod_nan.c: New file.
* stdlib/strtod_nan_double.h: Likewise.
* stdlib/strtod_nan_float.h: Likewise.
* stdlib/strtod_nan_main.c: Likewise.
* stdlib/strtod_nan_narrow.h: Likewise.
* stdlib/strtod_nan_wide.h: Likewise.
* stdlib/strtof_nan.c: Likewise.
* stdlib/strtold_nan.c: Likewise.
* sysdeps/ieee754/ldbl-128/strtod_nan_ldouble.h: Likewise.
* sysdeps/ieee754/ldbl-128ibm/strtod_nan_ldouble.h: Likewise.
* sysdeps/ieee754/ldbl-96/strtod_nan_ldouble.h: Likewise.
* wcsmbs/wcstod_nan.c: Likewise.
* wcsmbs/wcstof_nan.c: Likewise.
* wcsmbs/wcstold_nan.c: Likewise.
* stdlib/Makefile (routines): Add strtof_nan, strtod_nan and
strtold_nan.
* wcsmbs/Makefile (routines): Add wcstod_nan, wcstold_nan and
wcstof_nan.
* include/stdlib.h (__strtof_nan): Declare and use
libc_hidden_proto.
(__strtod_nan): Likewise.
(__strtold_nan): Likewise.
(__wcstof_nan): Likewise.
(__wcstod_nan): Likewise.
(__wcstold_nan): Likewise.
* include/wchar.h (____wcstoull_l_internal): Declare.
* stdlib/strtod_l.c: Do not include <ieee754.h>.
(____strtoull_l_internal): Remove declaration.
(STRTOF_NAN): Define macro.
(SET_MANTISSA): Remove macro.
(STRTOULL): Likewise.
(____STRTOF_INTERNAL): Use STRTOF_NAN to parse NaN payload.
* stdlib/strtof_l.c (____strtoull_l_internal): Remove declaration.
(STRTOF_NAN): Define macro.
(SET_MANTISSA): Remove macro.
* sysdeps/ieee754/ldbl-128/strtold_l.c (STRTOF_NAN): Define macro.
(SET_MANTISSA): Remove macro.
* sysdeps/ieee754/ldbl-128ibm/strtold_l.c (STRTOF_NAN): Define
macro.
(SET_MANTISSA): Remove macro.
* sysdeps/ieee754/ldbl-64-128/strtold_l.c (STRTOF_NAN): Define
macro.
(SET_MANTISSA): Remove macro.
* sysdeps/ieee754/ldbl-96/strtold_l.c (STRTOF_NAN): Define macro.
(SET_MANTISSA): Remove macro.
* wcsmbs/wcstod_l.c (____wcstoull_l_internal): Remove declaration.
* wcsmbs/wcstof_l.c (____wcstoull_l_internal): Likewise.
* wcsmbs/wcstold_l.c (____wcstoull_l_internal): Likewise.
28 files changed:
ChangeLog
include/stdlib.h
include/wchar.h
stdlib/Makefile
stdlib/strtod_l.c
stdlib/strtod_nan.c [copied from wcsmbs/wcstold_l.c with 58% similarity]
stdlib/strtod_nan_double.h [copied from wcsmbs/wcstof_l.c with 63% similarity]
stdlib/strtod_nan_float.h [copied from wcsmbs/wcstof_l.c with 63% similarity]
stdlib/strtod_nan_main.c [new file with mode: 0644]
stdlib/strtod_nan_narrow.h [copied from wcsmbs/wcstof_l.c with 63% similarity]
stdlib/strtod_nan_wide.h [copied from wcsmbs/wcstof_l.c with 63% similarity]
stdlib/strtof_l.c
stdlib/strtof_nan.c [copied from wcsmbs/wcstold_l.c with 58% similarity]
stdlib/strtold_nan.c [copied from wcsmbs/wcstold_l.c with 58% similarity]
sysdeps/ieee754/ldbl-128/strtod_nan_ldouble.h [copied from wcsmbs/wcstold_l.c with 59% similarity]
sysdeps/ieee754/ldbl-128/strtold_l.c
sysdeps/ieee754/ldbl-128ibm/strtod_nan_ldouble.h [copied from wcsmbs/wcstold_l.c with 63% similarity]
sysdeps/ieee754/ldbl-128ibm/strtold_l.c
sysdeps/ieee754/ldbl-64-128/strtold_l.c
sysdeps/ieee754/ldbl-96/strtod_nan_ldouble.h [copied from wcsmbs/wcstold_l.c with 63% similarity]
sysdeps/ieee754/ldbl-96/strtold_l.c
wcsmbs/Makefile
wcsmbs/wcstod_l.c
wcsmbs/wcstod_nan.c [copied from wcsmbs/wcstold_l.c with 58% similarity]
wcsmbs/wcstof_l.c
wcsmbs/wcstof_nan.c [copied from wcsmbs/wcstold_l.c with 58% similarity]
wcsmbs/wcstold_l.c
wcsmbs/wcstold_nan.c [copied from wcsmbs/wcstold_l.c with 58% similarity]