2007-12-19 Dave Korn <dave.korn@artimi.com>
Jeff Johnston <jjohnstn@redhhat.com>
* libc/include/_ansi.h: Add _LONG_LONG definition.
* libc/include/math.h (llrint, llrintf, rintl, lrintl, llrintl): Add
prototypes.
* libc/machine/i386/machine/fastmath.h: Add support for new i386
fast math versions of rint, lrint, and llrint family functions.
* libm/machine/i386/Makefile.am: Add new files.
* libm/machine/i386/Makefile.in: Regenerated.
* libm/machine/i386/f_llrint.c, libm/machine/i386/f_lrint.c,
libm/machine/i386/f_rint.c, libm/machine/i386/f_llrintf.c,
libm/machine/i386/f_lrintf.c, libm/machine/i386/f_rintf.c,
libm/machine/i386/f_llrintl.c, libm/machine/i386/f_lrintl.c,
libm/machine/i386/f_rintl.c: New files with fast math implementations.
2007-12-20 06:20:25 +08:00
|
|
|
/*
|
|
|
|
* ====================================================
|
|
|
|
* x87 FP implementation contributed to Newlib by
|
|
|
|
* Dave Korn, November 2007. This file is placed in the
|
|
|
|
* public domain. Permission to use, copy, modify, and
|
|
|
|
* distribute this software is freely granted.
|
|
|
|
* ====================================================
|
|
|
|
*/
|
|
|
|
|
|
|
|
#if defined(__GNUC__) && !defined(_SOFT_FLOAT)
|
|
|
|
|
|
|
|
#include <math.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
FUNCTION
|
|
|
|
<<rint>>, <<rintf>>, <<rintl>>---round to integer
|
|
|
|
INDEX
|
|
|
|
rint
|
|
|
|
INDEX
|
|
|
|
rintf
|
|
|
|
INDEX
|
|
|
|
rintl
|
|
|
|
|
2017-11-30 16:37:42 +08:00
|
|
|
SYNOPSIS
|
2007-12-19 Dave Korn <dave.korn@artimi.com>
Jeff Johnston <jjohnstn@redhhat.com>
* libc/include/_ansi.h: Add _LONG_LONG definition.
* libc/include/math.h (llrint, llrintf, rintl, lrintl, llrintl): Add
prototypes.
* libc/machine/i386/machine/fastmath.h: Add support for new i386
fast math versions of rint, lrint, and llrint family functions.
* libm/machine/i386/Makefile.am: Add new files.
* libm/machine/i386/Makefile.in: Regenerated.
* libm/machine/i386/f_llrint.c, libm/machine/i386/f_lrint.c,
libm/machine/i386/f_rint.c, libm/machine/i386/f_llrintf.c,
libm/machine/i386/f_lrintf.c, libm/machine/i386/f_rintf.c,
libm/machine/i386/f_llrintl.c, libm/machine/i386/f_lrintl.c,
libm/machine/i386/f_rintl.c: New files with fast math implementations.
2007-12-20 06:20:25 +08:00
|
|
|
#include <math.h>
|
|
|
|
double rint(double x);
|
|
|
|
float rintf(float x);
|
|
|
|
long double rintl(long double x);
|
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
The <<rint>>, <<rintf>> and <<rintl>> functions round <[x]> to an integer value
|
|
|
|
in floating-point format, using the current rounding direction. They may
|
|
|
|
raise the inexact exception if the result differs in value from the argument.
|
|
|
|
|
|
|
|
RETURNS
|
|
|
|
These functions return the rounded integer value of <[x]>.
|
|
|
|
|
|
|
|
PORTABILITY
|
|
|
|
<<rint>>, <<rintf>> and <<rintl>> are ANSI.
|
|
|
|
<<rint>> and <<rintf>> are available on all platforms.
|
|
|
|
<<rintl>> is only available on i386 platforms when hardware
|
|
|
|
floating point support is available and when compiling with GCC.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Fast math version of rint(x)
|
|
|
|
* Return x rounded to integral value according to the prevailing
|
|
|
|
* rounding mode.
|
|
|
|
* Method:
|
|
|
|
* Using inline x87 asms.
|
|
|
|
* Exception:
|
|
|
|
* Governed by x87 FPCR.
|
|
|
|
*/
|
|
|
|
|
|
|
|
double _f_rint (double x)
|
|
|
|
{
|
|
|
|
double _result;
|
|
|
|
asm ("frndint" : "=t" (_result) : "0" (x));
|
|
|
|
return _result;
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* !__GNUC__ || _SOFT_FLOAT */
|
|
|
|
|