diff options
author | Christopher Faylor <me@cgf.cx> | 2000-02-17 19:39:52 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2000-02-17 19:39:52 +0000 |
commit | 8a0efa53e44919bcf5ccb1d3353618a82afdf8bc (patch) | |
tree | 68c3dbf3f2c6fd5d49777def9914d77b5cd4589d /newlib/libm/mathfp/sf_frexp.c | |
parent | 1fd5e000ace55b323124c7e556a7a864b972a5c4 (diff) | |
download | cygnal-8a0efa53e44919bcf5ccb1d3353618a82afdf8bc.tar.gz cygnal-8a0efa53e44919bcf5ccb1d3353618a82afdf8bc.tar.bz2 cygnal-8a0efa53e44919bcf5ccb1d3353618a82afdf8bc.zip |
import newlib-2000-02-17 snapshot
Diffstat (limited to 'newlib/libm/mathfp/sf_frexp.c')
-rw-r--r-- | newlib/libm/mathfp/sf_frexp.c | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/newlib/libm/mathfp/sf_frexp.c b/newlib/libm/mathfp/sf_frexp.c new file mode 100644 index 000000000..c2751f65c --- /dev/null +++ b/newlib/libm/mathfp/sf_frexp.c @@ -0,0 +1,58 @@ + +/* @(#)z_frexpf.c 1.0 98/08/13 */ +/****************************************************************** + * frexp + * + * Input: + * d - floating point value + * exp - exponent value + * + * Output: + * A floating point value in the range [0.5, 1). + * + * Description: + * This routine breaks a floating point value into a number f and + * an exponent exp such that d = f * 2 ^ exp. + * + *****************************************************************/ + +#include "fdlibm.h" +#include "zmath.h" + +float frexpf (float d, int *exp) +{ + float f; + __int32_t wf, wd; + + GET_FLOAT_WORD (wd, d); + + /* Get the exponent. */ + *exp = ((wd & 0x7f800000) >> 23) - 126; + + /* Get the mantissa. */ + wf = wd & 0x7fffff; + wf |= 0x3f000000; + + SET_FLOAT_WORD (f, wf); + + /* Check for special values. */ + switch (numtestf (f)) + { + case NAN: + case INF: + errno = EDOM; + *exp = 0; + return (f); + } + + return (f); +} + +#ifdef _DOUBLE_IS_32BITS + +double frexp (double x, int *exp) +{ + return (double) frexpf ((float) x, exp); +} + +#endif /* defined(_DOUBLE_IS_32BITS) */ |