From f95a4a932476be2ba99e2fd081e8d2bc6ea12813 Mon Sep 17 00:00:00 2001 From: PikalaxALT Date: Fri, 15 Dec 2017 09:38:53 -0500 Subject: Import newlib and create makefile --- newlib/libm/mathfp/s_ldexp.c | 123 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100644 newlib/libm/mathfp/s_ldexp.c (limited to 'newlib/libm/mathfp/s_ldexp.c') diff --git a/newlib/libm/mathfp/s_ldexp.c b/newlib/libm/mathfp/s_ldexp.c new file mode 100644 index 0000000..f68e8e4 --- /dev/null +++ b/newlib/libm/mathfp/s_ldexp.c @@ -0,0 +1,123 @@ + +/* @(#)z_ldexp.c 1.0 98/08/13 */ + +/* +FUNCTION + <>, <>---load exponent + +INDEX + ldexp +INDEX + ldexpf + +ANSI_SYNOPSIS + #include + double ldexp(double <[val]>, int <[exp]>); + float ldexpf(float <[val]>, int <[exp]>); + +TRAD_SYNOPSIS + #include + + double ldexp(<[val]>, <[exp]>) + double <[val]>; + int <[exp]>; + + float ldexpf(<[val]>, <[exp]>) + float <[val]>; + int <[exp]>; + +DESCRIPTION +<> calculates the value +@ifinfo +<[val]> times 2 to the power <[exp]>. +@end ifinfo +@tex +$val\times 2^{exp}$. +@end tex +<> is identical, save that it takes and returns <> +rather than <> values. + +RETURNS +<> returns the calculated value. + +Underflow and overflow both set <> to <>. +On underflow, <> and <> return 0.0. +On overflow, <> returns plus or minus <>. + +PORTABILITY +<> is ANSI, <> is an extension. + +*/ + +/****************************************************************** + * ldexp + * + * Input: + * d - a floating point value + * e - an exponent value + * + * Output: + * A floating point value f such that f = d * 2 ^ e. + * + * Description: + * This function creates a floating point number f such that + * f = d * 2 ^ e. + * + *****************************************************************/ + +#include +#include "fdlibm.h" +#include "zmath.h" + +#ifndef _DOUBLE_IS_32BITS + +double +_DEFUN (ldexp, (double, int), + double d _AND + int e) +{ + int exp; + __uint32_t hd; + + GET_HIGH_WORD (hd, d); + + /* Check for special values and then scale d by e. */ + switch (numtest (d)) + { + case NAN: + errno = EDOM; + break; + + case INF: + errno = ERANGE; + break; + + case 0: + break; + + default: + exp = (hd & 0x7ff00000) >> 20; + exp += e; + + if (exp > (DBL_MAX_EXP + 1023)) + { + errno = ERANGE; + d = z_infinity.d; + } + else if (exp < DBL_MIN_EXP) + { + errno = ERANGE; + d = -z_infinity.d; + } + else + { + hd &= 0x800fffff; + hd |= exp << 20; + SET_HIGH_WORD (d, hd); + } + } + + return (d); +} + +#endif /* _DOUBLE_IS_32BITS */ -- cgit v1.2.3