mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-01 07:20:15 +00:00
1294b1892e
This patch series cleans up the many uses of __ieee754_sqrt(f/l) in GLIBC. The goal is to enable GCC to do the inlining, and if this fails call the __ieee754_sqrt function. This is done by internally declaring sqrt with asm redirects. The compat symbols and sqrt wrappers need to disable the redirect. The redirect is also disabled if there are already redirects defined when using -ffinite-math-only. All math functions (but not math tests, non-library code and libnldbl) are built with -fno-math-errno which means GCC will typically inline sqrt as a single instruction. This means targets are no longer forced to add a special inline for sqrt. * include/math.h (sqrt): Declare with asm redirect. (sqrtf): Likewise. (sqrtl): Likewise. (sqrtf128): Likewise. * Makeconfig: Add -fno-math-errno for libc/libm, but build testsuite, nonlib and libnldbl with -fmath-errno. * math/w_sqrt_compat.c: Define NO_MATH_REDIRECT. * math/w_sqrt_template.c: Likewise. * math/w_sqrtf_compat.c: Likewise. * math/w_sqrtl_compat.c: Likewise. * sysdeps/i386/fpu/w_sqrt.c: Likewise. * sysdeps/i386/fpu/w_sqrt_compat.c: Likewise. * sysdeps/generic/math-type-macros-float128.h: Remove math.h and complex.h.
41 lines
1.4 KiB
C
41 lines
1.4 KiB
C
/* Wrapper to set errno for sqrt.
|
|
Copyright (C) 2017-2018 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with the GNU C Library; if not, see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
/* Only build wrappers from the templates for the types that define the macro
|
|
below. This macro is set in math-type-macros-<type>.h in sysdeps/generic
|
|
for each floating-point type. */
|
|
#if __USE_WRAPPER_TEMPLATE
|
|
|
|
# define NO_MATH_REDIRECT
|
|
# include <errno.h>
|
|
# include <fenv.h>
|
|
# include <math.h>
|
|
# include <math_private.h>
|
|
|
|
FLOAT
|
|
M_DECL_FUNC (__sqrt) (FLOAT x)
|
|
{
|
|
if (__glibc_unlikely (isless (x, M_LIT (0.0))))
|
|
/* Domain error: sqrt(x<-0). */
|
|
__set_errno (EDOM);
|
|
return M_SUF (__ieee754_sqrt) (x);
|
|
}
|
|
declare_mgen_alias (__sqrt, sqrt)
|
|
|
|
#endif /* __USE_WRAPPER_TEMPLATE. */
|