diff options
author | Stefan Liebler <stli@linux.vnet.ibm.com> | 2014-06-20 07:48:20 +0530 |
---|---|---|
committer | Siddhesh Poyarekar <siddhesh@redhat.com> | 2014-06-20 07:48:20 +0530 |
commit | 3ef6b85059cdd52096625d98c4ce9259854cb8bb (patch) | |
tree | 1a187ab10962c293d888c3063d5ee8b22ad0dc9d /math/w_scalblnf.c | |
parent | d8c2869d4450d54935c3410ad3093d51b5d85f79 (diff) | |
download | glibc-3ef6b85059cdd52096625d98c4ce9259854cb8bb.zip glibc-3ef6b85059cdd52096625d98c4ce9259854cb8bb.tar.gz glibc-3ef6b85059cdd52096625d98c4ce9259854cb8bb.tar.bz2 |
[BZ #6803] Set errno for scalbln, scalbn
Errno is not set and the testcases will fail.
Now the scalbln-aliases are removed in i386/m68
and the wrappers are used when calling the scalbln-functions.
On ia64 only scalblnf has its own implementation.
For scalbln and scalblnl the ieee754/dbl-64 and ieee754/ldbl-96 are used, thus
the wrappers are needed, too.
Diffstat (limited to 'math/w_scalblnf.c')
-rw-r--r-- | math/w_scalblnf.c | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/math/w_scalblnf.c b/math/w_scalblnf.c new file mode 100644 index 0000000..99a3a87 --- /dev/null +++ b/math/w_scalblnf.c @@ -0,0 +1,36 @@ +/* Wrapper for __scalblnf handles setting errno. + Copyright (C) 2014 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/>. */ + +#include <errno.h> +#include <math.h> +#include <math_private.h> + +float +__w_scalblnf (float x, long int n) +{ + if (!__finitef (x) || x == 0.0f) + return x; + + x = __scalblnf (x, n); + + if (!__finitef (x) || x == 0.0f) + __set_errno (ERANGE); + + return x; +} +weak_alias (__w_scalblnf, scalblnf) |