mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-05 19:21:05 +00:00
5f93cd52f6
2003-11-17 Jakub Jelinek <jakub@redhat.com> * posix/regcomp.c (optimize_utf8): Optimize multi-byte chars as well. * posix/bug-regex20.c (tests): Add new tests. Multi-byte char followed by dup operator is expected to be optimized. * posix/regexec.c (check_node_accept_bytes): Move nrules and j variables to the block where they are only used, initialize nrules only immediately before using it. 2003-11-15 Andreas Jaeger <aj@suse.de> * sysdeps/x86_64/fpu/s_scalbnl.S: New file. * sysdeps/x86_64/fpu/s_truncl.S: New file. * sysdeps/x86_64/fpu/s_nearbyintl.S: New file. * sysdeps/x86_64/fpu/s_floorl.S: New file. * sysdeps/x86_64/fpu/s_ilogbl.S: New file. * sysdeps/x86_64/fpu/e_remainderl.S: New file. * math/libm-test.inc (floor_test): Test also ±0.25. (ceil_test): Test -0.25.
36 lines
678 B
ArmAsm
36 lines
678 B
ArmAsm
/*
|
|
* Written by J.T. Conklin <jtc@netbsd.org>.
|
|
* Changes for long double by Ulrich Drepper <drepper@cygnus.com>
|
|
* Adapted for x86-64 by Andreas Jaeger <aj@suse.de>.
|
|
* Public domain.
|
|
*/
|
|
|
|
#include <machine/asm.h>
|
|
|
|
ENTRY(__ilogbl)
|
|
fldt 8(%rsp)
|
|
/* I added the following ugly construct because ilogb(+-Inf) is
|
|
required to return INT_MAX in ISO C99.
|
|
-- jakub@redhat.com. */
|
|
fxam /* Is NaN or +-Inf? */
|
|
fstsw %ax
|
|
movb $0x45, %dh
|
|
andb %ah, %dh
|
|
cmpb $0x05, %dh
|
|
je 1f /* Is +-Inf, jump. */
|
|
|
|
fxtract
|
|
fstp %st
|
|
|
|
fistpl -4(%rsp)
|
|
fwait
|
|
movl -4(%rsp),%eax
|
|
|
|
ret
|
|
|
|
1: fstp %st
|
|
movl $0x7fffffff, %eax
|
|
ret
|
|
END (__ilogbl)
|
|
weak_alias (__ilogbl, ilogbl)
|