mirror of
https://sourceware.org/git/glibc.git
synced 2025-11-27 12:01:15 +03:00
Fix i386/x86_64 log2l (sNaN) (bug 20235).
The i386/x86_64 versions of log2l return sNaN for sNaN input. This patch fixes them to add NaN inputs to themselves so that qNaN is returned in this case. Tested for x86_64 and x86. [BZ #20235] * sysdeps/i386/fpu/e_log2l.S (__ieee754_log2l): Add NaN input to itself. * sysdeps/x86_64/fpu/e_log2l.S (__ieee754_log2l): Likewise. * math/libm-test.inc (log2_test_data): Add sNaN tests.
This commit is contained in:
@@ -1,5 +1,11 @@
|
|||||||
2016-06-09 Joseph Myers <joseph@codesourcery.com>
|
2016-06-09 Joseph Myers <joseph@codesourcery.com>
|
||||||
|
|
||||||
|
[BZ #20235]
|
||||||
|
* sysdeps/i386/fpu/e_log2l.S (__ieee754_log2l): Add NaN input to
|
||||||
|
itself.
|
||||||
|
* sysdeps/x86_64/fpu/e_log2l.S (__ieee754_log2l): Likewise.
|
||||||
|
* math/libm-test.inc (log2_test_data): Add sNaN tests.
|
||||||
|
|
||||||
[BZ #20234]
|
[BZ #20234]
|
||||||
* sysdeps/ieee754/ldbl-128ibm/s_log1pl.c (__log1pl): Add positive
|
* sysdeps/ieee754/ldbl-128ibm/s_log1pl.c (__log1pl): Add positive
|
||||||
infinity or NaN input to itself.
|
infinity or NaN input to itself.
|
||||||
|
|||||||
@@ -9076,6 +9076,8 @@ static const struct test_f_f_data log2_test_data[] =
|
|||||||
TEST_f_f (log2, plus_infty, plus_infty, ERRNO_UNCHANGED),
|
TEST_f_f (log2, plus_infty, plus_infty, ERRNO_UNCHANGED),
|
||||||
TEST_f_f (log2, qnan_value, qnan_value, NO_INEXACT_EXCEPTION|ERRNO_UNCHANGED),
|
TEST_f_f (log2, qnan_value, qnan_value, NO_INEXACT_EXCEPTION|ERRNO_UNCHANGED),
|
||||||
TEST_f_f (log2, -qnan_value, qnan_value, NO_INEXACT_EXCEPTION|ERRNO_UNCHANGED),
|
TEST_f_f (log2, -qnan_value, qnan_value, NO_INEXACT_EXCEPTION|ERRNO_UNCHANGED),
|
||||||
|
TEST_f_f (log2, snan_value, qnan_value, INVALID_EXCEPTION),
|
||||||
|
TEST_f_f (log2, -snan_value, qnan_value, INVALID_EXCEPTION),
|
||||||
|
|
||||||
AUTO_TESTS_f_f (log2),
|
AUTO_TESTS_f_f (log2),
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -64,6 +64,7 @@ ENTRY(__ieee754_log2l)
|
|||||||
3: jp 4b // in case x is <EFBFBD>Inf
|
3: jp 4b // in case x is <EFBFBD>Inf
|
||||||
fstp %st(1)
|
fstp %st(1)
|
||||||
fstp %st(1)
|
fstp %st(1)
|
||||||
|
fadd %st(0)
|
||||||
ret
|
ret
|
||||||
END (__ieee754_log2l)
|
END (__ieee754_log2l)
|
||||||
strong_alias (__ieee754_log2l, __log2l_finite)
|
strong_alias (__ieee754_log2l, __log2l_finite)
|
||||||
|
|||||||
@@ -63,6 +63,7 @@ ENTRY(__ieee754_log2l)
|
|||||||
jnz 4b // in case x is <EFBFBD>Inf
|
jnz 4b // in case x is <EFBFBD>Inf
|
||||||
fstp %st(1)
|
fstp %st(1)
|
||||||
fstp %st(1)
|
fstp %st(1)
|
||||||
|
fadd %st(0)
|
||||||
ret
|
ret
|
||||||
END (__ieee754_log2l)
|
END (__ieee754_log2l)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user