From: Gabriel F. T. Gomes Date: Fri, 9 Dec 2016 19:08:14 +0000 (-0200) Subject: Make w_scalbln type-generic X-Git-Tag: glibc-2.25~197 X-Git-Url: https://sourceware.org/git/?a=commitdiff_plain;h=e4d6a83565479c533aabae9046377a59712a5b22;p=glibc.git Make w_scalbln type-generic This patch converts the wrapper scalbln (which set errno directly rather than doing anything with __kernel_standard) to use the type-generic template machinery, in the same way that has been done for ldexp. Tested for powerpc64le, s390, and x86_64. --- diff --git a/ChangeLog b/ChangeLog index 3f7e5d6e20..374a69f8db 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,15 @@ +2016-12-16 Gabriel F. T. Gomes + + * math/Makefile (gen-libm-calls): Remove w_scalblnF. + (libm-calls): Add w_scalblnF. + * math/w_scalbln.c: Remove. + * math/w_scalblnf.c: Likewise. + * math/w_scalblnl.c: Likewise. + * math/w_scalbln_template.c: New file with type-generic + implementation based on math/w_scalbln.c. + * sysdeps/ieee754/ldbl-128ibm/w_scalblnl.c: Remove. + * sysdeps/ieee754/ldbl-64-128/w_scalblnl.c: Use new template. + 2016-12-15 Joseph Myers [BZ #20947] diff --git a/math/Makefile b/math/Makefile index 84d061f124..076fd34213 100644 --- a/math/Makefile +++ b/math/Makefile @@ -54,7 +54,7 @@ gen-libm-calls = cargF conjF cimagF crealF cabsF s_cacosF \ s_ctanF s_ctanhF s_cexpF s_clogF s_cprojF s_csqrtF \ s_cpowF s_clog10F s_fdimF s_nextdownF s_fmaxF s_fminF \ s_nanF s_iseqsigF s_canonicalizeF w_ilogbF w_llogbF \ - w_log1pF + w_log1pF w_scalblnF libm-calls = \ e_acosF e_acoshF e_asinF e_atan2F e_atanhF e_coshF e_expF e_fmodF \ @@ -64,7 +64,7 @@ libm-calls = \ k_cosF k_sinF k_tanF s_asinhF s_atanF s_cbrtF \ s_ceilF s_cosF s_erfF s_expm1F s_fabsF \ s_floorF s_log1pF s_logbF \ - s_nextafterF s_nexttowardF s_rintF s_scalblnF w_scalblnF \ + s_nextafterF s_nexttowardF s_rintF s_scalblnF \ s_significandF s_sinF s_tanF s_tanhF w_acosF w_acoshF w_asinF \ w_atan2F w_atanhF w_coshF w_expF w_exp2F w_exp10F w_fmodF \ w_tgammaF w_hypotF w_j0F w_j1F w_jnF w_lgammaF w_lgammaF_r \ diff --git a/math/w_scalbln.c b/math/w_scalbln_template.c similarity index 72% rename from math/w_scalbln.c rename to math/w_scalbln_template.c index bcc33191d9..11c9afe37d 100644 --- a/math/w_scalbln.c +++ b/math/w_scalbln_template.c @@ -20,21 +20,22 @@ #include #include -double -__w_scalbln (double x, long int n) +FLOAT +M_DECL_FUNC (__w_scalbln) (FLOAT x, long int n) { - if (!isfinite (x) || x == 0.0) + if (!isfinite (x) || x == 0) return x + x; - x = __scalbln (x, n); + x = M_SUF (__scalbln) (x, n); - if (!isfinite (x) || x == 0.0) + if (!isfinite (x) || x == 0) __set_errno (ERANGE); return x; } -weak_alias (__w_scalbln, scalbln) -#ifdef NO_LONG_DOUBLE -weak_alias (__w_scalbln, scalblnl) -#endif +/* Define strong_alias to nothing because we don't want + declare_mgen_alias to create a strong alias for scalblnl. */ +#undef strong_alias +#define strong_alias(name, alias_name) +declare_mgen_alias (__w_scalbln, scalbln) diff --git a/math/w_scalblnf.c b/math/w_scalblnf.c deleted file mode 100644 index 2a0b237352..0000000000 --- a/math/w_scalblnf.c +++ /dev/null @@ -1,36 +0,0 @@ -/* Wrapper for __scalblnf handles setting errno. - Copyright (C) 2014-2016 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 - . */ - -#include -#include -#include - -float -__w_scalblnf (float x, long int n) -{ - if (!isfinite (x) || x == 0.0f) - return x + x; - - x = __scalblnf (x, n); - - if (!isfinite (x) || x == 0.0f) - __set_errno (ERANGE); - - return x; -} -weak_alias (__w_scalblnf, scalblnf) diff --git a/math/w_scalblnl.c b/math/w_scalblnl.c deleted file mode 100644 index 8ee8130d72..0000000000 --- a/math/w_scalblnl.c +++ /dev/null @@ -1,36 +0,0 @@ -/* Wrapper for __scalblnl handles setting errno. - Copyright (C) 2014-2016 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 - . */ - -#include -#include -#include - -long double -__w_scalblnl (long double x, long int n) -{ - if (!isfinite (x) || x == 0.0L) - return x + x; - - x = __scalblnl (x, n); - - if (!isfinite (x) || x == 0.0L) - __set_errno (ERANGE); - - return x; -} -weak_alias (__w_scalblnl, scalblnl) diff --git a/sysdeps/ieee754/ldbl-128ibm/w_scalblnl.c b/sysdeps/ieee754/ldbl-128ibm/w_scalblnl.c deleted file mode 100644 index 7e73c9abf8..0000000000 --- a/sysdeps/ieee754/ldbl-128ibm/w_scalblnl.c +++ /dev/null @@ -1,23 +0,0 @@ -/* Wrapper for __scalblnl handles setting errno. - Copyright (C) 2014-2016 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 - . */ - -#include -#undef weak_alias -#define weak_alias(name, alias) -#include -long_double_symbol (libm, __w_scalblnl, scalblnl); diff --git a/sysdeps/ieee754/ldbl-64-128/w_scalblnl.c b/sysdeps/ieee754/ldbl-64-128/w_scalblnl.c index 05d4dfe05b..de210878ec 100644 --- a/sysdeps/ieee754/ldbl-64-128/w_scalblnl.c +++ b/sysdeps/ieee754/ldbl-64-128/w_scalblnl.c @@ -16,10 +16,9 @@ License along with the GNU C Library; if not, see . */ -#include -#undef weak_alias -#define weak_alias(name, alias) -#include +#define declare_mgen_alias(from, to) +#include +#include #if IS_IN (libm) long_double_symbol (libm, __w_scalblnl, scalblnl); #else