diff options
Diffstat (limited to 'newlib/libm/machine/i386/f_lrintl.c')
-rw-r--r-- | newlib/libm/machine/i386/f_lrintl.c | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/newlib/libm/machine/i386/f_lrintl.c b/newlib/libm/machine/i386/f_lrintl.c new file mode 100644 index 000000000..eae2bca28 --- /dev/null +++ b/newlib/libm/machine/i386/f_lrintl.c @@ -0,0 +1,38 @@ +/* + * ==================================================== + * 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. + * ==================================================== + */ + +#ifdef __GNUC__ +#if !defined(_SOFT_FLOAT) + +#include <math.h> + +/* + * Fast math version of lrintl(x) + * Return x rounded to integral value according to the prevailing + * rounding mode. + * Method: + * Using inline x87 asms. + * Exception: + * Governed by x87 FPCR. + */ + +long int _f_lrintl (long double x) +{ + long int _result; + asm ("fistpl %0" : "=m" (_result) : "t" (x) : "st"); + return _result; +} + +/* For now, there is only the fast math version so we use it. */ +long int lrintl (long double x) { + return _f_lrintl(x); +} + +#endif /* !_SOFT_FLOAT */ +#endif /* __GNUC__ */ |