Home | History | Annotate | Line # | Download | only in gen
flt_rounds.S revision 1.5
      1  1.5  christos /*	$NetBSD: flt_rounds.S,v 1.5 2011/09/29 22:55:45 christos Exp $	*/
      2  1.1      fvdl 
      3  1.4  christos #include <machine/asm.h>
      4  1.4  christos 
      5  1.1      fvdl /*
      6  1.4  christos  * 00 0 round to zero
      7  1.4  christos  * 01 1 round to nearest
      8  1.4  christos  * 10 2 round to positive infinity
      9  1.4  christos  * 11 3 round to negative infinity
     10  1.1      fvdl  */
     11  1.1      fvdl 	.text
     12  1.1      fvdl 	_ALIGN_TEXT
     13  1.1      fvdl ENTRY(__flt_rounds)
     14  1.4  christos 	fnstcw	-4(%rsp)
     15  1.5  christos 	movl	-4(%rsp), %eax
     16  1.5  christos 	shrl	$10, %eax
     17  1.5  christos 	andl	$3, %eax
     18  1.4  christos 	xorl	$1, %eax	/* map 0,1,2,3 -> 1,0,3,2 */
     19  1.1      fvdl 	ret
     20