diff options
Diffstat (limited to 'tools')
| -rw-r--r-- | tools/mpfr/Makefile | 6 | ||||
| -rw-r--r-- | tools/mpfr/patches/000-upstream_cumulative.patch | 1945 | ||||
| -rw-r--r-- | tools/mpfr/patches/001-no_tests.patch | 26 | ||||
| -rw-r--r-- | tools/mpfr/patches/001-only_src.patch | 22 | 
4 files changed, 25 insertions, 1974 deletions
| diff --git a/tools/mpfr/Makefile b/tools/mpfr/Makefile index 55c329ff8..e34830ad5 100644 --- a/tools/mpfr/Makefile +++ b/tools/mpfr/Makefile @@ -1,5 +1,5 @@  # -# Copyright (C) 2009 OpenWrt.org +# Copyright (C) 2009-2013 OpenWrt.org  #  # This is free software, licensed under the GNU General Public License v2.  # See /LICENSE for more information. @@ -7,11 +7,11 @@  include $(TOPDIR)/rules.mk  PKG_NAME:=mpfr -PKG_VERSION:=3.0.0 +PKG_VERSION:=3.1.1  PKG_SOURCE_URL:=http://www.mpfr.org/mpfr-$(PKG_VERSION)  PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2 -PKG_MD5SUM:=f45bac3584922c8004a10060ab1a8f9f +PKG_MD5SUM:=e90e0075bb1b5f626c6e31aaa9c64e3b  HOST_BUILD_PARALLEL:=1  HOST_FIXUP:=autoreconf diff --git a/tools/mpfr/patches/000-upstream_cumulative.patch b/tools/mpfr/patches/000-upstream_cumulative.patch deleted file mode 100644 index e21571b52..000000000 --- a/tools/mpfr/patches/000-upstream_cumulative.patch +++ /dev/null @@ -1,1945 +0,0 @@ -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES ---- mpfr-3.0.0-a/PATCHES	2010-06-23 11:02:49.000000000 +0000 -+++ mpfr-3.0.0-b/PATCHES	2010-06-23 11:03:36.000000000 +0000 -@@ -0,0 +1 @@ -+mpfr_out_str -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION ---- mpfr-3.0.0-a/VERSION	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/VERSION	2010-06-23 11:03:20.000000000 +0000 -@@ -1 +1 @@ --3.0.0 -+3.0.0-p1 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h ---- mpfr-3.0.0-a/mpfr.h	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.h	2010-06-23 11:03:20.000000000 +0000 -@@ -27,7 +27,7 @@ - #define MPFR_VERSION_MAJOR 3 - #define MPFR_VERSION_MINOR 0 - #define MPFR_VERSION_PATCHLEVEL 0 --#define MPFR_VERSION_STRING "3.0.0" -+#define MPFR_VERSION_STRING "3.0.0-p1" -  - /* Macros dealing with MPFR VERSION */ - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) -diff -Naurd mpfr-3.0.0-a/mpfr.texi mpfr-3.0.0-b/mpfr.texi ---- mpfr-3.0.0-a/mpfr.texi	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.texi	2010-06-23 11:03:12.000000000 +0000 -@@ -2050,7 +2050,7 @@ - are printed. If @var{base} is greater than 10, @samp{@@} will be used - instead of @samp{e} as exponent delimiter. -  --Return the number of bytes written, or if an error occurred, return 0. -+Return the number of characters written, or if an error occurred, return 0. - @end deftypefun -  - @deftypefun size_t mpfr_inp_str (mpfr_t @var{rop}, FILE *@var{stream}, int @var{base}, mpfr_rnd_t @var{rnd}) -diff -Naurd mpfr-3.0.0-a/out_str.c mpfr-3.0.0-b/out_str.c ---- mpfr-3.0.0-a/out_str.c	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/out_str.c	2010-06-23 11:03:12.000000000 +0000 -@@ -22,6 +22,16 @@ -  - #include "mpfr-impl.h" -  -+/* Warning! S should not contain "%". */ -+#define OUT_STR_RET(S)                          \ -+  do                                            \ -+    {                                           \ -+      int r;                                    \ -+      r = fprintf (stream, (S));                \ -+      return r < 0 ? 0 : r;                     \ -+    }                                           \ -+  while (0) -+ - size_t - mpfr_out_str (FILE *stream, int base, size_t n_digits, mpfr_srcptr op, -               mpfr_rnd_t rnd_mode) -@@ -29,6 +39,7 @@ -   char *s, *s0; -   size_t l; -   mpfr_exp_t e; -+  int err; -  -   MPFR_ASSERTN (base >= 2 && base <= 62); -  -@@ -36,37 +47,16 @@ -   if (stream == NULL) -     stream = stdout; -  --  if (MPFR_IS_NAN(op)) --    { --      fprintf (stream, "@NaN@"); --      return 3; --    } -- --  if (MPFR_IS_INF(op)) --    { --      if (MPFR_SIGN(op) > 0) --        { --          fprintf (stream, "@Inf@"); --          return 3; --        } --      else --        { --          fprintf (stream, "-@Inf@"); --          return 4; --        } --    } -- --  if (MPFR_IS_ZERO(op)) -+  if (MPFR_UNLIKELY (MPFR_IS_SINGULAR (op))) -     { --      if (MPFR_SIGN(op) > 0) --        { --          fprintf(stream, "0"); --          return 1; --        } -+      if (MPFR_IS_NAN (op)) -+        OUT_STR_RET ("@NaN@"); -+      else if (MPFR_IS_INF (op)) -+        OUT_STR_RET (MPFR_IS_POS (op) ? "@Inf@" : "-@Inf@"); -       else -         { --          fprintf(stream, "-0"); --          return 2; -+          MPFR_ASSERTD (MPFR_IS_ZERO (op)); -+          OUT_STR_RET (MPFR_IS_POS (op) ? "0" : "-0"); -         } -     } -  -@@ -77,21 +67,31 @@ -  -   l = strlen (s) + 1; /* size of allocated block returned by mpfr_get_str -                          - may be incorrect, as only an upper bound? */ --  if (*s == '-') --    fputc (*s++, stream); -  --  /* outputs mantissa */ --  fputc (*s++, stream); e--; /* leading digit */ --  fputc ((unsigned char) MPFR_DECIMAL_POINT, stream); --  fputs (s, stream);         /* rest of mantissa */ -+  /* outputs possible sign and significand */ -+  err = (*s == '-' && fputc (*s++, stream) == EOF) -+    || fputc (*s++, stream) == EOF  /* leading digit */ -+    || fputc ((unsigned char) MPFR_DECIMAL_POINT, stream) == EOF -+    || fputs (s, stream) == EOF;     /* trailing significand */ -   (*__gmp_free_func) (s0, l); -+  if (MPFR_UNLIKELY (err)) -+    return 0; -+ -+  e--;  /* due to the leading digit */ -  -   /* outputs exponent */ -   if (e) -     { -+      int r; -+ -       MPFR_ASSERTN(e >= LONG_MIN); -       MPFR_ASSERTN(e <= LONG_MAX); --      l += fprintf (stream, (base <= 10 ? "e%ld" : "@%ld"), (long) e); -+ -+      r = fprintf (stream, (base <= 10 ? "e%ld" : "@%ld"), (long) e); -+      if (MPFR_UNLIKELY (r < 0)) -+        return 0; -+ -+      l += r; -     } -  -   return l; -diff -Naurd mpfr-3.0.0-a/tests/tout_str.c mpfr-3.0.0-b/tests/tout_str.c ---- mpfr-3.0.0-a/tests/tout_str.c	2010-06-10 11:00:13.000000000 +0000 -+++ mpfr-3.0.0-b/tests/tout_str.c	2010-06-23 11:03:12.000000000 +0000 -@@ -46,22 +46,54 @@ - special (void) - { -   mpfr_t x; -+  unsigned int n; -  -   mpfr_init (x); -  -   mpfr_set_nan (x); --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  if (n != 5) -+    { -+      printf ("Error: mpfr_out_str (file, 10, 0, NaN, MPFR_RNDN) wrote %u " -+              "characters instead of 5.\n", n); -+      exit (1); -+    } -  -   mpfr_set_inf (x, 1); --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  if (n != 5) -+    { -+      printf ("Error: mpfr_out_str (file, 10, 0, +Inf, MPFR_RNDN) wrote %u " -+               "characters instead of 5.\n", n); -+      exit (1); -+    } -  -   mpfr_set_inf (x, -1); --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  if (n != 6) -+    { -+      printf ("Error: mpfr_out_str (file, 10, 0, -Inf, MPFR_RNDN) wrote %u " -+               "characters instead of 6.\n", n); -+      exit (1); -+    } -  -   mpfr_set_ui (x, 0, MPFR_RNDN); --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  if (n != 1) -+    { -+      printf ("Error: mpfr_out_str (file, 10, 0, +0, MPFR_RNDN) wrote %u " -+               "characters instead of 1.\n", n); -+      exit (1); -+    } -+ -   mpfr_neg (x, x, MPFR_RNDN); --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN); -+  if (n != 2) -+    { -+      printf ("Error: mpfr_out_str (file, 10, 0, -0, MPFR_RNDN) wrote %u " -+               "characters instead of 2.\n", n); -+      exit (1); -+    } -  -   mpfr_clear (x); - } -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c ---- mpfr-3.0.0-a/version.c	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/version.c	2010-06-23 11:03:20.000000000 +0000 -@@ -25,5 +25,5 @@ - const char * - mpfr_get_version (void) - { --  return "3.0.0"; -+  return "3.0.0-p1"; - } -diff -Naurd mpfr-3.0.0-a/Makefile.in mpfr-3.0.0-b/Makefile.in ---- mpfr-3.0.0-a/Makefile.in	2010-06-10 11:00:52.000000000 +0000 -+++ mpfr-3.0.0-b/Makefile.in	2010-06-10 11:00:52.000000000 +0000 -@@ -239,6 +239,7 @@ - distuninstallcheck_listfiles = find . -type f -print - distcleancheck_listfiles = find . -type f -print - ACLOCAL = @ACLOCAL@ -+ALLOCA = @ALLOCA@ - AMTAR = @AMTAR@ - AR = @AR@ - AS = @AS@ -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES ---- mpfr-3.0.0-a/PATCHES	2010-06-23 11:03:36.000000000 +0000 -+++ mpfr-3.0.0-b/PATCHES	2010-06-25 13:23:13.000000000 +0000 -@@ -0,0 +1 @@ -+alloca -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION ---- mpfr-3.0.0-a/VERSION	2010-06-23 11:03:20.000000000 +0000 -+++ mpfr-3.0.0-b/VERSION	2010-06-25 13:23:13.000000000 +0000 -@@ -1 +1 @@ --3.0.0-p1 -+3.0.0-p2 -diff -Naurd mpfr-3.0.0-a/acinclude.m4 mpfr-3.0.0-b/acinclude.m4 ---- mpfr-3.0.0-a/acinclude.m4	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/acinclude.m4	2010-06-10 11:00:14.000000000 +0000 -@@ -59,6 +59,9 @@ - dnl sys/fpu.h - MIPS specific - AC_CHECK_HEADERS([sys/time.h sys/fpu.h]) -  -+dnl Check how to get `alloca' -+AC_FUNC_ALLOCA -+ - dnl SIZE_MAX macro - gl_SIZE_MAX -  -diff -Naurd mpfr-3.0.0-a/configure mpfr-3.0.0-b/configure ---- mpfr-3.0.0-a/configure	2010-06-10 11:00:51.000000000 +0000 -+++ mpfr-3.0.0-b/configure	2010-06-25 13:23:05.000000000 +0000 -@@ -783,6 +783,7 @@ - OBJDUMP - DLLTOOL - AS -+ALLOCA - MPFR_LIBM - ANSI2KNR - U -@@ -5622,6 +5623,197 @@ - done -  -  -+# The Ultrix 4.2 mips builtin alloca declared by alloca.h only works -+# for constant arguments.  Useless! -+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for working alloca.h" >&5 -+$as_echo_n "checking for working alloca.h... " >&6; } -+if test "${ac_cv_working_alloca_h+set}" = set; then : -+  $as_echo_n "(cached) " >&6 -+else -+  cat confdefs.h - <<_ACEOF >conftest.$ac_ext -+/* end confdefs.h.  */ -+#include <alloca.h> -+int -+main () -+{ -+char *p = (char *) alloca (2 * sizeof (int)); -+			  if (p) return 0; -+  ; -+  return 0; -+} -+_ACEOF -+if ac_fn_c_try_link "$LINENO"; then : -+  ac_cv_working_alloca_h=yes -+else -+  ac_cv_working_alloca_h=no -+fi -+rm -f core conftest.err conftest.$ac_objext \ -+    conftest$ac_exeext conftest.$ac_ext -+fi -+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_working_alloca_h" >&5 -+$as_echo "$ac_cv_working_alloca_h" >&6; } -+if test $ac_cv_working_alloca_h = yes; then -+ -+$as_echo "#define HAVE_ALLOCA_H 1" >>confdefs.h -+ -+fi -+ -+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for alloca" >&5 -+$as_echo_n "checking for alloca... " >&6; } -+if test "${ac_cv_func_alloca_works+set}" = set; then : -+  $as_echo_n "(cached) " >&6 -+else -+  cat confdefs.h - <<_ACEOF >conftest.$ac_ext -+/* end confdefs.h.  */ -+#ifdef __GNUC__ -+# define alloca __builtin_alloca -+#else -+# ifdef _MSC_VER -+#  include <malloc.h> -+#  define alloca _alloca -+# else -+#  ifdef HAVE_ALLOCA_H -+#   include <alloca.h> -+#  else -+#   ifdef _AIX -+ #pragma alloca -+#   else -+#    ifndef alloca /* predefined by HP cc +Olibcalls */ -+char *alloca (); -+#    endif -+#   endif -+#  endif -+# endif -+#endif -+ -+int -+main () -+{ -+char *p = (char *) alloca (1); -+				    if (p) return 0; -+  ; -+  return 0; -+} -+_ACEOF -+if ac_fn_c_try_link "$LINENO"; then : -+  ac_cv_func_alloca_works=yes -+else -+  ac_cv_func_alloca_works=no -+fi -+rm -f core conftest.err conftest.$ac_objext \ -+    conftest$ac_exeext conftest.$ac_ext -+fi -+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_func_alloca_works" >&5 -+$as_echo "$ac_cv_func_alloca_works" >&6; } -+ -+if test $ac_cv_func_alloca_works = yes; then -+ -+$as_echo "#define HAVE_ALLOCA 1" >>confdefs.h -+ -+else -+  # The SVR3 libPW and SVR4 libucb both contain incompatible functions -+# that cause trouble.  Some versions do not even contain alloca or -+# contain a buggy version.  If you still want to use their alloca, -+# use ar to extract alloca.o from them instead of compiling alloca.c. -+ -+ALLOCA=\${LIBOBJDIR}alloca.$ac_objext -+ -+$as_echo "#define C_ALLOCA 1" >>confdefs.h -+ -+ -+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether \`alloca.c' needs Cray hooks" >&5 -+$as_echo_n "checking whether \`alloca.c' needs Cray hooks... " >&6; } -+if test "${ac_cv_os_cray+set}" = set; then : -+  $as_echo_n "(cached) " >&6 -+else -+  cat confdefs.h - <<_ACEOF >conftest.$ac_ext -+/* end confdefs.h.  */ -+#if defined CRAY && ! defined CRAY2 -+webecray -+#else -+wenotbecray -+#endif -+ -+_ACEOF -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | -+  $EGREP "webecray" >/dev/null 2>&1; then : -+  ac_cv_os_cray=yes -+else -+  ac_cv_os_cray=no -+fi -+rm -f conftest* -+ -+fi -+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_os_cray" >&5 -+$as_echo "$ac_cv_os_cray" >&6; } -+if test $ac_cv_os_cray = yes; then -+  for ac_func in _getb67 GETB67 getb67; do -+    as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh` -+ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var" -+eval as_val=\$$as_ac_var -+   if test "x$as_val" = x""yes; then : -+ -+cat >>confdefs.h <<_ACEOF -+#define CRAY_STACKSEG_END $ac_func -+_ACEOF -+ -+    break -+fi -+ -+  done -+fi -+ -+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking stack direction for C alloca" >&5 -+$as_echo_n "checking stack direction for C alloca... " >&6; } -+if test "${ac_cv_c_stack_direction+set}" = set; then : -+  $as_echo_n "(cached) " >&6 -+else -+  if test "$cross_compiling" = yes; then : -+  ac_cv_c_stack_direction=0 -+else -+  cat confdefs.h - <<_ACEOF >conftest.$ac_ext -+/* end confdefs.h.  */ -+$ac_includes_default -+int -+find_stack_direction () -+{ -+  static char *addr = 0; -+  auto char dummy; -+  if (addr == 0) -+    { -+      addr = &dummy; -+      return find_stack_direction (); -+    } -+  else -+    return (&dummy > addr) ? 1 : -1; -+} -+ -+int -+main () -+{ -+  return find_stack_direction () < 0; -+} -+_ACEOF -+if ac_fn_c_try_run "$LINENO"; then : -+  ac_cv_c_stack_direction=1 -+else -+  ac_cv_c_stack_direction=-1 -+fi -+rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ -+  conftest.$ac_objext conftest.beam conftest.$ac_ext -+fi -+ -+fi -+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_stack_direction" >&5 -+$as_echo "$ac_cv_c_stack_direction" >&6; } -+cat >>confdefs.h <<_ACEOF -+#define STACK_DIRECTION $ac_cv_c_stack_direction -+_ACEOF -+ -+ -+fi -+ -+ -  -   for ac_header in stdint.h - do : -@@ -7564,13 +7756,13 @@ - else -   lt_cv_nm_interface="BSD nm" -   echo "int some_variable = 0;" > conftest.$ac_ext --  (eval echo "\"\$as_me:7567: $ac_compile\"" >&5) -+  (eval echo "\"\$as_me:7759: $ac_compile\"" >&5) -   (eval "$ac_compile" 2>conftest.err) -   cat conftest.err >&5 --  (eval echo "\"\$as_me:7570: $NM \\\"conftest.$ac_objext\\\"\"" >&5) -+  (eval echo "\"\$as_me:7762: $NM \\\"conftest.$ac_objext\\\"\"" >&5) -   (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) -   cat conftest.err >&5 --  (eval echo "\"\$as_me:7573: output\"" >&5) -+  (eval echo "\"\$as_me:7765: output\"" >&5) -   cat conftest.out >&5 -   if $GREP 'External.*some_variable' conftest.out > /dev/null; then -     lt_cv_nm_interface="MS dumpbin" -@@ -8772,7 +8964,7 @@ -   ;; - *-*-irix6*) -   # Find out which ABI we are using. --  echo '#line 8775 "configure"' > conftest.$ac_ext -+  echo '#line 8967 "configure"' > conftest.$ac_ext -   if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 -   (eval $ac_compile) 2>&5 -   ac_status=$? -@@ -10032,11 +10224,11 @@ -    -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -    -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -    -e 's:$: $lt_compiler_flag:'` --   (eval echo "\"\$as_me:10035: $lt_compile\"" >&5) -+   (eval echo "\"\$as_me:10227: $lt_compile\"" >&5) -    (eval "$lt_compile" 2>conftest.err) -    ac_status=$? -    cat conftest.err >&5 --   echo "$as_me:10039: \$? = $ac_status" >&5 -+   echo "$as_me:10231: \$? = $ac_status" >&5 -    if (exit $ac_status) && test -s "$ac_outfile"; then -      # The compiler can only warn and ignore the option if not recognized -      # So say no if there are warnings other than the usual output. -@@ -10371,11 +10563,11 @@ -    -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -    -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -    -e 's:$: $lt_compiler_flag:'` --   (eval echo "\"\$as_me:10374: $lt_compile\"" >&5) -+   (eval echo "\"\$as_me:10566: $lt_compile\"" >&5) -    (eval "$lt_compile" 2>conftest.err) -    ac_status=$? -    cat conftest.err >&5 --   echo "$as_me:10378: \$? = $ac_status" >&5 -+   echo "$as_me:10570: \$? = $ac_status" >&5 -    if (exit $ac_status) && test -s "$ac_outfile"; then -      # The compiler can only warn and ignore the option if not recognized -      # So say no if there are warnings other than the usual output. -@@ -10476,11 +10668,11 @@ -    -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -    -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -    -e 's:$: $lt_compiler_flag:'` --   (eval echo "\"\$as_me:10479: $lt_compile\"" >&5) -+   (eval echo "\"\$as_me:10671: $lt_compile\"" >&5) -    (eval "$lt_compile" 2>out/conftest.err) -    ac_status=$? -    cat out/conftest.err >&5 --   echo "$as_me:10483: \$? = $ac_status" >&5 -+   echo "$as_me:10675: \$? = $ac_status" >&5 -    if (exit $ac_status) && test -s out/conftest2.$ac_objext -    then -      # The compiler can only warn and ignore the option if not recognized -@@ -10531,11 +10723,11 @@ -    -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -    -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -    -e 's:$: $lt_compiler_flag:'` --   (eval echo "\"\$as_me:10534: $lt_compile\"" >&5) -+   (eval echo "\"\$as_me:10726: $lt_compile\"" >&5) -    (eval "$lt_compile" 2>out/conftest.err) -    ac_status=$? -    cat out/conftest.err >&5 --   echo "$as_me:10538: \$? = $ac_status" >&5 -+   echo "$as_me:10730: \$? = $ac_status" >&5 -    if (exit $ac_status) && test -s out/conftest2.$ac_objext -    then -      # The compiler can only warn and ignore the option if not recognized -@@ -12915,7 +13107,7 @@ -   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 -   lt_status=$lt_dlunknown -   cat > conftest.$ac_ext <<_LT_EOF --#line 12918 "configure" -+#line 13110 "configure" - #include "confdefs.h" -  - #if HAVE_DLFCN_H -@@ -13011,7 +13203,7 @@ -   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 -   lt_status=$lt_dlunknown -   cat > conftest.$ac_ext <<_LT_EOF --#line 13014 "configure" -+#line 13206 "configure" - #include "confdefs.h" -  - #if HAVE_DLFCN_H -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h ---- mpfr-3.0.0-a/mpfr.h	2010-06-23 11:03:20.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.h	2010-06-25 13:23:13.000000000 +0000 -@@ -27,7 +27,7 @@ - #define MPFR_VERSION_MAJOR 3 - #define MPFR_VERSION_MINOR 0 - #define MPFR_VERSION_PATCHLEVEL 0 --#define MPFR_VERSION_STRING "3.0.0-p1" -+#define MPFR_VERSION_STRING "3.0.0-p2" -  - /* Macros dealing with MPFR VERSION */ - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) -diff -Naurd mpfr-3.0.0-a/tests/Makefile.in mpfr-3.0.0-b/tests/Makefile.in ---- mpfr-3.0.0-a/tests/Makefile.in	2010-06-10 11:00:52.000000000 +0000 -+++ mpfr-3.0.0-b/tests/Makefile.in	2010-06-10 11:00:52.000000000 +0000 -@@ -960,6 +960,7 @@ - red=; grn=; lgn=; blu=; std= - DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) - ACLOCAL = @ACLOCAL@ -+ALLOCA = @ALLOCA@ - AMTAR = @AMTAR@ - AR = @AR@ - AS = @AS@ -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c ---- mpfr-3.0.0-a/version.c	2010-06-23 11:03:20.000000000 +0000 -+++ mpfr-3.0.0-b/version.c	2010-06-25 13:23:13.000000000 +0000 -@@ -25,5 +25,5 @@ - const char * - mpfr_get_version (void) - { --  return "3.0.0-p1"; -+  return "3.0.0-p2"; - } -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES ---- mpfr-3.0.0-a/PATCHES	2010-07-10 00:11:19.000000000 +0000 -+++ mpfr-3.0.0-b/PATCHES	2010-07-10 00:12:50.000000000 +0000 -@@ -0,0 +1 @@ -+gamma_underflow -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION ---- mpfr-3.0.0-a/VERSION	2010-06-25 13:23:13.000000000 +0000 -+++ mpfr-3.0.0-b/VERSION	2010-07-10 00:11:53.000000000 +0000 -@@ -1 +1 @@ --3.0.0-p2 -+3.0.0-p3 -diff -Naurd mpfr-3.0.0-a/gamma.c mpfr-3.0.0-b/gamma.c ---- mpfr-3.0.0-a/gamma.c	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/gamma.c	2010-07-10 00:11:46.000000000 +0000 -@@ -274,7 +274,7 @@ -       /* we want an upper bound for x * [log(2-x)-1]. -          since x < 0, we need a lower bound on log(2-x) */ -       mpfr_ui_sub (xp, 2, x, MPFR_RNDD); --      mpfr_log (xp, xp, MPFR_RNDD); -+      mpfr_log2 (xp, xp, MPFR_RNDD); -       mpfr_sub_ui (xp, xp, 1, MPFR_RNDD); -       mpfr_mul (xp, xp, x, MPFR_RNDU); -  -@@ -303,8 +303,8 @@ -         { -           mpfr_sub (tmp, tmp, tmp2, MPFR_RNDZ); /* low bnd on |sin(Pi*(2-x))| */ -           mpfr_ui_div (tmp, 12, tmp, MPFR_RNDU); /* upper bound */ --          mpfr_log (tmp, tmp, MPFR_RNDU); --          mpfr_add (tmp, tmp, xp, MPFR_RNDU); -+          mpfr_log2 (tmp, tmp, MPFR_RNDU); -+          mpfr_add (xp, tmp, xp, MPFR_RNDU); -           underflow = mpfr_cmp_si (xp, expo.saved_emin - 2) <= 0; -         } -  -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h ---- mpfr-3.0.0-a/mpfr.h	2010-06-25 13:23:13.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.h	2010-07-10 00:11:53.000000000 +0000 -@@ -27,7 +27,7 @@ - #define MPFR_VERSION_MAJOR 3 - #define MPFR_VERSION_MINOR 0 - #define MPFR_VERSION_PATCHLEVEL 0 --#define MPFR_VERSION_STRING "3.0.0-p2" -+#define MPFR_VERSION_STRING "3.0.0-p3" -  - /* Macros dealing with MPFR VERSION */ - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) -diff -Naurd mpfr-3.0.0-a/tests/tgamma.c mpfr-3.0.0-b/tests/tgamma.c ---- mpfr-3.0.0-a/tests/tgamma.c	2010-06-10 11:00:13.000000000 +0000 -+++ mpfr-3.0.0-b/tests/tgamma.c	2010-07-10 00:11:46.000000000 +0000 -@@ -461,6 +461,20 @@ -   mpfr_clear (x); - } -  -+/* bug found by Stathis, only occurs on 32-bit machines */ -+static void -+test20100709 (void) -+{ -+  mpfr_t x; -+  int inex; -+ -+  mpfr_init2 (x, 100); -+  mpfr_set_str (x, "-4.6308260837372266e+07", 10, MPFR_RNDN); -+  inex = mpfr_gamma (x, x, MPFR_RNDN); -+  MPFR_ASSERTN(MPFR_IS_ZERO(x) && MPFR_IS_NEG(x) && inex > 0); -+  mpfr_clear (x); -+} -+ - int - main (int argc, char *argv[]) - { -@@ -471,6 +485,7 @@ -   test_generic (2, 100, 2); -   gamma_integer (); -   test20071231 (); -+  test20100709 (); -  -   data_check ("data/gamma", mpfr_gamma, "mpfr_gamma"); -  -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c ---- mpfr-3.0.0-a/version.c	2010-06-25 13:23:13.000000000 +0000 -+++ mpfr-3.0.0-b/version.c	2010-07-10 00:11:53.000000000 +0000 -@@ -25,5 +25,5 @@ - const char * - mpfr_get_version (void) - { --  return "3.0.0-p2"; -+  return "3.0.0-p3"; - } -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES ---- mpfr-3.0.0-a/PATCHES	2010-09-07 08:44:01.000000000 +0000 -+++ mpfr-3.0.0-b/PATCHES	2010-09-07 08:48:46.000000000 +0000 -@@ -0,0 +1 @@ -+mpfr_cmp/set_ui/si -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION ---- mpfr-3.0.0-a/VERSION	2010-07-10 00:11:53.000000000 +0000 -+++ mpfr-3.0.0-b/VERSION	2010-09-07 08:46:06.000000000 +0000 -@@ -1 +1 @@ --3.0.0-p3 -+3.0.0-p4 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h ---- mpfr-3.0.0-a/mpfr.h	2010-07-10 00:11:53.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.h	2010-09-07 08:46:06.000000000 +0000 -@@ -27,7 +27,7 @@ - #define MPFR_VERSION_MAJOR 3 - #define MPFR_VERSION_MINOR 0 - #define MPFR_VERSION_PATCHLEVEL 0 --#define MPFR_VERSION_STRING "3.0.0-p3" -+#define MPFR_VERSION_STRING "3.0.0-p4" -  - /* Macros dealing with MPFR VERSION */ - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) -@@ -798,35 +798,45 @@ -      anyway. Checking with other ICC versions is needed. Possibly detect -      whether warnings are produced or not with a configure test. -    + Remove C++ too, since it complains too much. */ -+/* Added casts to improve robustness in case of undefined behavior and -+   compiler extensions based on UB (in particular -fwrapv). MPFR doesn't -+   use such extensions, but these macros will be used by 3rd-party code, -+   where such extensions may be required. -+   Moreover casts to unsigned long have been added to avoid warnings in -+   programs that use MPFR and are compiled with -Wconversion; such casts -+   are OK since if X is a constant expression, then (unsigned long) X is -+   also a constant expression, so that the optimizations still work. */ - #if defined (__GNUC__) && !defined(__ICC) && !defined(__cplusplus) - #if (__GNUC__ >= 2) - #undef mpfr_cmp_ui --/* We use the fact that mpfr_sgn on NaN sets the erange flag and returns 0. */ --#define mpfr_cmp_ui(_f,_u)                 \ -- (__builtin_constant_p (_u) && (_u) == 0 ? \ --   mpfr_sgn (_f) :                         \ --   mpfr_cmp_ui_2exp ((_f),(_u),0)) -+/* We use the fact that mpfr_sgn on NaN sets the erange flag and returns 0. -+   But warning! mpfr_sgn is specified as a macro in the API, thus the macro -+   mustn't be used if side effects are possible, like here. */ -+#define mpfr_cmp_ui(_f,_u)                                      \ -+  (__builtin_constant_p (_u) && (unsigned long) (_u) == 0 ?     \ -+   (mpfr_sgn) (_f) :                                            \ -+   mpfr_cmp_ui_2exp ((_f), (unsigned long) (_u), 0)) - #undef mpfr_cmp_si --#define mpfr_cmp_si(_f,_s)                 \ -- (__builtin_constant_p (_s) && (_s) >= 0 ? \ --   mpfr_cmp_ui ((_f), (_s)) :              \ --   mpfr_cmp_si_2exp ((_f), (_s), 0)) -+#define mpfr_cmp_si(_f,_s)                              \ -+  (__builtin_constant_p (_s) && (long) (_s) >= 0 ?      \ -+   mpfr_cmp_ui ((_f), (unsigned long) (long) (_s)) :    \ -+   mpfr_cmp_si_2exp ((_f), (long) (_s), 0)) - #if __GNUC__ > 2 || __GNUC_MINOR__ >= 95 - #undef mpfr_set_ui --#define mpfr_set_ui(_f,_u,_r)              \ -- (__builtin_constant_p (_u) && (_u) == 0 ? \ --   __extension__ ({                        \ --     mpfr_ptr _p = (_f);                   \ --     _p->_mpfr_sign = 1;                   \ --     _p->_mpfr_exp = __MPFR_EXP_ZERO;      \ --     (void) (_r); 0; }) :                  \ --   mpfr_set_ui_2exp ((_f), (_u), 0, (_r))) -+#define mpfr_set_ui(_f,_u,_r)                                   \ -+  (__builtin_constant_p (_u) && (unsigned long) (_u) == 0 ?     \ -+   __extension__ ({                                             \ -+       mpfr_ptr _p = (_f);                                      \ -+       _p->_mpfr_sign = 1;                                      \ -+       _p->_mpfr_exp = __MPFR_EXP_ZERO;                         \ -+       (void) (_r); 0; }) :                                     \ -+   mpfr_set_ui_2exp ((_f), (unsigned long) (_u), 0, (_r))) - #endif - #undef mpfr_set_si --#define mpfr_set_si(_f,_s,_r)              \ -- (__builtin_constant_p (_s) && (_s) >= 0 ? \ --   mpfr_set_ui ((_f), (_s), (_r)) :        \ --   mpfr_set_si_2exp ((_f), (_s), 0, (_r))) -+#define mpfr_set_si(_f,_s,_r)                                   \ -+  (__builtin_constant_p (_s) && (long) (_s) >= 0 ?              \ -+   mpfr_set_ui ((_f), (unsigned long) (long) (_s), (_r)) :      \ -+   mpfr_set_si_2exp ((_f), (long) (_s), 0, (_r))) - #endif - #endif -  -diff -Naurd mpfr-3.0.0-a/tests/tcmp_ui.c mpfr-3.0.0-b/tests/tcmp_ui.c ---- mpfr-3.0.0-a/tests/tcmp_ui.c	2010-06-10 11:00:13.000000000 +0000 -+++ mpfr-3.0.0-b/tests/tcmp_ui.c	2010-09-07 08:45:12.000000000 +0000 -@@ -88,6 +88,126 @@ -   mpfr_clear (x); - } -  -+/* Since mpfr_cmp_ui and mpfr_cmp_si are also implemented by a macro -+   with __builtin_constant_p for GCC, check that side effects are -+   handled correctly. */ -+static void -+check_macros (void) -+{ -+  mpfr_t x; -+  int c; -+ -+  mpfr_init2 (x, 32); -+ -+  c = 0; -+  mpfr_set_ui (x, 17, MPFR_RNDN); -+  if (mpfr_cmp_ui (x, 17) != 0) -+    { -+      printf ("Error 1 on mpfr_cmp_ui(x,17) in check_macros\n"); -+      exit (1); -+    } -+  if (mpfr_cmp_ui (x, (c++, 17)) != 0) -+    { -+      printf ("Error 2 on mpfr_cmp_ui(x,17) in check_macros\n"); -+      exit (1); -+    } -+  if (c != 1) -+    { -+      printf ("Error 3 on mpfr_cmp_ui(x,17) in check_macros\n" -+              "(c = %d instead of 1)\n", c); -+      exit (1); -+    } -+  if (mpfr_cmp_si (x, 17) != 0) -+    { -+      printf ("Error 1 on mpfr_cmp_si(x,17) in check_macros\n"); -+      exit (1); -+    } -+  if (mpfr_cmp_si (x, (c++, 17)) != 0) -+    { -+      printf ("Error 2 on mpfr_cmp_si(x,17) in check_macros\n"); -+      exit (1); -+    } -+  if (c != 2) -+    { -+      printf ("Error 3 on mpfr_cmp_si(x,17) in check_macros\n" -+              "(c = %d instead of 2)\n", c); -+      exit (1); -+    } -+ -+  c = 0; -+  mpfr_set_ui (x, 0, MPFR_RNDN); -+  if (mpfr_cmp_ui (x, 0) != 0) -+    { -+      printf ("Error 1 on mpfr_cmp_ui(x,0) in check_macros\n"); -+      exit (1); -+    } -+  if (mpfr_cmp_ui (x, (c++, 0)) != 0) -+    { -+      printf ("Error 2 on mpfr_cmp_ui(x,0) in check_macros\n"); -+      exit (1); -+    } -+  if (c != 1) -+    { -+      printf ("Error 3 on mpfr_cmp_ui(x,0) in check_macros\n" -+              "(c = %d instead of 1)\n", c); -+      exit (1); -+    } -+  if (mpfr_cmp_si (x, 0) != 0) -+    { -+      printf ("Error 1 on mpfr_cmp_si(x,0) in check_macros\n"); -+      exit (1); -+    } -+  if (mpfr_cmp_si (x, (c++, 0)) != 0) -+    { -+      printf ("Error 2 on mpfr_cmp_si(x,0) in check_macros\n"); -+      exit (1); -+    } -+  if (c != 2) -+    { -+      printf ("Error 3 on mpfr_cmp_si(x,0) in check_macros\n" -+              "(c = %d instead of 2)\n", c); -+      exit (1); -+    } -+ -+  mpfr_clear (x); -+} -+ -+/* Bug in r7114 */ -+static void -+test_macros (void) -+{ -+  mpfr_t x[3]; -+  mpfr_ptr p; -+ -+  mpfr_inits (x[0], x[1], x[2], (mpfr_ptr) 0); -+  mpfr_set_ui (x[0], 0, MPFR_RNDN); -+  p = x[0]; -+  if (mpfr_cmp_ui (p++, 0) != 0) -+    { -+      printf ("Error in mpfr_cmp_ui macro: result should be 0.\n"); -+      exit (1); -+    } -+  if (p != x[1]) -+    { -+      printf ("Error in mpfr_cmp_ui macro: p - x[0] = %d (expecting 1)\n", -+              (int) (p - x[0])); -+      exit (1); -+    } -+  p = x[0]; -+  if (mpfr_cmp_si (p++, 0) != 0) -+    { -+      printf ("Error in mpfr_cmp_si macro: result should be 0.\n"); -+      exit (1); -+    } -+  if (p != x[1]) -+    { -+      printf ("Error in mpfr_cmp_si macro: p - x[0] = %d (expecting 1)\n", -+              (int) (p - x[0])); -+      exit (1); -+    } -+  mpfr_clears (x[0], x[1], x[2], (mpfr_ptr) 0); -+} -+ - int - main (void) - { -@@ -216,6 +336,8 @@ -   mpfr_clear (x); -  -   check_nan (); -+  check_macros (); -+  test_macros (); -  -   tests_end_mpfr (); -   return 0; -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c ---- mpfr-3.0.0-a/version.c	2010-07-10 00:11:53.000000000 +0000 -+++ mpfr-3.0.0-b/version.c	2010-09-07 08:46:06.000000000 +0000 -@@ -25,5 +25,5 @@ - const char * - mpfr_get_version (void) - { --  return "3.0.0-p3"; -+  return "3.0.0-p4"; - } -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES ---- mpfr-3.0.0-a/PATCHES	2010-10-21 20:28:38.000000000 +0000 -+++ mpfr-3.0.0-b/PATCHES	2010-10-21 20:28:38.000000000 +0000 -@@ -0,0 +1 @@ -+tcan_round -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION ---- mpfr-3.0.0-a/VERSION	2010-09-07 08:46:06.000000000 +0000 -+++ mpfr-3.0.0-b/VERSION	2010-10-21 20:28:38.000000000 +0000 -@@ -1 +1 @@ --3.0.0-p4 -+3.0.0-p5 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h ---- mpfr-3.0.0-a/mpfr.h	2010-09-07 08:46:06.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.h	2010-10-21 20:28:38.000000000 +0000 -@@ -27,7 +27,7 @@ - #define MPFR_VERSION_MAJOR 3 - #define MPFR_VERSION_MINOR 0 - #define MPFR_VERSION_PATCHLEVEL 0 --#define MPFR_VERSION_STRING "3.0.0-p4" -+#define MPFR_VERSION_STRING "3.0.0-p5" -  - /* Macros dealing with MPFR VERSION */ - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) -diff -Naurd mpfr-3.0.0-a/tests/tcan_round.c mpfr-3.0.0-b/tests/tcan_round.c ---- mpfr-3.0.0-a/tests/tcan_round.c	2010-06-10 11:00:13.000000000 +0000 -+++ mpfr-3.0.0-b/tests/tcan_round.c	2010-10-21 20:28:38.000000000 +0000 -@@ -41,7 +41,7 @@ -       /* avoid mpn_random which leaks memory */ -       for (i = 0; i < n; i++) -         buf[i] = randlimb (); --      p = (mpfr_prec_t) randlimb() % ((n-1) * GMP_NUMB_BITS) + MPFR_PREC_MIN; -+      p = randlimb() % ((n-1) * GMP_NUMB_BITS) + MPFR_PREC_MIN; -       err = p + randlimb () % GMP_NUMB_BITS; -       r1 = mpfr_round_p (buf, n, err, p); -       r2 = mpfr_can_round_raw (buf, n, MPFR_SIGN_POS, err, -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c ---- mpfr-3.0.0-a/version.c	2010-09-07 08:46:06.000000000 +0000 -+++ mpfr-3.0.0-b/version.c	2010-10-21 20:28:38.000000000 +0000 -@@ -25,5 +25,5 @@ - const char * - mpfr_get_version (void) - { --  return "3.0.0-p4"; -+  return "3.0.0-p5"; - } -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES ---- mpfr-3.0.0-a/PATCHES	2010-10-21 20:59:32.000000000 +0000 -+++ mpfr-3.0.0-b/PATCHES	2010-10-21 20:59:32.000000000 +0000 -@@ -0,0 +1 @@ -+mpfr_sub1 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION ---- mpfr-3.0.0-a/VERSION	2010-10-21 20:28:38.000000000 +0000 -+++ mpfr-3.0.0-b/VERSION	2010-10-21 20:59:32.000000000 +0000 -@@ -1 +1 @@ --3.0.0-p5 -+3.0.0-p6 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h ---- mpfr-3.0.0-a/mpfr.h	2010-10-21 20:28:38.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.h	2010-10-21 20:59:32.000000000 +0000 -@@ -27,7 +27,7 @@ - #define MPFR_VERSION_MAJOR 3 - #define MPFR_VERSION_MINOR 0 - #define MPFR_VERSION_PATCHLEVEL 0 --#define MPFR_VERSION_STRING "3.0.0-p5" -+#define MPFR_VERSION_STRING "3.0.0-p6" -  - /* Macros dealing with MPFR VERSION */ - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) -diff -Naurd mpfr-3.0.0-a/sub1.c mpfr-3.0.0-b/sub1.c ---- mpfr-3.0.0-a/sub1.c	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/sub1.c	2010-10-21 20:59:32.000000000 +0000 -@@ -37,7 +37,9 @@ -   mp_size_t cancel2, an, bn, cn, cn0; -   mp_limb_t *ap, *bp, *cp; -   mp_limb_t carry, bb, cc, borrow = 0; --  int inexact, shift_b, shift_c, is_exact = 1, down = 0, add_exp = 0; -+  int inexact, shift_b, shift_c, add_exp = 0; -+  int cmp_low = 0; /* used for rounding to nearest: 0 if low(b) = low(c), -+                      negative if low(b) < low(c), positive if low(b)>low(c) */ -   int sh, k; -   MPFR_TMP_DECL(marker); -  -@@ -196,7 +198,8 @@ -     } -  - #ifdef DEBUG --  printf ("shift_b=%d shift_c=%d diffexp=%lu\n", shift_b, shift_c, -+  printf ("rnd=%s shift_b=%d shift_c=%d diffexp=%lu\n", -+          mpfr_print_rnd_mode (rnd_mode), shift_b, shift_c, -           (unsigned long) diff_exp); - #endif -  -@@ -307,17 +310,18 @@ -     { -       if (MPFR_LIKELY(sh)) -         { --          is_exact = (carry == 0); -           /* can decide except when carry = 2^(sh-1) [middle] -              or carry = 0 [truncate, but cannot decide inexact flag] */ --          down = (carry < (MPFR_LIMB_ONE << (sh - 1))); -           if (carry > (MPFR_LIMB_ONE << (sh - 1))) -             goto add_one_ulp; --          else if ((0 < carry) && down) -+          else if ((0 < carry) && (carry < (MPFR_LIMB_ONE << (sh - 1)))) -             { -               inexact = -1; /* result if smaller than exact value */ -               goto truncate; -             } -+          /* now carry = 2^(sh-1), in which case cmp_low=2, -+             or carry = 0, in which case cmp_low=0 */ -+          cmp_low = (carry == 0) ? 0 : 2; -         } -     } -   else /* directed rounding: set rnd_mode to RNDZ iff toward zero */ -@@ -344,12 +348,32 @@ -   cn -= (long int) an + cancel2; -  - #ifdef DEBUG --  printf ("last %d bits from a are %lu, bn=%ld, cn=%ld\n", -+  printf ("last sh=%d bits from a are %lu, bn=%ld, cn=%ld\n", -           sh, (unsigned long) carry, (long) bn, (long) cn); - #endif -  -+  /* for rounding to nearest, we couldn't conclude up to here in the following -+     cases: -+     1. sh = 0, then cmp_low=0: we can either truncate, subtract one ulp -+        or add one ulp: -1 ulp < low(b)-low(c) < 1 ulp -+     2. sh > 0 but the low sh bits from high(b)-high(c) equal 2^(sh-1): -+        -0.5 ulp <= -1/2^sh < low(b)-low(c)-0.5 < 1/2^sh <= 0.5 ulp -+        we can't decide the rounding, in that case cmp_low=2: -+        either we truncate and flag=-1, or we add one ulp and flag=1 -+     3. the low sh>0 bits from high(b)-high(c) equal 0: we know we have to -+        truncate but we can't decide the ternary value, here cmp_low=0: -+        -0.5 ulp <= -1/2^sh < low(b)-low(c) < 1/2^sh <= 0.5 ulp -+        we always truncate and inexact can be any of -1,0,1 -+  */ -+ -+  /* note: here cn might exceed cn0, in which case we consider a zero limb */ -   for (k = 0; (bn > 0) || (cn > 0); k = 1) -     { -+      /* if cmp_low < 0, we know low(b) - low(c) < 0 -+         if cmp_low > 0, we know low(b) - low(c) > 0 -+            (more precisely if cmp_low = 2, low(b) - low(c) = 0.5 ulp so far) -+         if cmp_low = 0, so far low(b) - low(c) = 0 */ -+ -       /* get next limbs */ -       bb = (bn > 0) ? bp[--bn] : 0; -       if ((cn > 0) && (cn-- <= cn0)) -@@ -357,76 +381,115 @@ -       else -         cc = 0; -  --      /* down is set when low(b) < low(c) */ --      if (down == 0) --        down = (bb < cc); -+      /* cmp_low compares low(b) and low(c) */ -+      if (cmp_low == 0) /* case 1 or 3 */ -+        cmp_low = (bb < cc) ? -2+k : (bb > cc) ? 1 : 0; -+ -+      /* Case 1 for k=0 splits into 7 subcases: -+         1a: bb > cc + half -+         1b: bb = cc + half -+         1c: 0 < bb - cc < half -+         1d: bb = cc -+         1e: -half < bb - cc < 0 -+         1f: bb - cc = -half -+         1g: bb - cc < -half -+ -+         Case 2 splits into 3 subcases: -+         2a: bb > cc -+         2b: bb = cc -+         2c: bb < cc -+ -+         Case 3 splits into 3 subcases: -+         3a: bb > cc -+         3b: bb = cc -+         3c: bb < cc -+      */ -  -       /* the case rounding to nearest with sh=0 is special since one couldn't -          subtract above 1/2 ulp in the trailing limb of the result */ --      if ((rnd_mode == MPFR_RNDN) && sh == 0 && k == 0) -+      if (rnd_mode == MPFR_RNDN && sh == 0 && k == 0) /* case 1 for k=0 */ -         { -           mp_limb_t half = MPFR_LIMB_HIGHBIT; -  --          is_exact = (bb == cc); -- -           /* add one ulp if bb > cc + half -              truncate if cc - half < bb < cc + half -              sub one ulp if bb < cc - half -           */ -  --          if (down) -+          if (cmp_low < 0) /* bb < cc: -1 ulp < low(b) - low(c) < 0, -+                              cases 1e, 1f and 1g */ -             { -               if (cc >= half) -                 cc -= half; --              else -+              else /* since bb < cc < half, bb+half < 2*half */ -                 bb += half; -+              /* now we have bb < cc + half: -+                 we have to subtract one ulp if bb < cc, -+                 and truncate if bb > cc */ -             } --          else /* bb >= cc */ -+          else if (cmp_low >= 0) /* bb >= cc, cases 1a to 1d */ -             { -               if (cc < half) -                 cc += half; --              else -+              else /* since bb >= cc >= half, bb - half >= 0 */ -                 bb -= half; -+              /* now we have bb > cc - half: we have to add one ulp if bb > cc, -+                 and truncate if bb < cc */ -+              if (cmp_low > 0) -+                cmp_low = 2; -             } -         } -  - #ifdef DEBUG --      printf ("    bb=%lu cc=%lu down=%d is_exact=%d\n", --              (unsigned long) bb, (unsigned long) cc, down, is_exact); -+      printf ("k=%u bb=%lu cc=%lu cmp_low=%d\n", k, -+              (unsigned long) bb, (unsigned long) cc, cmp_low); - #endif --      if (bb < cc) -+      if (cmp_low < 0) /* low(b) - low(c) < 0: either truncate or subtract -+                          one ulp */ -         { -           if (rnd_mode == MPFR_RNDZ) --            goto sub_one_ulp; -+            goto sub_one_ulp; /* set inexact=-1 */ -           else if (rnd_mode != MPFR_RNDN) /* round away */ -             { -               inexact = 1; -               goto truncate; -             } --          else /* round to nearest: special case here since for sh=k=0 --                  bb = bb0 - MPFR_LIMB_HIGHBIT */ -+          else /* round to nearest */ -             { --              if (is_exact && sh == 0) --                { --                  /* For k=0 we can't decide exactness since it may depend --                     from low order bits. --                     For k=1, the first low limbs matched: low(b)-low(c)<0. */ --                  if (k) --                    { --                      inexact = 1; --                      goto truncate; --                    } --                } --              else if (down && sh == 0) --                goto sub_one_ulp; --              else --                { --                  inexact = (is_exact) ? 1 : -1; -+              /* If cmp_low < 0 and bb > cc, then -0.5 ulp < low(b)-low(c) < 0, -+                 whatever the value of sh. -+                 If sh>0, then cmp_low < 0 implies that the initial neglected -+                 sh bits were 0 (otherwise cmp_low=2 initially), thus the -+                 weight of the new bits is less than 0.5 ulp too. -+                 If k > 0 (and sh=0) this means that either the first neglected -+                 limbs bb and cc were equal (thus cmp_low was 0 for k=0), -+                 or we had bb - cc = -0.5 ulp or 0.5 ulp. -+                 The last case is not possible here since we would have -+                 cmp_low > 0 which is sticky. -+                 In the first case (where we have cmp_low = -1), we truncate, -+                 whereas in the 2nd case we have cmp_low = -2 and we subtract -+                 one ulp. -+              */ -+              if (bb > cc || sh > 0 || cmp_low == -1) -+                {  /* -0.5 ulp < low(b)-low(c) < 0, -+                      bb > cc corresponds to cases 1e and 1f1 -+                      sh > 0 corresponds to cases 3c and 3b3 -+                      cmp_low = -1 corresponds to case 1d3 (also 3b3) */ -+                  inexact = 1; -                   goto truncate; -                 } -+              else if (bb < cc) /* here sh = 0 and low(b)-low(c) < -0.5 ulp, -+                                   this corresponds to cases 1g and 1f3 */ -+                goto sub_one_ulp; -+              /* the only case where we can't conclude is sh=0 and bb=cc, -+                 i.e., we have low(b) - low(c) = -0.5 ulp (up to now), thus -+                 we don't know if we must truncate or subtract one ulp. -+                 Note: for sh=0 we can't have low(b) - low(c) = -0.5 ulp up to -+                 now, since low(b) - low(c) > 1/2^sh */ -             } -         } --      else if (bb > cc) -+      else if (cmp_low > 0) /* 0 < low(b) - low(c): either truncate or -+                               add one ulp */ -         { -           if (rnd_mode == MPFR_RNDZ) -             { -@@ -437,34 +500,70 @@ -             goto add_one_ulp; -           else /* round to nearest */ -             { --              if (is_exact) -+              if (bb > cc) -                 { --                  inexact = -1; --                  goto truncate; -+                  /* if sh=0, then bb>cc means that low(b)-low(c) > 0.5 ulp, -+                     and similarly when cmp_low=2 */ -+                  if (cmp_low == 2) /* cases 1a, 1b1, 2a and 2b1 */ -+                    goto add_one_ulp; -+                  /* sh > 0 and cmp_low > 0: this implies that the sh initial -+                     neglected bits were 0, and the remaining low(b)-low(c)>0, -+                     but its weight is less than 0.5 ulp */ -+                  else /* 0 < low(b) - low(c) < 0.5 ulp, this corresponds to -+                          cases 3a, 1d1 and 3b1 */ -+                    { -+                      inexact = -1; -+                      goto truncate; -+                    } -                 } --              else if (down) -+              else if (bb < cc) /* 0 < low(b) - low(c) < 0.5 ulp, cases 1c, -+                                   1b3, 2b3 and 2c */ -                 { --                  inexact = 1; -+                  inexact = -1; -                   goto truncate; -                 } --              else --                goto add_one_ulp; -+              /* the only case where we can't conclude is bb=cc, i.e., -+                 low(b) - low(c) = 0.5 ulp (up to now), thus we don't know -+                 if we must truncate or add one ulp. */ -             } -         } -+      /* after k=0, we cannot conclude in the following cases, we split them -+         according to the values of bb and cc for k=1: -+         1b. sh=0 and cmp_low = 1 and bb-cc = half [around 0.5 ulp] -+             1b1. bb > cc: add one ulp, inex = 1 -+             1b2: bb = cc: cannot conclude -+             1b3: bb < cc: truncate, inex = -1 -+         1d. sh=0 and cmp_low = 0 and bb-cc = 0 [around 0] -+             1d1: bb > cc: truncate, inex = -1 -+             1d2: bb = cc: cannot conclude -+             1d3: bb < cc: truncate, inex = +1 -+         1f. sh=0 and cmp_low = -1 and bb-cc = -half [around -0.5 ulp] -+             1f1: bb > cc: truncate, inex = +1 -+             1f2: bb = cc: cannot conclude -+             1f3: bb < cc: sub one ulp, inex = -1 -+         2b. sh > 0 and cmp_low = 2 and bb=cc [around 0.5 ulp] -+             2b1. bb > cc: add one ulp, inex = 1 -+             2b2: bb = cc: cannot conclude -+             2b3: bb < cc: truncate, inex = -1 -+         3b. sh > 0 and cmp_low = 0 [around 0] -+             3b1. bb > cc: truncate, inex = -1 -+             3b2: bb = cc: cannot conclude -+             3b3: bb < cc: truncate, inex = +1 -+      */ -     } -  --  if ((rnd_mode == MPFR_RNDN) && !is_exact) -+  if ((rnd_mode == MPFR_RNDN) && cmp_low != 0) -     { -       /* even rounding rule */ -       if ((ap[0] >> sh) & 1) -         { --          if (down) -+          if (cmp_low < 0) -             goto sub_one_ulp; -           else -             goto add_one_ulp; -         } -       else --        inexact = (down) ? 1 : -1; -+        inexact = (cmp_low > 0) ? -1 : 1; -     } -   else -     inexact = 0; -diff -Naurd mpfr-3.0.0-a/tests/tfma.c mpfr-3.0.0-b/tests/tfma.c ---- mpfr-3.0.0-a/tests/tfma.c	2010-06-10 11:00:13.000000000 +0000 -+++ mpfr-3.0.0-b/tests/tfma.c	2010-10-21 20:59:32.000000000 +0000 -@@ -337,6 +337,94 @@ -   mpfr_clears (x, y, z, r, (mpfr_ptr) 0); - } -  -+static void -+bug20101018 (void) -+{ -+  mpfr_t x, y, z, t, u; -+  int i; -+ -+  mpfr_init2 (x, 64); -+  mpfr_init2 (y, 64); -+  mpfr_init2 (z, 64); -+  mpfr_init2 (t, 64); -+  mpfr_init2 (u, 64); -+ -+  mpfr_set_str (x, "0xf.fffffffffffffffp-14766", 16, MPFR_RNDN); -+  mpfr_set_str (y, "-0xf.fffffffffffffffp+317", 16, MPFR_RNDN); -+  mpfr_set_str (z, "0x8.3ffffffffffe3ffp-14443", 16, MPFR_RNDN); -+  mpfr_set_str (t, "0x8.7ffffffffffc7ffp-14444", 16, MPFR_RNDN); -+  i = mpfr_fma (u, x, y, z, MPFR_RNDN); -+  if (mpfr_cmp (u, t) != 0) -+    { -+      printf ("Wrong result in bug20101018 (a)\n"); -+      printf ("Expected "); -+      mpfr_out_str (stdout, 16, 0, t, MPFR_RNDN); -+      printf ("\nGot      "); -+      mpfr_out_str (stdout, 16, 0, u, MPFR_RNDN); -+      printf ("\n"); -+      exit (1); -+    } -+  if (i <= 0) -+    { -+      printf ("Wrong ternary value in bug20101018 (a)\n"); -+      printf ("Expected > 0\n"); -+      printf ("Got      %d\n", i); -+      exit (1); -+    } -+ -+  mpfr_set_str (x, "-0xf.fffffffffffffffp-11420", 16, MPFR_RNDN); -+  mpfr_set_str (y, "0xf.fffffffffffffffp+9863", 16, MPFR_RNDN); -+  mpfr_set_str (z, "0x8.fffff80ffffffffp-1551", 16, MPFR_RNDN); -+  mpfr_set_str (t, "0x9.fffff01ffffffffp-1552", 16, MPFR_RNDN); -+  i = mpfr_fma (u, x, y, z, MPFR_RNDN); -+  if (mpfr_cmp (u, t) != 0) -+    { -+      printf ("Wrong result in bug20101018 (b)\n"); -+      printf ("Expected "); -+      mpfr_out_str (stdout, 16, 0, t, MPFR_RNDN); -+      printf ("\nGot      "); -+      mpfr_out_str (stdout, 16, 0, u, MPFR_RNDN); -+      printf ("\n"); -+      exit (1); -+    } -+  if (i <= 0) -+    { -+      printf ("Wrong ternary value in bug20101018 (b)\n"); -+      printf ("Expected > 0\n"); -+      printf ("Got      %d\n", i); -+      exit (1); -+    } -+ -+  mpfr_set_str (x, "0xf.fffffffffffffffp-2125", 16, MPFR_RNDN); -+  mpfr_set_str (y, "-0xf.fffffffffffffffp-6000", 16, MPFR_RNDN); -+  mpfr_set_str (z, "0x8p-8119", 16, MPFR_RNDN); -+  mpfr_set_str (t, "0x8.000000000000001p-8120", 16, MPFR_RNDN); -+  i = mpfr_fma (u, x, y, z, MPFR_RNDN); -+  if (mpfr_cmp (u, t) != 0) -+    { -+      printf ("Wrong result in bug20101018 (c)\n"); -+      printf ("Expected "); -+      mpfr_out_str (stdout, 16, 0, t, MPFR_RNDN); -+      printf ("\nGot      "); -+      mpfr_out_str (stdout, 16, 0, u, MPFR_RNDN); -+      printf ("\n"); -+      exit (1); -+    } -+  if (i <= 0) -+    { -+      printf ("Wrong ternary value in bug20101018 (c)\n"); -+      printf ("Expected > 0\n"); -+      printf ("Got      %d\n", i); -+      exit (1); -+    } -+ -+  mpfr_clear (x); -+  mpfr_clear (y); -+  mpfr_clear (z); -+  mpfr_clear (t); -+  mpfr_clear (u); -+} -+ - int - main (int argc, char *argv[]) - { -@@ -345,6 +433,8 @@ -  -   tests_start_mpfr (); -  -+  bug20101018 (); -+ -   mpfr_init (x); -   mpfr_init (s); -   mpfr_init (y); -diff -Naurd mpfr-3.0.0-a/tests/tsub.c mpfr-3.0.0-b/tests/tsub.c ---- mpfr-3.0.0-a/tests/tsub.c	2010-06-10 11:00:13.000000000 +0000 -+++ mpfr-3.0.0-b/tests/tsub.c	2010-10-21 20:59:32.000000000 +0000 -@@ -201,6 +201,8 @@ -   if (mpfr_cmp (z, x)) -     { -       printf ("Error in mpfr_sub (2)\n"); -+      printf ("Expected "); mpfr_print_binary (x); puts (""); -+      printf ("Got      "); mpfr_print_binary (z); puts (""); -       exit (1); -     } -   mpfr_set_str_binary (x, "1.1110111011110001110111011111111111101000011001011100101100101101"); -@@ -478,6 +480,156 @@ -   mpfr_clear (u); - } -  -+/* Bug found by Jakub Jelinek -+ * http://bugzilla.redhat.com/643657 -+ * https://gforge.inria.fr/tracker/index.php?func=detail&aid=11301 -+ * The consequence can be either an assertion failure (i = 2 in the -+ * testcase below, in debug mode) or an incorrectly rounded value. -+ */ -+static void -+bug20101017 (void) -+{ -+  mpfr_t a, b, c; -+  int inex; -+  int i; -+ -+  mpfr_init2 (a, GMP_NUMB_BITS * 2); -+  mpfr_init2 (b, GMP_NUMB_BITS); -+  mpfr_init2 (c, GMP_NUMB_BITS); -+ -+  /* a = 2^(2N) + k.2^(2N-1) + 2^N and b = 1 -+     with N = GMP_NUMB_BITS and k = 0 or 1. -+     c = a - b should round to the same value as a. */ -+ -+  for (i = 2; i <= 3; i++) -+    { -+      mpfr_set_ui_2exp (a, i, GMP_NUMB_BITS - 1, MPFR_RNDN); -+      mpfr_add_ui (a, a, 1, MPFR_RNDN); -+      mpfr_mul_2ui (a, a, GMP_NUMB_BITS, MPFR_RNDN); -+      mpfr_set_ui (b, 1, MPFR_RNDN); -+      inex = mpfr_sub (c, a, b, MPFR_RNDN); -+      mpfr_set (b, a, MPFR_RNDN); -+      if (! mpfr_equal_p (c, b)) -+        { -+          printf ("Error in bug20101017 for i = %d.\n", i); -+          printf ("Expected "); -+          mpfr_out_str (stdout, 16, 0, b, MPFR_RNDN); -+          putchar ('\n'); -+          printf ("Got      "); -+          mpfr_out_str (stdout, 16, 0, c, MPFR_RNDN); -+          putchar ('\n'); -+          exit (1); -+        } -+      if (inex >= 0) -+        { -+          printf ("Error in bug20101017 for i = %d: bad inex value.\n", i); -+          printf ("Expected negative, got %d.\n", inex); -+          exit (1); -+        } -+    } -+ -+  mpfr_set_prec (a, 64); -+  mpfr_set_prec (b, 129); -+  mpfr_set_prec (c, 2); -+  mpfr_set_str_binary (b, "0.100000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001E65"); -+  mpfr_set_str_binary (c, "0.10E1"); -+  inex = mpfr_sub (a, b, c, MPFR_RNDN); -+  if (mpfr_cmp_ui_2exp (a, 1, 64) != 0 || inex >= 0) -+    { -+      printf ("Error in mpfr_sub for b-c for b=2^64+1+2^(-64), c=1\n"); -+      printf ("Expected result 2^64 with inex < 0\n"); -+      printf ("Got "); mpfr_print_binary (a); -+      printf (" with inex=%d\n", inex); -+      exit (1); -+    } -+ -+  mpfr_clears (a, b, c, (mpfr_ptr) 0); -+} -+ -+/* hard test of rounding */ -+static void -+check_rounding (void) -+{ -+  mpfr_t a, b, c, res; -+  mpfr_prec_t p; -+  long k, l; -+  int i; -+ -+#define MAXKL (2 * GMP_NUMB_BITS) -+  for (p = MPFR_PREC_MIN; p <= GMP_NUMB_BITS; p++) -+    { -+      mpfr_init2 (a, p); -+      mpfr_init2 (res, p); -+      mpfr_init2 (b, p + 1 + MAXKL); -+      mpfr_init2 (c, MPFR_PREC_MIN); -+ -+      /* b = 2^p + 1 + 2^(-k), c = 2^(-l) */ -+      for (k = 0; k <= MAXKL; k++) -+        for (l = 0; l <= MAXKL; l++) -+          { -+            mpfr_set_ui_2exp (b, 1, p, MPFR_RNDN); -+            mpfr_add_ui (b, b, 1, MPFR_RNDN); -+            mpfr_mul_2ui (b, b, k, MPFR_RNDN); -+            mpfr_add_ui (b, b, 1, MPFR_RNDN); -+            mpfr_div_2ui (b, b, k, MPFR_RNDN); -+            mpfr_set_ui_2exp (c, 1, -l, MPFR_RNDN); -+            i = mpfr_sub (a, b, c, MPFR_RNDN); -+            /* b - c = 2^p + 1 + 2^(-k) - 2^(-l), should be rounded to -+               2^p for l <= k, and 2^p+2 for l < k */ -+            if (l <= k) -+              { -+                if (mpfr_cmp_ui_2exp (a, 1, p) != 0) -+                  { -+                    printf ("Wrong result in check_rounding\n"); -+                    printf ("p=%lu k=%ld l=%ld\n", p, k, l); -+                    printf ("b="); mpfr_print_binary (b); puts (""); -+                    printf ("c="); mpfr_print_binary (c); puts (""); -+                    printf ("Expected 2^%lu\n", p); -+                    printf ("Got      "); mpfr_print_binary (a); puts (""); -+                    exit (1); -+                  } -+                if (i >= 0) -+                  { -+                    printf ("Wrong ternary value in check_rounding\n"); -+                    printf ("p=%lu k=%ld l=%ld\n", p, k, l); -+                    printf ("b="); mpfr_print_binary (b); puts (""); -+                    printf ("c="); mpfr_print_binary (c); puts (""); -+                    printf ("a="); mpfr_print_binary (a); puts (""); -+                    printf ("Expected < 0, got %d\n", i); -+                    exit (1); -+                  } -+              } -+            else /* l < k */ -+              { -+                mpfr_set_ui_2exp (res, 1, p, MPFR_RNDN); -+                mpfr_add_ui (res, res, 2, MPFR_RNDN); -+                if (mpfr_cmp (a, res) != 0) -+                  { -+                    printf ("Wrong result in check_rounding\n"); -+                    printf ("b="); mpfr_print_binary (b); puts (""); -+                    printf ("c="); mpfr_print_binary (c); puts (""); -+                    printf ("Expected "); mpfr_print_binary (res); puts (""); -+                    printf ("Got      "); mpfr_print_binary (a); puts (""); -+                    exit (1); -+                  } -+                if (i <= 0) -+                  { -+                    printf ("Wrong ternary value in check_rounding\n"); -+                    printf ("b="); mpfr_print_binary (b); puts (""); -+                    printf ("c="); mpfr_print_binary (c); puts (""); -+                    printf ("Expected > 0, got %d\n", i); -+                    exit (1); -+                  } -+              } -+          } -+ -+      mpfr_clear (a); -+      mpfr_clear (res); -+      mpfr_clear (b); -+      mpfr_clear (c); -+    } -+} -+ - #define TEST_FUNCTION test_sub - #define TWO_ARGS - #define RAND_FUNCTION(x) mpfr_random2(x, MPFR_LIMB_SIZE (x), randlimb () % 100, RANDS) -@@ -491,6 +643,8 @@ -  -   tests_start_mpfr (); -  -+  bug20101017 (); -+  check_rounding (); -   check_diverse (); -   check_inexact (); -   bug_ddefour (); -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c ---- mpfr-3.0.0-a/version.c	2010-10-21 20:28:38.000000000 +0000 -+++ mpfr-3.0.0-b/version.c	2010-10-21 20:59:32.000000000 +0000 -@@ -25,5 +25,5 @@ - const char * - mpfr_get_version (void) - { --  return "3.0.0-p5"; -+  return "3.0.0-p6"; - } -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES ---- mpfr-3.0.0-a/PATCHES	2010-10-21 21:18:26.000000000 +0000 -+++ mpfr-3.0.0-b/PATCHES	2010-10-21 21:18:26.000000000 +0000 -@@ -0,0 +1 @@ -+mpfr_set_ld -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION ---- mpfr-3.0.0-a/VERSION	2010-10-21 20:59:32.000000000 +0000 -+++ mpfr-3.0.0-b/VERSION	2010-10-21 21:18:26.000000000 +0000 -@@ -1 +1 @@ --3.0.0-p6 -+3.0.0-p7 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h ---- mpfr-3.0.0-a/mpfr.h	2010-10-21 20:59:32.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.h	2010-10-21 21:18:26.000000000 +0000 -@@ -27,7 +27,7 @@ - #define MPFR_VERSION_MAJOR 3 - #define MPFR_VERSION_MINOR 0 - #define MPFR_VERSION_PATCHLEVEL 0 --#define MPFR_VERSION_STRING "3.0.0-p6" -+#define MPFR_VERSION_STRING "3.0.0-p7" -  - /* Macros dealing with MPFR VERSION */ - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) -diff -Naurd mpfr-3.0.0-a/set_ld.c mpfr-3.0.0-b/set_ld.c ---- mpfr-3.0.0-a/set_ld.c	2010-06-10 11:00:14.000000000 +0000 -+++ mpfr-3.0.0-b/set_ld.c	2010-10-21 21:18:26.000000000 +0000 -@@ -102,21 +102,25 @@ -             { -               x /= div13; /* exact */ -               shift_exp += 8192; -+              mpfr_div_2si (t, t, 8192, MPFR_RNDZ); -             } -           if (ABS (x) >= div12) -             { -               x /= div12; /* exact */ -               shift_exp += 4096; -+              mpfr_div_2si (t, t, 4096, MPFR_RNDZ); -             } -           if (ABS (x) >= div11) -             { -               x /= div11; /* exact */ -               shift_exp += 2048; -+              mpfr_div_2si (t, t, 2048, MPFR_RNDZ); -             } -           if (ABS (x) >= div10) -             { -               x /= div10; /* exact */ -               shift_exp += 1024; -+              mpfr_div_2si (t, t, 1024, MPFR_RNDZ); -             } -           /* warning: we may have DBL_MAX=2^1024*(1-2^(-53)) < x < 2^1024, -              therefore we have one extra exponent reduction step */ -@@ -124,9 +128,10 @@ -             { -               x /= div9; /* exact */ -               shift_exp += 512; -+              mpfr_div_2si (t, t, 512, MPFR_RNDZ); -             } -         } /* Check overflow of double */ --      else -+      else /* no overflow on double */ -         { -           long double div9, div10, div11; -  -@@ -149,29 +154,34 @@ -                 { -                   x /= div13; /* exact */ -                   shift_exp -= 8192; -+                  mpfr_mul_2si (t, t, 8192, MPFR_RNDZ); -                 } -               if (ABS (x) <= div12) -                 { -                   x /= div12; /* exact */ -                   shift_exp -= 4096; -+                  mpfr_mul_2si (t, t, 4096, MPFR_RNDZ); -                 } -               if (ABS (x) <= div11) -                 { -                   x /= div11; /* exact */ -                   shift_exp -= 2048; -+                  mpfr_mul_2si (t, t, 2048, MPFR_RNDZ); -                 } -               if (ABS (x) <= div10) -                 { -                   x /= div10; /* exact */ -                   shift_exp -= 1024; -+                  mpfr_mul_2si (t, t, 1024, MPFR_RNDZ); -                 } -               if (ABS(x) <= div9) -                 { -                   x /= div9;  /* exact */ -                   shift_exp -= 512; -+                  mpfr_mul_2si (t, t, 512, MPFR_RNDZ); -                 } -             } --          else -+          else /* no underflow */ -             { -               inexact = mpfr_set_d (u, (double) x, MPFR_RNDZ); -               MPFR_ASSERTD (inexact == 0); -diff -Naurd mpfr-3.0.0-a/tests/tset_ld.c mpfr-3.0.0-b/tests/tset_ld.c ---- mpfr-3.0.0-a/tests/tset_ld.c	2010-06-10 11:00:13.000000000 +0000 -+++ mpfr-3.0.0-b/tests/tset_ld.c	2010-10-21 21:18:26.000000000 +0000 -@@ -147,12 +147,39 @@ - test_fixed_bugs (void) - { -   mpfr_t x; --  long double d; -+  long double l, m; -  -   /* bug found by Steve Kargl (2009-03-14) */ -   mpfr_init2 (x, 64); -   mpfr_set_ui_2exp (x, 1, -16447, MPFR_RNDN); --  d = mpfr_get_ld (x, MPFR_RNDN);  /* an assertion failed in init2.c:50 */ -+  mpfr_get_ld (x, MPFR_RNDN);  /* an assertion failed in init2.c:50 */ -+ -+  /* bug reported by Jakub Jelinek (2010-10-17) -+     https://gforge.inria.fr/tracker/?func=detail&aid=11300 */ -+  mpfr_set_prec (x, MPFR_LDBL_MANT_DIG); -+  /* l = 0x1.23456789abcdef0123456789abcdp-914L; */ -+  l = 8.215640181713713164092636634579e-276; -+  mpfr_set_ld (x, l, MPFR_RNDN); -+  m = mpfr_get_ld (x, MPFR_RNDN); -+  if (m != l) -+    { -+      printf ("Error in get_ld o set_ld for l=%Le\n", l); -+      printf ("Got m=%Le instead of l\n", m); -+      exit (1); -+    } -+ -+  /* another similar test which failed with extended double precision and the -+     generic code for mpfr_set_ld */ -+  /* l = 0x1.23456789abcdef0123456789abcdp-968L; */ -+  l = 4.560596445887084662336528403703e-292; -+  mpfr_set_ld (x, l, MPFR_RNDN); -+  m = mpfr_get_ld (x, MPFR_RNDN); -+  if (m != l) -+    { -+      printf ("Error in get_ld o set_ld for l=%Le\n", l); -+      printf ("Got m=%Le instead of l\n", m); -+      exit (1); -+    } -  -   mpfr_clear (x); - } -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c ---- mpfr-3.0.0-a/version.c	2010-10-21 20:59:32.000000000 +0000 -+++ mpfr-3.0.0-b/version.c	2010-10-21 21:18:26.000000000 +0000 -@@ -25,5 +25,5 @@ - const char * - mpfr_get_version (void) - { --  return "3.0.0-p6"; -+  return "3.0.0-p7"; - } -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES ---- mpfr-3.0.0-a/PATCHES	2010-11-09 15:15:07.000000000 +0000 -+++ mpfr-3.0.0-b/PATCHES	2010-11-09 15:15:07.000000000 +0000 -@@ -0,0 +1 @@ -+macros -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION ---- mpfr-3.0.0-a/VERSION	2010-10-21 21:18:26.000000000 +0000 -+++ mpfr-3.0.0-b/VERSION	2010-11-09 15:15:07.000000000 +0000 -@@ -1 +1 @@ --3.0.0-p7 -+3.0.0-p8 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h ---- mpfr-3.0.0-a/mpfr.h	2010-10-21 21:18:26.000000000 +0000 -+++ mpfr-3.0.0-b/mpfr.h	2010-11-09 15:15:07.000000000 +0000 -@@ -27,7 +27,7 @@ - #define MPFR_VERSION_MAJOR 3 - #define MPFR_VERSION_MINOR 0 - #define MPFR_VERSION_PATCHLEVEL 0 --#define MPFR_VERSION_STRING "3.0.0-p7" -+#define MPFR_VERSION_STRING "3.0.0-p8" -  - /* Macros dealing with MPFR VERSION */ - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c)) -@@ -67,6 +67,16 @@ - # define _MPFR_H_HAVE_INTMAX_T 1 - #endif -  -+/* Avoid some problems with macro expansion if the user defines macros -+   with the same name as keywords. By convention, identifiers and macro -+   names starting with mpfr_ are reserved by MPFR. */ -+typedef void            mpfr_void; -+typedef int             mpfr_int; -+typedef unsigned int    mpfr_uint; -+typedef long            mpfr_long; -+typedef unsigned long   mpfr_ulong; -+typedef size_t          mpfr_size_t; -+ - /* Definition of rounding modes (DON'T USE MPFR_RNDNA!). -    Warning! Changing the contents of this enum should be seen as an -    interface change since the old and the new types are not compatible -@@ -136,7 +146,7 @@ - typedef mp_exp_t     mpfr_exp_t; -  - /* Definition of the standard exponent limits */ --#define MPFR_EMAX_DEFAULT ((mpfr_exp_t) (((unsigned long) 1 << 30) - 1)) -+#define MPFR_EMAX_DEFAULT ((mpfr_exp_t) (((mpfr_ulong) 1 << 30) - 1)) - #define MPFR_EMIN_DEFAULT (-(MPFR_EMAX_DEFAULT)) -  - /* Definition of the main structure */ -@@ -725,13 +735,13 @@ -    unexpected results with future compilers and aggressive optimisations. -    Why not working only with signed types, using INT_MIN and LONG_MIN? */ - #if __GMP_MP_SIZE_T_INT --#define __MPFR_EXP_NAN  ((mpfr_exp_t)((~((~(unsigned int)0)>>1))+2)) --#define __MPFR_EXP_ZERO ((mpfr_exp_t)((~((~(unsigned int)0)>>1))+1)) --#define __MPFR_EXP_INF  ((mpfr_exp_t)((~((~(unsigned int)0)>>1))+3)) -+#define __MPFR_EXP_NAN  ((mpfr_exp_t)((~((~(mpfr_uint)0)>>1))+2)) -+#define __MPFR_EXP_ZERO ((mpfr_exp_t)((~((~(mpfr_uint)0)>>1))+1)) -+#define __MPFR_EXP_INF  ((mpfr_exp_t)((~((~(mpfr_uint)0)>>1))+3)) - #else --#define __MPFR_EXP_NAN  ((mpfr_exp_t)((~((~(unsigned long)0)>>1))+2)) --#define __MPFR_EXP_ZERO ((mpfr_exp_t)((~((~(unsigned long)0)>>1))+1)) --#define __MPFR_EXP_INF  ((mpfr_exp_t)((~((~(unsigned long)0)>>1))+3)) -+#define __MPFR_EXP_NAN  ((mpfr_exp_t)((~((~(mpfr_ulong)0)>>1))+2)) -+#define __MPFR_EXP_ZERO ((mpfr_exp_t)((~((~(mpfr_ulong)0)>>1))+1)) -+#define __MPFR_EXP_INF  ((mpfr_exp_t)((~((~(mpfr_ulong)0)>>1))+3)) - #endif -  - /* Define MPFR_USE_EXTENSION to avoid "gcc -pedantic" warnings. */ -@@ -760,9 +770,9 @@ - #define mpfr_inf_p(_x)      ((_x)->_mpfr_exp == __MPFR_EXP_INF) - #define mpfr_zero_p(_x)     ((_x)->_mpfr_exp == __MPFR_EXP_ZERO) - #define mpfr_regular_p(_x)  ((_x)->_mpfr_exp >  __MPFR_EXP_INF) --#define mpfr_sgn(_x)                                          \ --  ((_x)->_mpfr_exp < __MPFR_EXP_INF ?                         \ --   (mpfr_nan_p (_x) ? mpfr_set_erangeflag () : (void) 0), 0 : \ -+#define mpfr_sgn(_x)                                               \ -+  ((_x)->_mpfr_exp < __MPFR_EXP_INF ?                              \ -+   (mpfr_nan_p (_x) ? mpfr_set_erangeflag () : (mpfr_void) 0), 0 : \ -    MPFR_SIGN (_x)) -  - /* Prevent them from using as lvalues */ -@@ -805,7 +815,19 @@ -    Moreover casts to unsigned long have been added to avoid warnings in -    programs that use MPFR and are compiled with -Wconversion; such casts -    are OK since if X is a constant expression, then (unsigned long) X is --   also a constant expression, so that the optimizations still work. */ -+   also a constant expression, so that the optimizations still work. The -+   warnings are probably related to the following two bugs: -+     http://gcc.gnu.org/bugzilla/show_bug.cgi?id=4210 -+     http://gcc.gnu.org/bugzilla/show_bug.cgi?id=38470 (possibly a variant) -+   and the casts could be removed once these bugs are fixed. -+   Casts shouldn't be used on the generic calls (to the ..._2exp functions), -+   where implicit conversions are performed. Indeed, having at least one -+   implicit conversion in the macro allows the compiler to emit diagnostics -+   when normally expected, for instance in the following call: -+     mpfr_set_ui (x, "foo", MPFR_RNDN); -+   If this is not possible (for future macros), one of the tricks described -+   on http://groups.google.com/group/comp.std.c/msg/e92abd24bf9eaf7b could -+   be used. */ - #if defined (__GNUC__) && !defined(__ICC) && !defined(__cplusplus) - #if (__GNUC__ >= 2) - #undef mpfr_cmp_ui -@@ -813,45 +835,45 @@ -    But warning! mpfr_sgn is specified as a macro in the API, thus the macro -    mustn't be used if side effects are possible, like here. */ - #define mpfr_cmp_ui(_f,_u)                                      \ --  (__builtin_constant_p (_u) && (unsigned long) (_u) == 0 ?     \ -+  (__builtin_constant_p (_u) && (mpfr_ulong) (_u) == 0 ?        \ -    (mpfr_sgn) (_f) :                                            \ --   mpfr_cmp_ui_2exp ((_f), (unsigned long) (_u), 0)) -+   mpfr_cmp_ui_2exp ((_f), (_u), 0)) - #undef mpfr_cmp_si --#define mpfr_cmp_si(_f,_s)                              \ --  (__builtin_constant_p (_s) && (long) (_s) >= 0 ?      \ --   mpfr_cmp_ui ((_f), (unsigned long) (long) (_s)) :    \ --   mpfr_cmp_si_2exp ((_f), (long) (_s), 0)) -+#define mpfr_cmp_si(_f,_s)                                      \ -+  (__builtin_constant_p (_s) && (mpfr_long) (_s) >= 0 ?         \ -+   mpfr_cmp_ui ((_f), (mpfr_ulong) (mpfr_long) (_s)) :          \ -+   mpfr_cmp_si_2exp ((_f), (_s), 0)) - #if __GNUC__ > 2 || __GNUC_MINOR__ >= 95 - #undef mpfr_set_ui - #define mpfr_set_ui(_f,_u,_r)                                   \ --  (__builtin_constant_p (_u) && (unsigned long) (_u) == 0 ?     \ -+  (__builtin_constant_p (_u) && (mpfr_ulong) (_u) == 0 ?        \ -    __extension__ ({                                             \ -        mpfr_ptr _p = (_f);                                      \ -        _p->_mpfr_sign = 1;                                      \ -        _p->_mpfr_exp = __MPFR_EXP_ZERO;                         \ --       (void) (_r); 0; }) :                                     \ --   mpfr_set_ui_2exp ((_f), (unsigned long) (_u), 0, (_r))) -+       (mpfr_void) (_r); 0; }) :                                \ -+   mpfr_set_ui_2exp ((_f), (_u), 0, (_r))) - #endif - #undef mpfr_set_si - #define mpfr_set_si(_f,_s,_r)                                   \ --  (__builtin_constant_p (_s) && (long) (_s) >= 0 ?              \ --   mpfr_set_ui ((_f), (unsigned long) (long) (_s), (_r)) :      \ --   mpfr_set_si_2exp ((_f), (long) (_s), 0, (_r))) -+  (__builtin_constant_p (_s) && (mpfr_long) (_s) >= 0 ?         \ -+   mpfr_set_ui ((_f), (mpfr_ulong) (mpfr_long) (_s), (_r)) :    \ -+   mpfr_set_si_2exp ((_f), (_s), 0, (_r))) - #endif - #endif -  - /* Macro version of mpfr_stack interface for fast access */ --#define mpfr_custom_get_size(p) ((size_t)                            \ -+#define mpfr_custom_get_size(p) ((mpfr_size_t)                          \ -        (((p)+GMP_NUMB_BITS-1)/GMP_NUMB_BITS*sizeof (mp_limb_t))) - #define mpfr_custom_init(m,p) do {} while (0) --#define mpfr_custom_get_significand(x) ((void*)((x)->_mpfr_d)) -+#define mpfr_custom_get_significand(x) ((mpfr_void*)((x)->_mpfr_d)) - #define mpfr_custom_get_exp(x) ((x)->_mpfr_exp) - #define mpfr_custom_move(x,m) do { ((x)->_mpfr_d = (mp_limb_t*)(m)); } while (0) - #define mpfr_custom_init_set(x,k,e,p,m) do {                   \ -   mpfr_ptr _x = (x);                                           \ -   mpfr_exp_t _e;                                               \ -   mpfr_kind_t _t;                                              \ --  int _s, _k;                                                  \ -+  mpfr_int _s, _k;                                             \ -   _k = (k);                                                    \ -   if (_k >= 0)  {                                              \ -     _t = (mpfr_kind_t) _k;                                     \ -@@ -868,11 +890,13 @@ -   _x->_mpfr_exp  = _e;                                         \ -   _x->_mpfr_d    = (mp_limb_t*) (m);                           \ -  } while (0) --#define mpfr_custom_get_kind(x)                                              \ --  ( (x)->_mpfr_exp >  __MPFR_EXP_INF ? (int)MPFR_REGULAR_KIND*MPFR_SIGN (x) \ --  : (x)->_mpfr_exp == __MPFR_EXP_INF ? (int)MPFR_INF_KIND*MPFR_SIGN (x)     \ --  : (x)->_mpfr_exp == __MPFR_EXP_NAN ? (int)MPFR_NAN_KIND                   \ --  : (int) MPFR_ZERO_KIND * MPFR_SIGN (x) ) -+#define mpfr_custom_get_kind(x)                                         \ -+  ( (x)->_mpfr_exp >  __MPFR_EXP_INF ?                                  \ -+    (mpfr_int) MPFR_REGULAR_KIND * MPFR_SIGN (x)                        \ -+  : (x)->_mpfr_exp == __MPFR_EXP_INF ?                                  \ -+    (mpfr_int) MPFR_INF_KIND * MPFR_SIGN (x)                            \ -+  : (x)->_mpfr_exp == __MPFR_EXP_NAN ? (mpfr_int) MPFR_NAN_KIND         \ -+  : (mpfr_int) MPFR_ZERO_KIND * MPFR_SIGN (x) ) -  -  - #endif /* MPFR_USE_NO_MACRO */ -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c ---- mpfr-3.0.0-a/version.c	2010-10-21 21:18:26.000000000 +0000 -+++ mpfr-3.0.0-b/version.c	2010-11-09 15:15:07.000000000 +0000 -@@ -25,5 +25,5 @@ - const char * - mpfr_get_version (void) - { --  return "3.0.0-p7"; -+  return "3.0.0-p8"; - } diff --git a/tools/mpfr/patches/001-no_tests.patch b/tools/mpfr/patches/001-no_tests.patch deleted file mode 100644 index 08c1a4ff4..000000000 --- a/tools/mpfr/patches/001-no_tests.patch +++ /dev/null @@ -1,26 +0,0 @@ -Index: mpfr-3.0.0/Makefile.am -=================================================================== ---- mpfr-3.0.0.orig/Makefile.am -+++ mpfr-3.0.0/Makefile.am -@@ -12,7 +12,7 @@ - AUTOMAKE_OPTIONS = gnu ansi2knr - ACLOCAL_AMFLAGS = -I m4 -  --SUBDIRS = tests -+SUBDIRS = -  - nobase_dist_doc_DATA = AUTHORS BUGS COPYING COPYING.LESSER FAQ.html NEWS TODO \ -   examples/ReadMe examples/divworst.c examples/rndo-add.c examples/sample.c \ -Index: mpfr-3.0.0/Makefile.in -=================================================================== ---- mpfr-3.0.0.orig/Makefile.in -+++ mpfr-3.0.0/Makefile.in -@@ -357,7 +357,7 @@ top_builddir = @top_builddir@ - top_srcdir = @top_srcdir@ - AUTOMAKE_OPTIONS = gnu ansi2knr - ACLOCAL_AMFLAGS = -I m4 --SUBDIRS = tests -+SUBDIRS = - nobase_dist_doc_DATA = AUTHORS BUGS COPYING COPYING.LESSER FAQ.html NEWS TODO \ -   examples/ReadMe examples/divworst.c examples/rndo-add.c examples/sample.c \ -   examples/version.c diff --git a/tools/mpfr/patches/001-only_src.patch b/tools/mpfr/patches/001-only_src.patch new file mode 100644 index 000000000..e6579b211 --- /dev/null +++ b/tools/mpfr/patches/001-only_src.patch @@ -0,0 +1,22 @@ +--- a/Makefile.am ++++ b/Makefile.am +@@ -12,7 +12,7 @@ + AUTOMAKE_OPTIONS = gnu + ACLOCAL_AMFLAGS = -I m4 +  +-SUBDIRS = doc src tests tune ++SUBDIRS = src +  + nobase_dist_doc_DATA = AUTHORS BUGS COPYING COPYING.LESSER NEWS TODO \ +   examples/ReadMe examples/divworst.c examples/rndo-add.c examples/sample.c \ +--- a/Makefile.in ++++ b/Makefile.in +@@ -294,7 +294,7 @@ top_builddir = @top_builddir@ + top_srcdir = @top_srcdir@ + AUTOMAKE_OPTIONS = gnu + ACLOCAL_AMFLAGS = -I m4 +-SUBDIRS = doc src tests tune ++SUBDIRS = src + nobase_dist_doc_DATA = AUTHORS BUGS COPYING COPYING.LESSER NEWS TODO \ +   examples/ReadMe examples/divworst.c examples/rndo-add.c examples/sample.c \ +   examples/version.c | 
