mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-09 23:00:07 +00:00
Set errno for y1 overflow (bug 17050).
This patch fixes bug 17050, missing errno setting for y1 overflow (for small positive arguments). An appropriate check is added for overflow directly in the __ieee754_y1 implementation, similar to the check present for yn (doing it there rather than in the wrapper also avoids yn needing to repeat the check when called for order 1 or -1 and it uses __ieee754_y1). Tested x86_64 and x86; no ulps update needed. Also tested for mips64 to verify the ldbl-128 fix (the ldbl-128ibm code just #includes the ldbl-128 file). [BZ #17050] * sysdeps/ieee754/dbl-64/e_j1.c: Include <errno.h>. (__ieee754_y1): Set errno if return value overflows. * sysdeps/ieee754/flt-32/e_j1f.c: Include <errno.h>. (__ieee754_y1f): Set errno if return value overflows. * sysdeps/ieee754/ldbl-128/e_j1l.c: Include <errno.h>. (__ieee754_y1l): Set errno if return value overflows. * sysdeps/ieee754/ldbl-96/e_j1l.c: Include <errno.h>. (__ieee754_y1l): Set errno if return value overflows. * math/auto-libm-test-in: Add more tests of y0, y1 and yn. * math/auto-libm-test-out: Regenerated.
This commit is contained in:
parent
863893ec95
commit
46a3d3c7d6
12
ChangeLog
12
ChangeLog
@ -1,5 +1,17 @@
|
||||
2014-06-23 Joseph Myers <joseph@codesourcery.com>
|
||||
|
||||
[BZ #17050]
|
||||
* sysdeps/ieee754/dbl-64/e_j1.c: Include <errno.h>.
|
||||
(__ieee754_y1): Set errno if return value overflows.
|
||||
* sysdeps/ieee754/flt-32/e_j1f.c: Include <errno.h>.
|
||||
(__ieee754_y1f): Set errno if return value overflows.
|
||||
* sysdeps/ieee754/ldbl-128/e_j1l.c: Include <errno.h>.
|
||||
(__ieee754_y1l): Set errno if return value overflows.
|
||||
* sysdeps/ieee754/ldbl-96/e_j1l.c: Include <errno.h>.
|
||||
(__ieee754_y1l): Set errno if return value overflows.
|
||||
* math/auto-libm-test-in: Add more tests of y0, y1 and yn.
|
||||
* math/auto-libm-test-out: Regenerated.
|
||||
|
||||
* math/gen-auto-libm-tests.c: Document use of
|
||||
ignore-zero-inf-sign.
|
||||
(input_flag_type): Add value flag_ignore_zero_inf_sign.
|
||||
|
2
NEWS
2
NEWS
@ -20,7 +20,7 @@ Version 2.20
|
||||
16849, 16854, 16876, 16877, 16878, 16882, 16885, 16888, 16890, 16912,
|
||||
16915, 16916, 16917, 16922, 16927, 16928, 16932, 16943, 16958, 16965,
|
||||
16966, 16967, 16977, 16978, 16984, 16990, 16996, 17009, 17022, 17031,
|
||||
17042, 17048, 17058, 17062, 17069, 17075, 17079.
|
||||
17042, 17048, 17050, 17058, 17062, 17069, 17075, 17079.
|
||||
|
||||
* Optimized strchr implementation for AArch64. Contributed by ARM Ltd.
|
||||
|
||||
|
@ -2458,6 +2458,8 @@ y0 0x1p-80
|
||||
y0 0x1p-90
|
||||
y0 0x1p-100
|
||||
y0 0x1p-110
|
||||
y0 min
|
||||
y0 min_subnorm
|
||||
|
||||
y1 0.125
|
||||
y1 0.75
|
||||
@ -2482,6 +2484,8 @@ y1 0x1p-80
|
||||
y1 0x1p-90
|
||||
y1 0x1p-100
|
||||
y1 0x1p-110
|
||||
y1 min
|
||||
y1 min_subnorm
|
||||
|
||||
# yn (0, x) == y0 (x).
|
||||
yn 0 0.125
|
||||
@ -2526,3 +2530,22 @@ yn 2 0x1.ffff62p+99
|
||||
yn 2 0x1p127
|
||||
yn 2 0x1p1023
|
||||
yn 2 0x1p16383
|
||||
|
||||
yn 0 min
|
||||
yn 0 min_subnorm
|
||||
yn 1 min
|
||||
yn 1 min_subnorm
|
||||
yn -1 min
|
||||
yn -1 min_subnorm
|
||||
yn 2 min
|
||||
yn 2 min_subnorm
|
||||
yn -2 min
|
||||
yn -2 min_subnorm
|
||||
yn 17 min
|
||||
yn 17 min_subnorm
|
||||
yn -17 min
|
||||
yn -17 min_subnorm
|
||||
yn 42 min
|
||||
yn 42 min_subnorm
|
||||
yn -42 min
|
||||
yn -42 min_subnorm
|
||||
|
File diff suppressed because it is too large
Load Diff
@ -58,6 +58,7 @@
|
||||
* by method mentioned above.
|
||||
*/
|
||||
|
||||
#include <errno.h>
|
||||
#include <math.h>
|
||||
#include <math_private.h>
|
||||
|
||||
@ -205,7 +206,10 @@ __ieee754_y1 (double x)
|
||||
}
|
||||
if (__glibc_unlikely (ix <= 0x3c900000)) /* x < 2**-54 */
|
||||
{
|
||||
return (-tpi / x);
|
||||
z = -tpi / x;
|
||||
if (__isinf (z))
|
||||
__set_errno (ERANGE);
|
||||
return z;
|
||||
}
|
||||
z = x * x;
|
||||
u1 = U0[0] + z * U0[1]; z2 = z * z;
|
||||
|
@ -13,6 +13,7 @@
|
||||
* ====================================================
|
||||
*/
|
||||
|
||||
#include <errno.h>
|
||||
#include <math.h>
|
||||
#include <math_private.h>
|
||||
|
||||
@ -135,7 +136,10 @@ __ieee754_y1f(float x)
|
||||
return z;
|
||||
}
|
||||
if(__builtin_expect(ix<=0x33000000, 0)) { /* x < 2**-25 */
|
||||
return(-tpi/x);
|
||||
z = -tpi / x;
|
||||
if (__isinff (z))
|
||||
__set_errno (ERANGE);
|
||||
return z;
|
||||
}
|
||||
z = x*x;
|
||||
u = U0[0]+z*(U0[1]+z*(U0[2]+z*(U0[3]+z*U0[4])));
|
||||
|
@ -95,6 +95,7 @@
|
||||
License along with this library; if not, see
|
||||
<http://www.gnu.org/licenses/>. */
|
||||
|
||||
#include <errno.h>
|
||||
#include <math.h>
|
||||
#include <math_private.h>
|
||||
#include <float.h>
|
||||
@ -852,7 +853,12 @@ __ieee754_y1l (long double x)
|
||||
}
|
||||
xx = fabsl (x);
|
||||
if (xx <= 0x1p-114)
|
||||
return -TWOOPI / x;
|
||||
{
|
||||
z = -TWOOPI / x;
|
||||
if (__isinfl (z))
|
||||
__set_errno (ERANGE);
|
||||
return z;
|
||||
}
|
||||
if (xx <= 2.0L)
|
||||
{
|
||||
/* 0 <= x <= 2 */
|
||||
|
@ -71,6 +71,7 @@
|
||||
* by method mentioned above.
|
||||
*/
|
||||
|
||||
#include <errno.h>
|
||||
#include <math.h>
|
||||
#include <math_private.h>
|
||||
|
||||
@ -234,7 +235,10 @@ __ieee754_y1l (long double x)
|
||||
}
|
||||
if (__glibc_unlikely (ix <= 0x3fbe))
|
||||
{ /* x < 2**-65 */
|
||||
return (-tpi / x);
|
||||
z = -tpi / x;
|
||||
if (__isinfl (z))
|
||||
__set_errno (ERANGE);
|
||||
return z;
|
||||
}
|
||||
z = x * x;
|
||||
u = U0[0] + z * (U0[1] + z * (U0[2] + z * (U0[3] + z * (U0[4] + z * U0[5]))));
|
||||
|
Loading…
Reference in New Issue
Block a user