diff options
author | Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> | 2015-08-09 08:46:52 +0000 |
---|---|---|
committer | François-Xavier Coudert <fxcoudert@gcc.gnu.org> | 2015-08-09 08:46:52 +0000 |
commit | 03c02a42c59949e6ae0fdb0892fb3e751932d17b (patch) | |
tree | 23d737a6cb4a3fa57fd2bff054bbf1a74bee923e /libquadmath/math/logbq.c | |
parent | e7b724da79a8b0ef274c65ac9bdb58b55ad7eea3 (diff) | |
download | gcc-03c02a42c59949e6ae0fdb0892fb3e751932d17b.tar.gz |
Makefile.am (libquadmath_la_SOURCES): Add math/logbq.c.
* Makefile.am (libquadmath_la_SOURCES): Add math/logbq.c.
* Makefile.in: Regenerate.
* libquadmath.texi: Document logbq.
* quadmath.h: Add logbq prototype.
* quadmath.map: Add logbq.
* quadmath_weak.h: Add logbq prototype.
* math/logbq.c: New file
From-SVN: r226748
Diffstat (limited to 'libquadmath/math/logbq.c')
-rw-r--r-- | libquadmath/math/logbq.c | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/libquadmath/math/logbq.c b/libquadmath/math/logbq.c new file mode 100644 index 00000000000..2e47a4b434a --- /dev/null +++ b/libquadmath/math/logbq.c @@ -0,0 +1,47 @@ +/* s_logbl.c -- long double version of s_logb.c. + * Conversion to IEEE quad long double by Jakub Jelinek, jj@ultra.linux.cz. + */ + +/* + * ==================================================== + * Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved. + * + * Developed at SunPro, a Sun Microsystems, Inc. business. + * Permission to use, copy, modify, and distribute this + * software is freely granted, provided that this notice + * is preserved. + * ==================================================== + */ + +/* + * long double logbl(x) + * IEEE 754 logb. Included to pass IEEE test suite. Not recommend. + * Use ilogb instead. + */ + +#include "quadmath-imp.h" + +__float128 +logbq (__float128 x) +{ + int64_t lx, hx, ex; + + GET_FLT128_WORDS64 (hx, lx, x); + hx &= 0x7fffffffffffffffLL; /* high |x| */ + if ((hx | lx) == 0) + return -1.0 / fabsq (x); + if (hx >= 0x7fff000000000000LL) + return x * x; + if ((ex = hx >> 48) == 0) /* IEEE 754 logb */ + { + /* POSIX specifies that denormal number is treated as + though it were normalized. */ + int ma; + if (hx == 0) + ma = __builtin_clzll (lx) + 64; + else + ma = __builtin_clzll (hx); + ex -= ma - 16; + } + return (__float128) (ex - 16383); +} |