mirror of
git://sourceware.org/git/glibc.git
synced 2025-02-23 13:09:58 +08:00
Fix dbl-64 asin (sNaN) (bug 20213).
The dbl-64 version of asin returns sNaN for sNaN arguments. This patch fixes it to add NaN arguments to themselves so that qNaN is returned in this case. Tested for x86_64 and x86. [BZ #20213] * sysdeps/ieee754/dbl-64/e_asin.c (__ieee754_asin): Add NaN argument to itself. * math/libm-test.inc (asin_test_data): Add sNaN tests.
This commit is contained in:
parent
af5fdf5a35
commit
3d8b06bc61
@ -1,3 +1,10 @@
|
||||
2016-06-06 Joseph Myers <joseph@codesourcery.com>
|
||||
|
||||
[BZ #20213]
|
||||
* sysdeps/ieee754/dbl-64/e_asin.c (__ieee754_asin): Add NaN
|
||||
argument to itself.
|
||||
* math/libm-test.inc (asin_test_data): Add sNaN tests.
|
||||
|
||||
2016-06-06 Adhemerval Zanella <adhemerval.zanella@linaro.org>
|
||||
|
||||
* misc/Makefile (CFLAGS-pwritev.c): New variable: add cancellation
|
||||
|
@ -1853,6 +1853,8 @@ static const struct test_f_f_data asin_test_data[] =
|
||||
TEST_f_f (asin, minus_infty, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
|
||||
TEST_f_f (asin, qnan_value, qnan_value, NO_INEXACT_EXCEPTION|ERRNO_UNCHANGED),
|
||||
TEST_f_f (asin, -qnan_value, qnan_value, NO_INEXACT_EXCEPTION|ERRNO_UNCHANGED),
|
||||
TEST_f_f (asin, snan_value, qnan_value, INVALID_EXCEPTION),
|
||||
TEST_f_f (asin, -snan_value, qnan_value, INVALID_EXCEPTION),
|
||||
|
||||
/* asin x == qNaN plus invalid exception for |x| > 1. */
|
||||
TEST_f_f (asin, 1.125L, qnan_value, INVALID_EXCEPTION|ERRNO_EDOM),
|
||||
|
@ -323,7 +323,7 @@ __ieee754_asin(double x){
|
||||
/*---------------------------- |x|>=1 -------------------------------*/
|
||||
else if (k==0x3ff00000 && u.i[LOW_HALF]==0) return (m>0)?hp0.x:-hp0.x;
|
||||
else
|
||||
if (k>0x7ff00000 || (k == 0x7ff00000 && u.i[LOW_HALF] != 0)) return x;
|
||||
if (k>0x7ff00000 || (k == 0x7ff00000 && u.i[LOW_HALF] != 0)) return x + x;
|
||||
else {
|
||||
u.i[HIGH_HALF]=0x7ff00000;
|
||||
v.i[HIGH_HALF]=0x7ff00000;
|
||||
|
Loading…
Reference in New Issue
Block a user