Simplify strncat.
[glibc.git] / sysdeps / i386 / fpu / s_ceill.S
blob4b272c522aeb56bd56db70d971b387b23e73a0dc
1 /*
2  * Written by J.T. Conklin <jtc@netbsd.org>.
3  * Changes for long double by Ulrich Drepper <drepper@cygnus.com>
4  * Public domain.
5  */
7 #include <machine/asm.h>
9 RCSID("$NetBSD: $")
11 ENTRY(__ceill)
12         fldt    4(%esp)
13         subl    $8,%esp
14         cfi_adjust_cfa_offset (8)
16         fstcw   4(%esp)                 /* store fpu control word */
18         /* We use here %edx although only the low 1 bits are defined.
19            But none of the operations should care and they are faster
20            than the 16 bit operations.  */
21         movl    $0x0800,%edx            /* round towards +oo */
22         orl     4(%esp),%edx
23         andl    $0xfbff,%edx
24         movl    %edx,(%esp)
25         fldcw   (%esp)                  /* load modified control word */
27         frndint                         /* round */
29         fldcw   4(%esp)                 /* restore original control word */
31         addl    $8,%esp
32         cfi_adjust_cfa_offset (-8)
33         ret
34 END (__ceill)
35 weak_alias (__ceill, ceill)