* mingwex/math/round.c: Rewrite.
* mingwex/math/roundf.c: Rewrite. * mingwex/math/roundl.c: Rewrite.
This commit is contained in:
parent
20e0dcfb3e
commit
521a0aa9a8
|
@ -1,3 +1,9 @@
|
||||||
|
2004-03-29 Danny Smith <dannysmith@users.sourceforge.net>
|
||||||
|
|
||||||
|
* mingwex/math/round.c: Rewrite.
|
||||||
|
* mingwex/math/roundf.c: Rewrite.
|
||||||
|
* mingwex/math/roundl.c: Rewrite.
|
||||||
|
|
||||||
2004-03-25 Danny Smith <dannysmith@users.sourceforge.net>
|
2004-03-25 Danny Smith <dannysmith@users.sourceforge.net>
|
||||||
|
|
||||||
* include/_mingw.h (__MSVCRT_VERSION__): Define default as 0x0600.
|
* include/_mingw.h (__MSVCRT_VERSION__): Define default as 0x0600.
|
||||||
|
|
|
@ -1,29 +1,8 @@
|
||||||
#include <fenv.h>
|
#include <math.h>
|
||||||
|
|
||||||
double
|
double
|
||||||
round (double x) {
|
round (double x)
|
||||||
double retval;
|
{
|
||||||
unsigned short saved_cw, _cw;
|
/* Add +/- 0.5 then then round towards zero. */
|
||||||
__asm__ (
|
return trunc ( x + (x >= 0.0 ? 0.5 : -0.5));
|
||||||
"fnstcw %0;"
|
|
||||||
: "=m" (saved_cw)
|
|
||||||
); /* save control word */
|
|
||||||
_cw = ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO)
|
|
||||||
| (x > 0.0 ? FE_UPWARD : FE_DOWNWARD); /* round away from zero */
|
|
||||||
__asm__ (
|
|
||||||
"fldcw %0;"
|
|
||||||
:
|
|
||||||
: "m" (_cw)
|
|
||||||
); /* load the rounding control */
|
|
||||||
__asm__ (
|
|
||||||
"frndint;"
|
|
||||||
: "=t" (retval)
|
|
||||||
: "0" (x)
|
|
||||||
); /* do the rounding */
|
|
||||||
__asm__ (
|
|
||||||
"fldcw %0;"
|
|
||||||
:
|
|
||||||
: "m" (saved_cw)
|
|
||||||
); /* restore control word */
|
|
||||||
return retval;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,29 +1,8 @@
|
||||||
#include <fenv.h>
|
#include <math.h>
|
||||||
|
|
||||||
float
|
float
|
||||||
roundf (float x) {
|
roundf (float x)
|
||||||
double retval;
|
{
|
||||||
unsigned short saved_cw, _cw;
|
/* Add +/- 0.5 then then round towards zero. */
|
||||||
__asm__ (
|
return truncf ( x + (x >= 0.0F ? 0.5F : -0.5F));
|
||||||
"fnstcw %0;"
|
|
||||||
: "=m" (saved_cw)
|
|
||||||
); /* save control word */
|
|
||||||
_cw = ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO)
|
|
||||||
| (x > 0.0 ? FE_UPWARD : FE_DOWNWARD); /* round away from zero */
|
|
||||||
__asm__ (
|
|
||||||
"fldcw %0;"
|
|
||||||
:
|
|
||||||
: "m" (_cw)
|
|
||||||
); /* load the rounding control */
|
|
||||||
__asm__ (
|
|
||||||
"frndint;"
|
|
||||||
: "=t" (retval)
|
|
||||||
: "0" (x)
|
|
||||||
); /* do the rounding */
|
|
||||||
__asm__ (
|
|
||||||
"fldcw %0;"
|
|
||||||
:
|
|
||||||
: "m" (saved_cw)
|
|
||||||
); /* restore control word */
|
|
||||||
return retval;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,30 +1,8 @@
|
||||||
#include <fenv.h>
|
#include <math.h>
|
||||||
|
|
||||||
long double
|
long double
|
||||||
roundl (long double x) {
|
roundl (long double x)
|
||||||
long double retval;
|
{
|
||||||
unsigned short saved_cw, _cw;
|
/* Add +/- 0.5 then then round towards zero. */
|
||||||
__asm__ (
|
return truncl ( x + (x >= 0.0L ? 0.5L : -0.5L));
|
||||||
"fnstcw %0;"
|
|
||||||
: "=m" (saved_cw)
|
|
||||||
); /* save control word */
|
|
||||||
_cw = ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO)
|
|
||||||
| (x > 0.0 ? FE_UPWARD : FE_DOWNWARD); /* round away from zero */
|
|
||||||
__asm__ (
|
|
||||||
"fldcw %0;"
|
|
||||||
:
|
|
||||||
: "m" (_cw)
|
|
||||||
); /* load the rounding control */
|
|
||||||
__asm__ (
|
|
||||||
"frndint;"
|
|
||||||
: "=t" (retval)
|
|
||||||
: "0" (x)
|
|
||||||
); /* do the rounding */
|
|
||||||
__asm__ (
|
|
||||||
"fldcw %0;"
|
|
||||||
:
|
|
||||||
: "m" (saved_cw)
|
|
||||||
); /* restore control word */
|
|
||||||
return retval;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue