35 lines
663 B
C
35 lines
663 B
C
|
/* $NetBSD: flt_rounds.c,v 1.6 2010/09/03 17:22:51 matt Exp $ */
|
||
|
|
||
|
/*
|
||
|
* Written by J.T. Conklin, Apr 11, 1995
|
||
|
* Public domain.
|
||
|
*/
|
||
|
|
||
|
#include <sys/cdefs.h>
|
||
|
#if defined(LIBC_SCCS) && !defined(lint)
|
||
|
__RCSID("$NetBSD: flt_rounds.c,v 1.6 2010/09/03 17:22:51 matt Exp $");
|
||
|
#endif /* LIBC_SCCS and not lint */
|
||
|
|
||
|
#include <machine/float.h>
|
||
|
#include <ieeefp.h>
|
||
|
|
||
|
static const int map[] = {
|
||
|
1, /* round to nearest */
|
||
|
0, /* round to zero */
|
||
|
2, /* round to positive infinity */
|
||
|
3 /* round to negative infinity */
|
||
|
};
|
||
|
|
||
|
int
|
||
|
__flt_rounds()
|
||
|
{
|
||
|
#ifdef SOFTFLOAT_FOR_GCC
|
||
|
return map[fpgetround()];
|
||
|
#else
|
||
|
int x;
|
||
|
|
||
|
__asm("cfc1\t%0,$31" : "=r" (x));
|
||
|
return map[x & 0x03];
|
||
|
#endif
|
||
|
}
|