Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(10)

Unified Diff: gcc/mpfr/get_d.c

Issue 3050029: [gcc] GCC 4.5.0=>4.5.1 (Closed) Base URL: ssh://git@gitrw.chromium.org:9222/nacl-toolchain.git
Patch Set: Created 10 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « gcc/mpfr/gen_inverse.h ('k') | gcc/mpfr/get_d64.c » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: gcc/mpfr/get_d.c
diff --git a/gcc/mpfr/get_d.c b/gcc/mpfr/get_d.c
deleted file mode 100644
index f6558b4d90378fc6cd6b67ed45b99ff71c028fae..0000000000000000000000000000000000000000
--- a/gcc/mpfr/get_d.c
+++ /dev/null
@@ -1,297 +0,0 @@
-/* mpfr_get_d, mpfr_get_d_2exp -- convert a multiple precision floating-point
- number to a machine double precision float
-
-Copyright 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Free Software Foundation, Inc.
-Contributed by the Arenaire and Cacao projects, INRIA.
-
-This file is part of the GNU MPFR Library.
-
-The GNU MPFR Library is free software; you can redistribute it and/or modify
-it under the terms of the GNU Lesser General Public License as published by
-the Free Software Foundation; either version 2.1 of the License, or (at your
-option) any later version.
-
-The GNU MPFR Library is distributed in the hope that it will be useful, but
-WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
-or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
-License for more details.
-
-You should have received a copy of the GNU Lesser General Public License
-along with the GNU MPFR Library; see the file COPYING.LIB. If not, write to
-the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston,
-MA 02110-1301, USA. */
-
-#include <float.h>
-
-#define MPFR_NEED_LONGLONG_H
-#include "mpfr-impl.h"
-
-/* "double" NaN and infinities are written as explicit bytes to be sure of
- getting what we want, and to be sure of not depending on libm.
-
- Could use 4-byte "float" values and let the code convert them, but it
- seems more direct to give exactly what we want. Certainly for gcc 3.0.2
- on alphaev56-unknown-freebsd4.3 the NaN must be 8-bytes, since that
- compiler+system was seen incorrectly converting from a "float" NaN. */
-
-#if _GMP_IEEE_FLOATS
-
-/* The "d" field guarantees alignment to a suitable boundary for a double.
- Could use a union instead, if we checked the compiler supports union
- initializers. */
-struct dbl_bytes {
- unsigned char b[8];
- double d;
-};
-
-#define MPFR_DBL_INFP (* (const double *) dbl_infp.b)
-#define MPFR_DBL_INFM (* (const double *) dbl_infm.b)
-#define MPFR_DBL_NAN (* (const double *) dbl_nan.b)
-
-#if HAVE_DOUBLE_IEEE_LITTLE_ENDIAN
-static const struct dbl_bytes dbl_infp =
- { { 0, 0, 0, 0, 0, 0, 0xF0, 0x7F }, 0.0 };
-static const struct dbl_bytes dbl_infm =
- { { 0, 0, 0, 0, 0, 0, 0xF0, 0xFF }, 0.0 };
-static const struct dbl_bytes dbl_nan =
- { { 0, 0, 0, 0, 0, 0, 0xF8, 0x7F }, 0.0 };
-#endif
-#if HAVE_DOUBLE_IEEE_LITTLE_SWAPPED
-static const struct dbl_bytes dbl_infp =
- { { 0, 0, 0xF0, 0x7F, 0, 0, 0, 0 }, 0.0 };
-static const struct dbl_bytes dbl_infm =
- { { 0, 0, 0xF0, 0xFF, 0, 0, 0, 0 }, 0.0 };
-static const struct dbl_bytes dbl_nan =
- { { 0, 0, 0xF8, 0x7F, 0, 0, 0, 0 }, 0.0 };
-#endif
-#if HAVE_DOUBLE_IEEE_BIG_ENDIAN
-static const struct dbl_bytes dbl_infp =
- { { 0x7F, 0xF0, 0, 0, 0, 0, 0, 0 }, 0.0 };
-static const struct dbl_bytes dbl_infm =
- { { 0xFF, 0xF0, 0, 0, 0, 0, 0, 0 }, 0.0 };
-static const struct dbl_bytes dbl_nan =
- { { 0x7F, 0xF8, 0, 0, 0, 0, 0, 0 }, 0.0 };
-#endif
-
-#else /* _GMP_IEEE_FLOATS */
-
-#define MPFR_DBL_INFP DBL_POS_INF
-#define MPFR_DBL_INFM DBL_NEG_INF
-#define MPFR_DBL_NAN DBL_NAN
-
-#endif /* _GMP_IEEE_FLOATS */
-
-
-/* multiplies 1/2 <= d <= 1 by 2^exp */
-static double
-mpfr_scale2 (double d, int exp)
-{
-#if _GMP_IEEE_FLOATS
- {
- union ieee_double_extract x;
-
- if (MPFR_UNLIKELY (d == 1.0))
- {
- d = 0.5;
- exp ++;
- }
-
- /* now 1/2 <= d < 1 */
-
- /* infinities and zeroes have already been checked */
- MPFR_ASSERTD (-1073 <= exp && exp <= 1025);
-
- x.d = d;
- if (MPFR_UNLIKELY (exp < -1021)) /* subnormal case */
- {
- x.s.exp += exp + 52;
- x.d *= DBL_EPSILON;
- }
- else /* normalized case */
- {
- x.s.exp += exp;
- }
- return x.d;
- }
-#else /* _GMP_IEEE_FLOATS */
- {
- double factor;
-
- /* An overflow may occurs (example: 0.5*2^1024) */
- if (d < 1.0)
- {
- d += d;
- exp--;
- }
- /* Now 1.0 <= d < 2.0 */
-
- if (exp < 0)
- {
- factor = 0.5;
- exp = -exp;
- }
- else
- {
- factor = 2.0;
- }
- while (exp != 0)
- {
- if ((exp & 1) != 0)
- d *= factor;
- exp >>= 1;
- factor *= factor;
- }
- return d;
- }
-#endif
-}
-
-/* Assumes IEEE-754 double precision; otherwise, only an approximated
- result will be returned, without any guaranty (and special cases
- such as NaN must be avoided if not supported). */
-
-double
-mpfr_get_d (mpfr_srcptr src, mp_rnd_t rnd_mode)
-{
- double d;
- int negative;
- mp_exp_t e;
-
- if (MPFR_UNLIKELY (MPFR_IS_SINGULAR (src)))
- {
- if (MPFR_IS_NAN (src))
- return MPFR_DBL_NAN;
-
- negative = MPFR_IS_NEG (src);
-
- if (MPFR_IS_INF (src))
- return negative ? MPFR_DBL_INFM : MPFR_DBL_INFP;
-
- MPFR_ASSERTD (MPFR_IS_ZERO(src));
- return negative ? DBL_NEG_ZERO : 0.0;
- }
-
- e = MPFR_GET_EXP (src);
- negative = MPFR_IS_NEG (src);
-
- /* the smallest normalized number is 2^(-1022)=0.1e-1021, and the smallest
- subnormal is 2^(-1074)=0.1e-1073 */
- if (MPFR_UNLIKELY (e < -1073))
- {
- /* Note: Avoid using a constant expression DBL_MIN * DBL_EPSILON
- as this gives 0 instead of the correct result with gcc on some
- Alpha machines. */
- d = negative ?
- (rnd_mode == GMP_RNDD ||
- (rnd_mode == GMP_RNDN && mpfr_cmp_si_2exp(src, -1, -1075) < 0)
- ? -DBL_MIN : DBL_NEG_ZERO) :
- (rnd_mode == GMP_RNDU ||
- (rnd_mode == GMP_RNDN && mpfr_cmp_si_2exp(src, 1, -1075) > 0)
- ? DBL_MIN : 0.0);
- if (d != 0.0)
- d *= DBL_EPSILON;
- }
- /* the largest normalized number is 2^1024*(1-2^(-53))=0.111...111e1024 */
- else if (MPFR_UNLIKELY (e > 1024))
- {
- d = negative ?
- (rnd_mode == GMP_RNDZ || rnd_mode == GMP_RNDU ?
- -DBL_MAX : MPFR_DBL_INFM) :
- (rnd_mode == GMP_RNDZ || rnd_mode == GMP_RNDD ?
- DBL_MAX : MPFR_DBL_INFP);
- }
- else
- {
- int nbits;
- mp_size_t np, i;
- mp_limb_t tp[ MPFR_LIMBS_PER_DOUBLE ];
- int carry;
-
- nbits = IEEE_DBL_MANT_DIG; /* 53 */
- if (MPFR_UNLIKELY (e < -1021))
- /*In the subnormal case, compute the exact number of significant bits*/
- {
- nbits += (1021 + e);
- MPFR_ASSERTD (nbits >= 1);
- }
- np = (nbits + BITS_PER_MP_LIMB - 1) / BITS_PER_MP_LIMB;
- MPFR_ASSERTD ( np <= MPFR_LIMBS_PER_DOUBLE );
- carry = mpfr_round_raw_4 (tp, MPFR_MANT(src), MPFR_PREC(src), negative,
- nbits, rnd_mode);
- if (MPFR_UNLIKELY(carry))
- d = 1.0;
- else
- {
- /* The following computations are exact thanks to the previous
- mpfr_round_raw. */
- d = (double) tp[0] / MP_BASE_AS_DOUBLE;
- for (i = 1 ; i < np ; i++)
- d = (d + tp[i]) / MP_BASE_AS_DOUBLE;
- /* d is the mantissa (between 1/2 and 1) of the argument rounded
- to 53 bits */
- }
- d = mpfr_scale2 (d, e);
- if (negative)
- d = -d;
- }
-
- return d;
-}
-
-#undef mpfr_get_d1
-double
-mpfr_get_d1 (mpfr_srcptr src)
-{
- return mpfr_get_d (src, __gmpfr_default_rounding_mode);
-}
-
-double
-mpfr_get_d_2exp (long *expptr, mpfr_srcptr src, mp_rnd_t rnd_mode)
-{
- double ret;
- mp_exp_t exp;
- mpfr_t tmp;
-
- if (MPFR_UNLIKELY (MPFR_IS_SINGULAR (src)))
- {
- int negative;
- *expptr = 0;
- if (MPFR_IS_NAN (src))
- return MPFR_DBL_NAN;
- negative = MPFR_IS_NEG (src);
- if (MPFR_IS_INF (src))
- return negative ? MPFR_DBL_INFM : MPFR_DBL_INFP;
- MPFR_ASSERTD (MPFR_IS_ZERO(src));
- return negative ? DBL_NEG_ZERO : 0.0;
- }
-
- tmp[0] = *src; /* Hack copy mpfr_t */
- MPFR_SET_EXP (tmp, 0);
- ret = mpfr_get_d (tmp, rnd_mode);
-
- if (MPFR_IS_PURE_FP(src))
- {
- exp = MPFR_GET_EXP (src);
-
- /* rounding can give 1.0, adjust back to 0.5 <= abs(ret) < 1.0 */
- if (ret == 1.0)
- {
- ret = 0.5;
- exp++;
- }
- else if (ret == -1.0)
- {
- ret = -0.5;
- exp++;
- }
-
- MPFR_ASSERTN ((ret >= 0.5 && ret < 1.0)
- || (ret <= -0.5 && ret > -1.0));
- MPFR_ASSERTN (exp >= LONG_MIN && exp <= LONG_MAX);
- }
- else
- exp = 0;
-
- *expptr = exp;
- return ret;
-}
« no previous file with comments | « gcc/mpfr/gen_inverse.h ('k') | gcc/mpfr/get_d64.c » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698