Add _Float64x function aliases

System Internals / glibc - Joseph Myers [codesourcery.com] - 27 November 2017 14:16 EST

This patch continues filling out TS 18661-3 support by adding *f64x function aliases on platforms with _Float64x support. (It so happens the set of such platforms is exactly the same as the set of platforms with _Float128 support, although on x86_64, x86 and ia32 the _Float64x format is Intel extended rather than binary128.) The API provided corresponds exactly to that provided for _Float128, mostly coming from TS 18661-3. As these functions always alias those for another type (long double, _Float128 or both), __* function names are not provided, as in other cases of alias types.

Given the preparation done in previous patches, this one just enables the feature via Makeconfig and bits/floatn.h, adds symbol versions, and updates documentation and ABI baselines. The symbol versions are present unconditionally as GLIBC_2.27 in the relevant Versions files, as it's OK for those to specify versions for functions that may not be present in some configurations; no additional complexity is needed unless in future some configuration gains support for this type that didn't have such support in 2.27. The Makeconfig additions for ia64 and x86 aren't strictly needed, as those configurations also get float64x-alias-fcts definitions from sysdeps/ieee754/float128/Makeconfig, but still seem appropriate given that _Float64x is not _Float128 for those configurations.

A libm-test-ulps update for x86 is included. This is because bits/mathinline.h does not have _Float64x support added and for two functions the use of out-of-line functions results in increased ulps (ifloat64x shares ulps with ildouble / ifloat128 as appropriate). Given that we'd like generally to eliminate bits/mathinline.h optimizations, preferring to have such optimizations in GCC instead, it seems reasonable not to add such support there for new types. GCC support for _FloatN / _FloatNx built-in functions is limited, but has been improved in GCC 8, and at some point I hope the full set of libm built-in functions in GCC, and other optimizations with per-floating-type aspects, will be enabled for all _FloatN / _FloatNx types.

Tested for x86_64 and x86, and with build-many-glibcs.py, with both GCC 6 and GCC 7.

- sysdeps/ia64/Makeconfig (float64x-alias-fcts): New variable.
- sysdeps/ieee754/float128/Makeconfig (float64x-alias-fcts): Likewise.
- sysdeps/ieee754/ldbl-128/Makeconfig (float64x-alias-fcts): Likewise.
- sysdeps/x86/Makeconfig: New file.
- bits/floatn-common.h (__HAVE_FLOAT64X): Remove macro. (__HAVE_FLOAT64X_LONG_DOUBLE): Likewise.
- bits/floatn.h (__HAVE_FLOAT64X): New macro. (__HAVE_FLOAT64X_LONG_DOUBLE): Likewise.
- sysdeps/ia64/bits/floatn.h (__HAVE_FLOAT64X): Likewise. (__HAVE_FLOAT64X_LONG_DOUBLE): Likewise.
- sysdeps/ieee754/ldbl-128/bits/floatn.h (__HAVE_FLOAT64X): Likewise. (__HAVE_FLOAT64X_LONG_DOUBLE): Likewise.
- sysdeps/mips/ieee754/bits/floatn.h (__HAVE_FLOAT64X): Likewise. (__HAVE_FLOAT64X_LONG_DOUBLE): Likewise.
- sysdeps/powerpc/bits/floatn.h (__HAVE_FLOAT64X): Likewise. (__HAVE_FLOAT64X_LONG_DOUBLE): Likewise.
- sysdeps/x86/bits/floatn.h (__HAVE_FLOAT64X): Likewise. (__HAVE_FLOAT64X_LONG_DOUBLE): Likewise.
- manual/math.texi (Mathematics): Document support for _Float64x.
- math/Versions (GLIBC_2.27): Add _Float64x functions.
- stdlib/Versions (GLIBC_2.27): Likewise.
- wcsmbs/Versions (GLIBC_2.27): Likewise.
- sysdeps/unix/sysv/linux/aarch64/libc.abilist: Update.
- sysdeps/unix/sysv/linux/aarch64/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/alpha/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/alpha/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/i386/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/i386/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/ia64/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/ia64/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/mips/mips64/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/mips/mips64/n32/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/mips/mips64/n64/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/powerpc/powerpc64/libc-le.abilist: Likewise.
- sysdeps/unix/sysv/linux/powerpc/powerpc64/libm-le.abilist: Likewise.
- sysdeps/unix/sysv/linux/s390/s390-32/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/s390/s390-32/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/s390/s390-64/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/s390/s390-64/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/sparc/sparc32/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/sparc/sparc32/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/sparc/sparc64/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/sparc/sparc64/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/x86_64/64/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/x86_64/64/libm.abilist: Likewise.
- sysdeps/unix/sysv/linux/x86_64/x32/libc.abilist: Likewise.
- sysdeps/unix/sysv/linux/x86_64/x32/libm.abilist: Likewise.
- sysdeps/i386/fpu/libm-test-ulps: Likewise.
- sysdeps/i386/i686/fpu/multiarch/libm-test-ulps: Likewise.

a23aa5b727 Add _Float64x function aliases.
ChangeLog | 57 +++++++++++
NEWS | 6 ++
bits/floatn-common.h | 7 --
bits/floatn.h | 11 +++
manual/math.texi | 6 +-
math/Versions | 104 +++++++++++++++++++++
stdlib/Versions | 5 +
sysdeps/i386/fpu/libm-test-ulps | 8 +-
sysdeps/i386/i686/fpu/multiarch/libm-test-ulps | 8 +-
sysdeps/ia64/Makeconfig | 2 +
sysdeps/ia64/bits/floatn.h | 11 +++
sysdeps/ieee754/float128/Makeconfig | 1 +
sysdeps/ieee754/ldbl-128/Makeconfig | 1 +
sysdeps/ieee754/ldbl-128/bits/floatn.h | 11 +++
sysdeps/mips/ieee754/bits/floatn.h | 11 +++
sysdeps/powerpc/bits/floatn.h | 11 +++
sysdeps/unix/sysv/linux/aarch64/libc.abilist | 5 +
sysdeps/unix/sysv/linux/aarch64/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/alpha/libc.abilist | 5 +
sysdeps/unix/sysv/linux/alpha/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/i386/libc.abilist | 5 +
sysdeps/unix/sysv/linux/i386/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/ia64/libc.abilist | 5 +
sysdeps/unix/sysv/linux/ia64/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/mips/mips64/libm.abilist | 104 +++++++++++++++++++++
.../unix/sysv/linux/mips/mips64/n32/libc.abilist | 5 +
.../unix/sysv/linux/mips/mips64/n64/libc.abilist | 5 +
.../sysv/linux/powerpc/powerpc64/libc-le.abilist | 5 +
.../sysv/linux/powerpc/powerpc64/libm-le.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/s390/s390-32/libc.abilist | 5 +
sysdeps/unix/sysv/linux/s390/s390-32/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/s390/s390-64/libc.abilist | 5 +
sysdeps/unix/sysv/linux/s390/s390-64/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/sparc/sparc32/libc.abilist | 5 +
sysdeps/unix/sysv/linux/sparc/sparc32/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/sparc/sparc64/libc.abilist | 5 +
sysdeps/unix/sysv/linux/sparc/sparc64/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/x86_64/64/libc.abilist | 5 +
sysdeps/unix/sysv/linux/x86_64/64/libm.abilist | 104 +++++++++++++++++++++
sysdeps/unix/sysv/linux/x86_64/x32/libc.abilist | 5 +
sysdeps/unix/sysv/linux/x86_64/x32/libm.abilist | 104 +++++++++++++++++++++
sysdeps/x86/Makeconfig | 1 +
sysdeps/x86/bits/floatn.h | 11 +++
wcsmbs/Versions | 4 +
44 files changed, 1571 insertions(+), 18 deletions(-)

Upstream: sourceware.org


  • Share