mirror of git://sourceware.org/git/glibc.git
Use trunc functions not __trunc functions in glibc libm.
Continuing the move to use, within libm, public names for libm functions that can be inlined as built-in functions on many architectures, this patch moves calls to __trunc functions to call the corresponding trunc names instead, with asm redirection to __trunc when the calls are not inlined. Tested for x86_64, and with build-many-glibcs.py. * include/math.h [!_ISOMAC && !(__FINITE_MATH_ONLY__ && __FINITE_MATH_ONLY__ > 0) && !NO_MATH_REDIRECT] (trunc): Redirect using MATH_REDIRECT. * sysdeps/aarch64/fpu/s_trunc.c: Define NO_MATH_REDIRECT before header inclusion. * sysdeps/aarch64/fpu/s_truncf.c: Likewise. * sysdeps/ieee754/dbl-64/wordsize-64/s_trunc.c: Likewise. * sysdeps/ieee754/float128/s_truncf128.c: Likewise. * sysdeps/ieee754/dbl-64/s_trunc.c: Likewise. * sysdeps/ieee754/flt-32/s_truncf.c: Likewise. * sysdeps/ieee754/ldbl-128/s_truncl.c: Likewise. * sysdeps/powerpc/powerpc32/power4/fpu/multiarch/s_trunc.c: Likewise. * sysdeps/powerpc/powerpc32/power4/fpu/multiarch/s_truncf.c: Likewise. * sysdeps/powerpc/powerpc64/fpu/multiarch/s_trunc.c: Likewise. * sysdeps/powerpc/powerpc64/fpu/multiarch/s_truncf.c: Likewise. * sysdeps/riscv/rv64/rvd/s_trunc.c: Likewise. * sysdeps/riscv/rvf/s_truncf.c: Likewise. * sysdeps/sparc/sparc64/fpu/multiarch/s_trunc.c: Likewise. * sysdeps/sparc/sparc64/fpu/multiarch/s_truncf.c: Likewise. * sysdeps/x86_64/fpu/multiarch/s_trunc.c: Likewise. * sysdeps/x86_64/fpu/multiarch/s_truncf.c: Likewise. * sysdeps/m68k/m680x0/fpu/s_trunc_template.c: Likewise. * sysdeps/ieee754/ldbl-128ibm/s_truncl.c: Likewise. (ceil): Redirect to __ceil. (floor): Redirect to __floor. (trunc): Redirect to __trunc. (__truncl): Call trunc instead of __trunc. * sysdeps/powerpc/fpu/math_private.h [_ARCH_PWR5X] (__trunc): Remove macro. [_ARCH_PWR5X] (__truncf): Likewise. * sysdeps/ieee754/dbl-64/e_gamma_r.c (__ieee754_gamma_r): Use trunc functions instead of __trunc variants. * sysdeps/ieee754/flt-32/e_gammaf_r.c (__ieee754_gammaf_r): Likewise. * sysdeps/ieee754/ldbl-128/e_gammal_r.c (__ieee754_gammal_r): Likewise. * sysdeps/ieee754/ldbl-128ibm/e_gammal_r.c (__ieee754_gammal_r): Likewise. * sysdeps/ieee754/ldbl-96/e_gammal_r.c (__ieee754_gammal_r): Likewise.
This commit is contained in:
parent
d90c9b1a12
commit
7abf97bed9
41
ChangeLog
41
ChangeLog
|
@ -1,5 +1,46 @@
|
|||
2018-09-20 Joseph Myers <joseph@codesourcery.com>
|
||||
|
||||
* include/math.h [!_ISOMAC && !(__FINITE_MATH_ONLY__ &&
|
||||
__FINITE_MATH_ONLY__ > 0) && !NO_MATH_REDIRECT] (trunc): Redirect
|
||||
using MATH_REDIRECT.
|
||||
* sysdeps/aarch64/fpu/s_trunc.c: Define NO_MATH_REDIRECT before
|
||||
header inclusion.
|
||||
* sysdeps/aarch64/fpu/s_truncf.c: Likewise.
|
||||
* sysdeps/ieee754/dbl-64/wordsize-64/s_trunc.c: Likewise.
|
||||
* sysdeps/ieee754/float128/s_truncf128.c: Likewise.
|
||||
* sysdeps/ieee754/dbl-64/s_trunc.c: Likewise.
|
||||
* sysdeps/ieee754/flt-32/s_truncf.c: Likewise.
|
||||
* sysdeps/ieee754/ldbl-128/s_truncl.c: Likewise.
|
||||
* sysdeps/powerpc/powerpc32/power4/fpu/multiarch/s_trunc.c: Likewise.
|
||||
* sysdeps/powerpc/powerpc32/power4/fpu/multiarch/s_truncf.c: Likewise.
|
||||
* sysdeps/powerpc/powerpc64/fpu/multiarch/s_trunc.c: Likewise.
|
||||
* sysdeps/powerpc/powerpc64/fpu/multiarch/s_truncf.c: Likewise.
|
||||
* sysdeps/riscv/rv64/rvd/s_trunc.c: Likewise.
|
||||
* sysdeps/riscv/rvf/s_truncf.c: Likewise.
|
||||
* sysdeps/sparc/sparc64/fpu/multiarch/s_trunc.c: Likewise.
|
||||
* sysdeps/sparc/sparc64/fpu/multiarch/s_truncf.c: Likewise.
|
||||
* sysdeps/x86_64/fpu/multiarch/s_trunc.c: Likewise.
|
||||
* sysdeps/x86_64/fpu/multiarch/s_truncf.c: Likewise.
|
||||
* sysdeps/m68k/m680x0/fpu/s_trunc_template.c: Likewise.
|
||||
* sysdeps/ieee754/ldbl-128ibm/s_truncl.c: Likewise.
|
||||
(ceil): Redirect to __ceil.
|
||||
(floor): Redirect to __floor.
|
||||
(trunc): Redirect to __trunc.
|
||||
(__truncl): Call trunc instead of __trunc.
|
||||
* sysdeps/powerpc/fpu/math_private.h [_ARCH_PWR5X] (__trunc):
|
||||
Remove macro.
|
||||
[_ARCH_PWR5X] (__truncf): Likewise.
|
||||
* sysdeps/ieee754/dbl-64/e_gamma_r.c (__ieee754_gamma_r): Use
|
||||
trunc functions instead of __trunc variants.
|
||||
* sysdeps/ieee754/flt-32/e_gammaf_r.c (__ieee754_gammaf_r):
|
||||
Likewise.
|
||||
* sysdeps/ieee754/ldbl-128/e_gammal_r.c (__ieee754_gammal_r):
|
||||
Likewise.
|
||||
* sysdeps/ieee754/ldbl-128ibm/e_gammal_r.c (__ieee754_gammal_r):
|
||||
Likewise.
|
||||
* sysdeps/ieee754/ldbl-96/e_gammal_r.c (__ieee754_gammal_r):
|
||||
Likewise.
|
||||
|
||||
* sysdeps/x86/cpu-features.h [__geode__ || __k6__]: Handle like
|
||||
[__i586__ || __pentium__].
|
||||
[__i486__]: Handle explicitly.
|
||||
|
|
|
@ -104,6 +104,7 @@ MATH_REDIRECT (sqrt, "__ieee754_", MATH_REDIRECT_UNARY_ARGS)
|
|||
MATH_REDIRECT (ceil, "__", MATH_REDIRECT_UNARY_ARGS)
|
||||
MATH_REDIRECT (floor, "__", MATH_REDIRECT_UNARY_ARGS)
|
||||
MATH_REDIRECT (rint, "__", MATH_REDIRECT_UNARY_ARGS)
|
||||
MATH_REDIRECT (trunc, "__", MATH_REDIRECT_UNARY_ARGS)
|
||||
# endif
|
||||
# endif
|
||||
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <libm-alias-double.h>
|
||||
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <libm-alias-float.h>
|
||||
|
||||
|
|
|
@ -173,8 +173,8 @@ __ieee754_gamma_r (double x, int *signgamp)
|
|||
}
|
||||
else
|
||||
{
|
||||
double tx = __trunc (x);
|
||||
*signgamp = (tx == 2.0 * __trunc (tx / 2.0)) ? -1 : 1;
|
||||
double tx = trunc (x);
|
||||
*signgamp = (tx == 2.0 * trunc (tx / 2.0)) ? -1 : 1;
|
||||
if (x <= -184.0)
|
||||
/* Underflow. */
|
||||
ret = DBL_MIN * DBL_MIN;
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
|
||||
#include <math_private.h>
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
|
||||
#include <math_private.h>
|
||||
|
|
|
@ -1,2 +1,3 @@
|
|||
#define NO_MATH_REDIRECT
|
||||
#include <float128_private.h>
|
||||
#include "../ldbl-128/s_truncl.c"
|
||||
|
|
|
@ -165,8 +165,8 @@ __ieee754_gammaf_r (float x, int *signgamp)
|
|||
}
|
||||
else
|
||||
{
|
||||
float tx = __truncf (x);
|
||||
*signgamp = (tx == 2.0f * __truncf (tx / 2.0f)) ? -1 : 1;
|
||||
float tx = truncf (x);
|
||||
*signgamp = (tx == 2.0f * truncf (tx / 2.0f)) ? -1 : 1;
|
||||
if (x <= -42.0f)
|
||||
/* Underflow. */
|
||||
ret = FLT_MIN * FLT_MIN;
|
||||
|
|
|
@ -17,6 +17,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
|
||||
#include <math_private.h>
|
||||
|
|
|
@ -179,8 +179,8 @@ __ieee754_gammal_r (_Float128 x, int *signgamp)
|
|||
}
|
||||
else
|
||||
{
|
||||
_Float128 tx = __truncl (x);
|
||||
*signgamp = (tx == 2 * __truncl (tx / 2)) ? -1 : 1;
|
||||
_Float128 tx = truncl (x);
|
||||
*signgamp = (tx == 2 * truncl (tx / 2)) ? -1 : 1;
|
||||
if (x <= -1775)
|
||||
/* Underflow. */
|
||||
ret = LDBL_MIN * LDBL_MIN;
|
||||
|
|
|
@ -18,6 +18,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
|
||||
#include <math_private.h>
|
||||
|
|
|
@ -179,8 +179,8 @@ __ieee754_gammal_r (long double x, int *signgamp)
|
|||
}
|
||||
else
|
||||
{
|
||||
long double tx = __truncl (x);
|
||||
*signgamp = (tx == 2.0L * __truncl (tx / 2.0L)) ? -1 : 1;
|
||||
long double tx = truncl (x);
|
||||
*signgamp = (tx == 2.0L * truncl (tx / 2.0L)) ? -1 : 1;
|
||||
if (x <= -191.0L)
|
||||
/* Underflow. */
|
||||
ret = LDBL_MIN * LDBL_MIN;
|
||||
|
|
|
@ -17,12 +17,17 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <math_private.h>
|
||||
#include <math_ldbl_opt.h>
|
||||
#include <float.h>
|
||||
#include <ieee754.h>
|
||||
|
||||
double ceil (double) asm ("__ceil");
|
||||
double floor (double) asm ("__floor");
|
||||
double trunc (double) asm ("__trunc");
|
||||
|
||||
|
||||
long double
|
||||
__truncl (long double x)
|
||||
|
@ -36,7 +41,7 @@ __truncl (long double x)
|
|||
&& __builtin_isless (__builtin_fabs (xh),
|
||||
__builtin_inf ()), 1))
|
||||
{
|
||||
hi = __trunc (xh);
|
||||
hi = trunc (xh);
|
||||
if (hi != xh)
|
||||
{
|
||||
/* The high part is not an integer; the low part does not
|
||||
|
|
|
@ -171,8 +171,8 @@ __ieee754_gammal_r (long double x, int *signgamp)
|
|||
}
|
||||
else
|
||||
{
|
||||
long double tx = __truncl (x);
|
||||
*signgamp = (tx == 2.0L * __truncl (tx / 2.0L)) ? -1 : 1;
|
||||
long double tx = truncl (x);
|
||||
*signgamp = (tx == 2.0L * truncl (tx / 2.0L)) ? -1 : 1;
|
||||
if (x <= -1766.0L)
|
||||
/* Underflow. */
|
||||
ret = LDBL_MIN * LDBL_MIN;
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library. If not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
|
||||
FLOAT
|
||||
|
|
|
@ -57,26 +57,6 @@ __ieee754_sqrtf128 (_Float128 __x)
|
|||
__z; })
|
||||
# endif
|
||||
|
||||
# ifndef __trunc
|
||||
# define __trunc(x) \
|
||||
({ double __z; \
|
||||
__asm __volatile ( \
|
||||
" friz %0,%1\n" \
|
||||
: "=f" (__z) \
|
||||
: "f" (x)); \
|
||||
__z; })
|
||||
# endif
|
||||
# ifndef __truncf
|
||||
# define __truncf(x) \
|
||||
({ float __z; \
|
||||
__asm __volatile ( \
|
||||
" friz %0,%1\n" \
|
||||
" frsp %0,%0\n" \
|
||||
: "=f" (__z) \
|
||||
: "f" (x)); \
|
||||
__z; })
|
||||
# endif
|
||||
|
||||
#endif /* defined _ARCH_PWR5X */
|
||||
|
||||
#endif /* _PPC_MATH_PRIVATE_H_ */
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <math_ldbl_opt.h>
|
||||
#include <shlib-compat.h>
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <math_ldbl_opt.h>
|
||||
#include <shlib-compat.h>
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <math_ldbl_opt.h>
|
||||
#include <shlib-compat.h>
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <math_ldbl_opt.h>
|
||||
#include <shlib-compat.h>
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library. If not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <math_private.h>
|
||||
#include <fenv_private.h>
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library. If not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <math.h>
|
||||
#include <math_private.h>
|
||||
#include <fenv_private.h>
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <sparc-ifunc.h>
|
||||
#include <math.h>
|
||||
#include <libm-alias-double.h>
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <sparc-ifunc.h>
|
||||
#include <math.h>
|
||||
#include <libm-alias-float.h>
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <libm-alias-double.h>
|
||||
|
||||
#define trunc __redirect_trunc
|
||||
|
|
|
@ -16,6 +16,7 @@
|
|||
License along with the GNU C Library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#define NO_MATH_REDIRECT
|
||||
#include <libm-alias-float.h>
|
||||
|
||||
#define truncf __redirect_truncf
|
||||
|
|
Loading…
Reference in New Issue