Cygwin: ilogbl: Make sure to return FP_ILGB0 on zero input

Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
This commit is contained in:
Corinna Vinschen 2019-12-16 10:50:17 +01:00
parent b74ba7dca6
commit 29ba52da95
2 changed files with 13 additions and 0 deletions

View File

@ -23,6 +23,8 @@ __MINGW_USYMBOL(ilogbl):
andb %ah, %dh
cmpb $0x05, %dh
je 1f /* Is +-Inf, jump. */
cmpb $0x40, %dh
je 2f /* Is +-Inf, jump. */
fxtract
pushq %rax
@ -37,6 +39,9 @@ __MINGW_USYMBOL(ilogbl):
1: fstp %st
movl $0x7fffffff, %eax
ret
2: fstp %st
movl $0x80000001, %eax /* FP_ILOGB0 */
ret
#else
fldt 4(%esp)
/* I added the following ugly construct because ilogb(+-Inf) is
@ -48,6 +53,8 @@ __MINGW_USYMBOL(ilogbl):
andb %ah, %dh
cmpb $0x05, %dh
je 1f /* Is +-Inf, jump. */
cmpb $0x40, %dh
je 2f /* Is +-Inf, jump. */
fxtract
pushl %eax
@ -62,4 +69,7 @@ __MINGW_USYMBOL(ilogbl):
1: fstp %st
movl $0x7fffffff, %eax
ret
2: fstp %st
movl $0x80000001, %eax /* FP_ILOGB0 */
ret
#endif

View File

@ -108,3 +108,6 @@ Bug Fixes
- Fix an assertion failure when /cygdrive contains an offline network
drive.
Addresses: https://cygwin.com/ml/cygwin/2019-12/msg00016.html
- Fix return value of ilogbl for 0 input.
Addresses: https://cygwin.com/ml/cygwin/2019-12/msg00074.html