20067523af
math routines that appear to be (a) correct and (b) faster than their MI counterparts on my Pentium 4. Obtained from: NetBSD
30 lines
552 B
ArmAsm
30 lines
552 B
ArmAsm
/*
|
|
* Written by J.T. Conklin <jtc@netbsd.org>.
|
|
* Public domain.
|
|
*/
|
|
|
|
#include <machine/asm.h>
|
|
|
|
__FBSDID("$FreeBSD$");
|
|
/* RCSID("$NetBSD: s_floorf.S,v 1.3 1995/05/09 00:04:32 jtc Exp $") */
|
|
|
|
ENTRY(floorf)
|
|
pushl %ebp
|
|
movl %esp,%ebp
|
|
subl $8,%esp
|
|
|
|
fstcw -12(%ebp) /* store fpu control word */
|
|
movw -12(%ebp),%dx
|
|
orw $0x0400,%dx /* round towards -oo */
|
|
andw $0xf7ff,%dx
|
|
movw %dx,-16(%ebp)
|
|
fldcw -16(%ebp) /* load modfied control word */
|
|
|
|
flds 8(%ebp); /* round */
|
|
frndint
|
|
|
|
fldcw -12(%ebp) /* restore original control word */
|
|
|
|
leave
|
|
ret
|