1 1.7 uebayasi /* $NetBSD: flt_rounds.S,v 1.7 2014/05/22 15:01:56 uebayasi 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.6 christos movl -4(%rsp), %ecx 16 1.6 christos shrl $9, %ecx 17 1.6 christos andl $6, %ecx 18 1.6 christos movl $0x2d, %eax /* 0x2d = 00.10.11.01 */ 19 1.6 christos sarl %cl, %eax /* 0,1,2,3 -> 1,3,2,0 */ 20 1.5 christos andl $3, %eax 21 1.1 fvdl ret 22 1.7 uebayasi END(__flt_rounds) 23