As the current libc includes a libm implementation, with the new libc this is needed. Unneeded (for the moment) archs have been removed.
		
			
				
	
	
		
			44 lines
		
	
	
		
			762 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			762 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
/*
 | 
						|
 * Written by J.T. Conklin <jtc@NetBSD.org>.
 | 
						|
 * Public domain.
 | 
						|
 */
 | 
						|
 | 
						|
#include <machine/asm.h>
 | 
						|
 | 
						|
RCSID("$NetBSD: s_floorf.S,v 1.7 2004/07/16 18:40:24 drochner Exp $")
 | 
						|
 | 
						|
ENTRY(floorf)
 | 
						|
#ifdef __i386__
 | 
						|
	pushl	%ebp
 | 
						|
	movl	%esp,%ebp
 | 
						|
	subl	$8,%esp
 | 
						|
 | 
						|
	fstcw	-4(%ebp)		/* store fpu control word */
 | 
						|
	movw	-4(%ebp),%dx
 | 
						|
	orw	$0x0400,%dx		/* round towards -oo */
 | 
						|
	andw	$0xf7ff,%dx
 | 
						|
	movw	%dx,-8(%ebp)
 | 
						|
	fldcw	-8(%ebp)		/* load modfied control word */
 | 
						|
 | 
						|
	flds	8(%ebp);		/* round */
 | 
						|
	frndint
 | 
						|
 | 
						|
	fldcw	-4(%ebp)		/* restore original control word */
 | 
						|
 | 
						|
	leave
 | 
						|
#else
 | 
						|
	movss	%xmm0, -4(%rsp)
 | 
						|
	fstcw	-8(%rsp)
 | 
						|
	movw	-8(%rsp),%dx
 | 
						|
	orw	$0x0400,%dx
 | 
						|
	andw	$0xf7ff,%dx  
 | 
						|
	movw	%dx,-12(%rsp)
 | 
						|
	fldcw	-12(%rsp)
 | 
						|
	flds	-4(%rsp)
 | 
						|
	frndint
 | 
						|
	fldcw	-8(%rsp)
 | 
						|
	fstps	-4(%rsp)
 | 
						|
	movss	-4(%rsp),%xmm0
 | 
						|
#endif
 | 
						|
	ret
 |