Home | History | Annotate | Line # | Download | only in gen
      1  1.5  uebayasi /*	$NetBSD: fpsetround.S,v 1.5 2014/05/22 15:01:56 uebayasi Exp $	*/
      2  1.1      fvdl 
      3  1.1      fvdl /*
      4  1.3      fvdl  * Written by Frank van der Linden at Wasabi Systems for NetBSD.
      5  1.1      fvdl  * Public domain.
      6  1.1      fvdl  */
      7  1.1      fvdl 
      8  1.1      fvdl #include <machine/asm.h>
      9  1.1      fvdl 
     10  1.3      fvdl /*
     11  1.3      fvdl  * XXX set both the x87 control word and the SSE mxcsr register.
     12  1.3      fvdl  * Applications should only set exception and round flags
     13  1.3      fvdl  * via the fp*() interface, otherwise the status words
     14  1.3      fvdl  * will get our of sync.
     15  1.3      fvdl  */
     16  1.3      fvdl 
     17  1.3      fvdl 
     18  1.2   thorpej #ifdef WEAK_ALIAS
     19  1.2   thorpej WEAK_ALIAS(fpsetround, _fpsetround)
     20  1.2   thorpej ENTRY(_fpsetround)
     21  1.2   thorpej #else
     22  1.1      fvdl ENTRY(fpsetround)
     23  1.2   thorpej #endif
     24  1.4  christos 
     25  1.3      fvdl 	fnstcw	-4(%rsp)
     26  1.4  christos 	movl	-4(%rsp), %edx
     27  1.4  christos 	movl	%edx, %eax
     28  1.4  christos 	andl	$0x00000c00, %eax
     29  1.4  christos 	andl	$0xfffff3ff, %edx
     30  1.4  christos 	orl	%edi, %edx
     31  1.4  christos 	movl	%edx, -4(%rsp)
     32  1.4  christos 	fldcw	-4(%rsp)
     33  1.3      fvdl 
     34  1.4  christos 	stmxcsr	-4(%rsp)
     35  1.4  christos 	movl	-4(%rsp), %edx
     36  1.4  christos 	andl	$0xffff9fff, %edx
     37  1.4  christos 	sall	$3, %edi
     38  1.3      fvdl 	orl	%edi,%edx
     39  1.3      fvdl 	movl	%edx,-4(%rsp)
     40  1.4  christos 	ldmxcsr	-4(%rsp)
     41  1.3      fvdl 
     42  1.1      fvdl 	ret
     43  1.5  uebayasi #ifdef WEAK_ALIAS
     44  1.5  uebayasi END(_fpsetround)
     45  1.5  uebayasi #else
     46  1.5  uebayasi END(fpsetround)
     47  1.5  uebayasi #endif
     48