rename amd64 architecture to x86_64
[dragonfly.git] / lib / libc / x86_64 / gen / fpsetround.S
CommitLineData
05ecdcef
SS
1/*
2 * Written by Frank van der Linden at Wasabi Systems for NetBSD.
3 * Public domain.
4 *
5 * $NetBSD: fpsetround.S,v 1.3 2002/06/12 19:17:22 fvdl Exp $
05ecdcef
SS
6 */
7
8#include <machine/asm.h>
9
10/*
11 * XXX set both the x87 control word and the SSE mxcsr register.
12 * Applications should only set exception and round flags
13 * via the fp*() interface, otherwise the status words
14 * will get our of sync.
15 */
16
17
18#ifdef WEAK_ALIAS
19WEAK_ALIAS(fpsetround, _fpsetround)
20ENTRY(_fpsetround)
21#else
22ENTRY(fpsetround)
23#endif
24 fnstcw -4(%rsp)
25 stmxcsr -8(%rsp)
26
27 andl $3,%edi
28
29 movl -4(%rsp),%edx
30 rorl $10,%edx
31 movl %edx,%eax
32 andl $3,%eax
33
34 andl $~3,%edx
35 orl %edi,%edx
36 roll $10,%edx
37 movl %edx,-4(%rsp)
38
39 movl -8(%rsp),%edx
40 rorl $13,%edx
41 andl $~3,%edx
42 orl %edi,%edx
43 roll $13,%edx
44 movl %edx,-8(%rsp)
45
46 ldmxcsr -8(%rsp)
47 fldcw -4(%rsp)
48 ret