wok rev 12265

mpfr add fixes patch
author Christophe Lincoln <pankso@slitaz.org>
date Thu Apr 12 14:35:51 2012 +0200 (2012-04-12)
parents bdfc74b6f7b0
children 733f7b1b5b2a
files mpfr/stuff/mpfr-3.0.0.patch mpfr/stuff/mpfr-3.0.1.patch mpfr/stuff/mpfr-3.1.0.patch
line diff
     1.1 --- a/mpfr/stuff/mpfr-3.0.0.patch	Thu Apr 12 13:04:07 2012 +0200
     1.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.3 @@ -1,1945 +0,0 @@
     1.4 -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES
     1.5 ---- mpfr-3.0.0-a/PATCHES	2010-06-23 11:02:49.000000000 +0000
     1.6 -+++ mpfr-3.0.0-b/PATCHES	2010-06-23 11:03:36.000000000 +0000
     1.7 -@@ -0,0 +1 @@
     1.8 -+mpfr_out_str
     1.9 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION
    1.10 ---- mpfr-3.0.0-a/VERSION	2010-06-10 11:00:14.000000000 +0000
    1.11 -+++ mpfr-3.0.0-b/VERSION	2010-06-23 11:03:20.000000000 +0000
    1.12 -@@ -1 +1 @@
    1.13 --3.0.0
    1.14 -+3.0.0-p1
    1.15 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h
    1.16 ---- mpfr-3.0.0-a/mpfr.h	2010-06-10 11:00:14.000000000 +0000
    1.17 -+++ mpfr-3.0.0-b/mpfr.h	2010-06-23 11:03:20.000000000 +0000
    1.18 -@@ -27,7 +27,7 @@
    1.19 - #define MPFR_VERSION_MAJOR 3
    1.20 - #define MPFR_VERSION_MINOR 0
    1.21 - #define MPFR_VERSION_PATCHLEVEL 0
    1.22 --#define MPFR_VERSION_STRING "3.0.0"
    1.23 -+#define MPFR_VERSION_STRING "3.0.0-p1"
    1.24 - 
    1.25 - /* Macros dealing with MPFR VERSION */
    1.26 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
    1.27 -diff -Naurd mpfr-3.0.0-a/mpfr.texi mpfr-3.0.0-b/mpfr.texi
    1.28 ---- mpfr-3.0.0-a/mpfr.texi	2010-06-10 11:00:14.000000000 +0000
    1.29 -+++ mpfr-3.0.0-b/mpfr.texi	2010-06-23 11:03:12.000000000 +0000
    1.30 -@@ -2050,7 +2050,7 @@
    1.31 - are printed. If @var{base} is greater than 10, @samp{@@} will be used
    1.32 - instead of @samp{e} as exponent delimiter.
    1.33 - 
    1.34 --Return the number of bytes written, or if an error occurred, return 0.
    1.35 -+Return the number of characters written, or if an error occurred, return 0.
    1.36 - @end deftypefun
    1.37 - 
    1.38 - @deftypefun size_t mpfr_inp_str (mpfr_t @var{rop}, FILE *@var{stream}, int @var{base}, mpfr_rnd_t @var{rnd})
    1.39 -diff -Naurd mpfr-3.0.0-a/out_str.c mpfr-3.0.0-b/out_str.c
    1.40 ---- mpfr-3.0.0-a/out_str.c	2010-06-10 11:00:14.000000000 +0000
    1.41 -+++ mpfr-3.0.0-b/out_str.c	2010-06-23 11:03:12.000000000 +0000
    1.42 -@@ -22,6 +22,16 @@
    1.43 - 
    1.44 - #include "mpfr-impl.h"
    1.45 - 
    1.46 -+/* Warning! S should not contain "%". */
    1.47 -+#define OUT_STR_RET(S)                          \
    1.48 -+  do                                            \
    1.49 -+    {                                           \
    1.50 -+      int r;                                    \
    1.51 -+      r = fprintf (stream, (S));                \
    1.52 -+      return r < 0 ? 0 : r;                     \
    1.53 -+    }                                           \
    1.54 -+  while (0)
    1.55 -+
    1.56 - size_t
    1.57 - mpfr_out_str (FILE *stream, int base, size_t n_digits, mpfr_srcptr op,
    1.58 -               mpfr_rnd_t rnd_mode)
    1.59 -@@ -29,6 +39,7 @@
    1.60 -   char *s, *s0;
    1.61 -   size_t l;
    1.62 -   mpfr_exp_t e;
    1.63 -+  int err;
    1.64 - 
    1.65 -   MPFR_ASSERTN (base >= 2 && base <= 62);
    1.66 - 
    1.67 -@@ -36,37 +47,16 @@
    1.68 -   if (stream == NULL)
    1.69 -     stream = stdout;
    1.70 - 
    1.71 --  if (MPFR_IS_NAN(op))
    1.72 --    {
    1.73 --      fprintf (stream, "@NaN@");
    1.74 --      return 3;
    1.75 --    }
    1.76 --
    1.77 --  if (MPFR_IS_INF(op))
    1.78 --    {
    1.79 --      if (MPFR_SIGN(op) > 0)
    1.80 --        {
    1.81 --          fprintf (stream, "@Inf@");
    1.82 --          return 3;
    1.83 --        }
    1.84 --      else
    1.85 --        {
    1.86 --          fprintf (stream, "-@Inf@");
    1.87 --          return 4;
    1.88 --        }
    1.89 --    }
    1.90 --
    1.91 --  if (MPFR_IS_ZERO(op))
    1.92 -+  if (MPFR_UNLIKELY (MPFR_IS_SINGULAR (op)))
    1.93 -     {
    1.94 --      if (MPFR_SIGN(op) > 0)
    1.95 --        {
    1.96 --          fprintf(stream, "0");
    1.97 --          return 1;
    1.98 --        }
    1.99 -+      if (MPFR_IS_NAN (op))
   1.100 -+        OUT_STR_RET ("@NaN@");
   1.101 -+      else if (MPFR_IS_INF (op))
   1.102 -+        OUT_STR_RET (MPFR_IS_POS (op) ? "@Inf@" : "-@Inf@");
   1.103 -       else
   1.104 -         {
   1.105 --          fprintf(stream, "-0");
   1.106 --          return 2;
   1.107 -+          MPFR_ASSERTD (MPFR_IS_ZERO (op));
   1.108 -+          OUT_STR_RET (MPFR_IS_POS (op) ? "0" : "-0");
   1.109 -         }
   1.110 -     }
   1.111 - 
   1.112 -@@ -77,21 +67,31 @@
   1.113 - 
   1.114 -   l = strlen (s) + 1; /* size of allocated block returned by mpfr_get_str
   1.115 -                          - may be incorrect, as only an upper bound? */
   1.116 --  if (*s == '-')
   1.117 --    fputc (*s++, stream);
   1.118 - 
   1.119 --  /* outputs mantissa */
   1.120 --  fputc (*s++, stream); e--; /* leading digit */
   1.121 --  fputc ((unsigned char) MPFR_DECIMAL_POINT, stream);
   1.122 --  fputs (s, stream);         /* rest of mantissa */
   1.123 -+  /* outputs possible sign and significand */
   1.124 -+  err = (*s == '-' && fputc (*s++, stream) == EOF)
   1.125 -+    || fputc (*s++, stream) == EOF  /* leading digit */
   1.126 -+    || fputc ((unsigned char) MPFR_DECIMAL_POINT, stream) == EOF
   1.127 -+    || fputs (s, stream) == EOF;     /* trailing significand */
   1.128 -   (*__gmp_free_func) (s0, l);
   1.129 -+  if (MPFR_UNLIKELY (err))
   1.130 -+    return 0;
   1.131 -+
   1.132 -+  e--;  /* due to the leading digit */
   1.133 - 
   1.134 -   /* outputs exponent */
   1.135 -   if (e)
   1.136 -     {
   1.137 -+      int r;
   1.138 -+
   1.139 -       MPFR_ASSERTN(e >= LONG_MIN);
   1.140 -       MPFR_ASSERTN(e <= LONG_MAX);
   1.141 --      l += fprintf (stream, (base <= 10 ? "e%ld" : "@%ld"), (long) e);
   1.142 -+
   1.143 -+      r = fprintf (stream, (base <= 10 ? "e%ld" : "@%ld"), (long) e);
   1.144 -+      if (MPFR_UNLIKELY (r < 0))
   1.145 -+        return 0;
   1.146 -+
   1.147 -+      l += r;
   1.148 -     }
   1.149 - 
   1.150 -   return l;
   1.151 -diff -Naurd mpfr-3.0.0-a/tests/tout_str.c mpfr-3.0.0-b/tests/tout_str.c
   1.152 ---- mpfr-3.0.0-a/tests/tout_str.c	2010-06-10 11:00:13.000000000 +0000
   1.153 -+++ mpfr-3.0.0-b/tests/tout_str.c	2010-06-23 11:03:12.000000000 +0000
   1.154 -@@ -46,22 +46,54 @@
   1.155 - special (void)
   1.156 - {
   1.157 -   mpfr_t x;
   1.158 -+  unsigned int n;
   1.159 - 
   1.160 -   mpfr_init (x);
   1.161 - 
   1.162 -   mpfr_set_nan (x);
   1.163 --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.164 -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.165 -+  if (n != 5)
   1.166 -+    {
   1.167 -+      printf ("Error: mpfr_out_str (file, 10, 0, NaN, MPFR_RNDN) wrote %u "
   1.168 -+              "characters instead of 5.\n", n);
   1.169 -+      exit (1);
   1.170 -+    }
   1.171 - 
   1.172 -   mpfr_set_inf (x, 1);
   1.173 --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.174 -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.175 -+  if (n != 5)
   1.176 -+    {
   1.177 -+      printf ("Error: mpfr_out_str (file, 10, 0, +Inf, MPFR_RNDN) wrote %u "
   1.178 -+               "characters instead of 5.\n", n);
   1.179 -+      exit (1);
   1.180 -+    }
   1.181 - 
   1.182 -   mpfr_set_inf (x, -1);
   1.183 --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.184 -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.185 -+  if (n != 6)
   1.186 -+    {
   1.187 -+      printf ("Error: mpfr_out_str (file, 10, 0, -Inf, MPFR_RNDN) wrote %u "
   1.188 -+               "characters instead of 6.\n", n);
   1.189 -+      exit (1);
   1.190 -+    }
   1.191 - 
   1.192 -   mpfr_set_ui (x, 0, MPFR_RNDN);
   1.193 --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.194 -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.195 -+  if (n != 1)
   1.196 -+    {
   1.197 -+      printf ("Error: mpfr_out_str (file, 10, 0, +0, MPFR_RNDN) wrote %u "
   1.198 -+               "characters instead of 1.\n", n);
   1.199 -+      exit (1);
   1.200 -+    }
   1.201 -+
   1.202 -   mpfr_neg (x, x, MPFR_RNDN);
   1.203 --  mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.204 -+  n = mpfr_out_str (fout, 10, 0, x, MPFR_RNDN);
   1.205 -+  if (n != 2)
   1.206 -+    {
   1.207 -+      printf ("Error: mpfr_out_str (file, 10, 0, -0, MPFR_RNDN) wrote %u "
   1.208 -+               "characters instead of 2.\n", n);
   1.209 -+      exit (1);
   1.210 -+    }
   1.211 - 
   1.212 -   mpfr_clear (x);
   1.213 - }
   1.214 -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c
   1.215 ---- mpfr-3.0.0-a/version.c	2010-06-10 11:00:14.000000000 +0000
   1.216 -+++ mpfr-3.0.0-b/version.c	2010-06-23 11:03:20.000000000 +0000
   1.217 -@@ -25,5 +25,5 @@
   1.218 - const char *
   1.219 - mpfr_get_version (void)
   1.220 - {
   1.221 --  return "3.0.0";
   1.222 -+  return "3.0.0-p1";
   1.223 - }
   1.224 -diff -Naurd mpfr-3.0.0-a/Makefile.in mpfr-3.0.0-b/Makefile.in
   1.225 ---- mpfr-3.0.0-a/Makefile.in	2010-06-10 11:00:52.000000000 +0000
   1.226 -+++ mpfr-3.0.0-b/Makefile.in	2010-06-10 11:00:52.000000000 +0000
   1.227 -@@ -239,6 +239,7 @@
   1.228 - distuninstallcheck_listfiles = find . -type f -print
   1.229 - distcleancheck_listfiles = find . -type f -print
   1.230 - ACLOCAL = @ACLOCAL@
   1.231 -+ALLOCA = @ALLOCA@
   1.232 - AMTAR = @AMTAR@
   1.233 - AR = @AR@
   1.234 - AS = @AS@
   1.235 -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES
   1.236 ---- mpfr-3.0.0-a/PATCHES	2010-06-23 11:03:36.000000000 +0000
   1.237 -+++ mpfr-3.0.0-b/PATCHES	2010-06-25 13:23:13.000000000 +0000
   1.238 -@@ -0,0 +1 @@
   1.239 -+alloca
   1.240 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION
   1.241 ---- mpfr-3.0.0-a/VERSION	2010-06-23 11:03:20.000000000 +0000
   1.242 -+++ mpfr-3.0.0-b/VERSION	2010-06-25 13:23:13.000000000 +0000
   1.243 -@@ -1 +1 @@
   1.244 --3.0.0-p1
   1.245 -+3.0.0-p2
   1.246 -diff -Naurd mpfr-3.0.0-a/acinclude.m4 mpfr-3.0.0-b/acinclude.m4
   1.247 ---- mpfr-3.0.0-a/acinclude.m4	2010-06-10 11:00:14.000000000 +0000
   1.248 -+++ mpfr-3.0.0-b/acinclude.m4	2010-06-10 11:00:14.000000000 +0000
   1.249 -@@ -59,6 +59,9 @@
   1.250 - dnl sys/fpu.h - MIPS specific
   1.251 - AC_CHECK_HEADERS([sys/time.h sys/fpu.h])
   1.252 - 
   1.253 -+dnl Check how to get `alloca'
   1.254 -+AC_FUNC_ALLOCA
   1.255 -+
   1.256 - dnl SIZE_MAX macro
   1.257 - gl_SIZE_MAX
   1.258 - 
   1.259 -diff -Naurd mpfr-3.0.0-a/configure mpfr-3.0.0-b/configure
   1.260 ---- mpfr-3.0.0-a/configure	2010-06-10 11:00:51.000000000 +0000
   1.261 -+++ mpfr-3.0.0-b/configure	2010-06-25 13:23:05.000000000 +0000
   1.262 -@@ -783,6 +783,7 @@
   1.263 - OBJDUMP
   1.264 - DLLTOOL
   1.265 - AS
   1.266 -+ALLOCA
   1.267 - MPFR_LIBM
   1.268 - ANSI2KNR
   1.269 - U
   1.270 -@@ -5622,6 +5623,197 @@
   1.271 - done
   1.272 - 
   1.273 - 
   1.274 -+# The Ultrix 4.2 mips builtin alloca declared by alloca.h only works
   1.275 -+# for constant arguments.  Useless!
   1.276 -+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for working alloca.h" >&5
   1.277 -+$as_echo_n "checking for working alloca.h... " >&6; }
   1.278 -+if test "${ac_cv_working_alloca_h+set}" = set; then :
   1.279 -+  $as_echo_n "(cached) " >&6
   1.280 -+else
   1.281 -+  cat confdefs.h - <<_ACEOF >conftest.$ac_ext
   1.282 -+/* end confdefs.h.  */
   1.283 -+#include <alloca.h>
   1.284 -+int
   1.285 -+main ()
   1.286 -+{
   1.287 -+char *p = (char *) alloca (2 * sizeof (int));
   1.288 -+			  if (p) return 0;
   1.289 -+  ;
   1.290 -+  return 0;
   1.291 -+}
   1.292 -+_ACEOF
   1.293 -+if ac_fn_c_try_link "$LINENO"; then :
   1.294 -+  ac_cv_working_alloca_h=yes
   1.295 -+else
   1.296 -+  ac_cv_working_alloca_h=no
   1.297 -+fi
   1.298 -+rm -f core conftest.err conftest.$ac_objext \
   1.299 -+    conftest$ac_exeext conftest.$ac_ext
   1.300 -+fi
   1.301 -+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_working_alloca_h" >&5
   1.302 -+$as_echo "$ac_cv_working_alloca_h" >&6; }
   1.303 -+if test $ac_cv_working_alloca_h = yes; then
   1.304 -+
   1.305 -+$as_echo "#define HAVE_ALLOCA_H 1" >>confdefs.h
   1.306 -+
   1.307 -+fi
   1.308 -+
   1.309 -+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for alloca" >&5
   1.310 -+$as_echo_n "checking for alloca... " >&6; }
   1.311 -+if test "${ac_cv_func_alloca_works+set}" = set; then :
   1.312 -+  $as_echo_n "(cached) " >&6
   1.313 -+else
   1.314 -+  cat confdefs.h - <<_ACEOF >conftest.$ac_ext
   1.315 -+/* end confdefs.h.  */
   1.316 -+#ifdef __GNUC__
   1.317 -+# define alloca __builtin_alloca
   1.318 -+#else
   1.319 -+# ifdef _MSC_VER
   1.320 -+#  include <malloc.h>
   1.321 -+#  define alloca _alloca
   1.322 -+# else
   1.323 -+#  ifdef HAVE_ALLOCA_H
   1.324 -+#   include <alloca.h>
   1.325 -+#  else
   1.326 -+#   ifdef _AIX
   1.327 -+ #pragma alloca
   1.328 -+#   else
   1.329 -+#    ifndef alloca /* predefined by HP cc +Olibcalls */
   1.330 -+char *alloca ();
   1.331 -+#    endif
   1.332 -+#   endif
   1.333 -+#  endif
   1.334 -+# endif
   1.335 -+#endif
   1.336 -+
   1.337 -+int
   1.338 -+main ()
   1.339 -+{
   1.340 -+char *p = (char *) alloca (1);
   1.341 -+				    if (p) return 0;
   1.342 -+  ;
   1.343 -+  return 0;
   1.344 -+}
   1.345 -+_ACEOF
   1.346 -+if ac_fn_c_try_link "$LINENO"; then :
   1.347 -+  ac_cv_func_alloca_works=yes
   1.348 -+else
   1.349 -+  ac_cv_func_alloca_works=no
   1.350 -+fi
   1.351 -+rm -f core conftest.err conftest.$ac_objext \
   1.352 -+    conftest$ac_exeext conftest.$ac_ext
   1.353 -+fi
   1.354 -+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_func_alloca_works" >&5
   1.355 -+$as_echo "$ac_cv_func_alloca_works" >&6; }
   1.356 -+
   1.357 -+if test $ac_cv_func_alloca_works = yes; then
   1.358 -+
   1.359 -+$as_echo "#define HAVE_ALLOCA 1" >>confdefs.h
   1.360 -+
   1.361 -+else
   1.362 -+  # The SVR3 libPW and SVR4 libucb both contain incompatible functions
   1.363 -+# that cause trouble.  Some versions do not even contain alloca or
   1.364 -+# contain a buggy version.  If you still want to use their alloca,
   1.365 -+# use ar to extract alloca.o from them instead of compiling alloca.c.
   1.366 -+
   1.367 -+ALLOCA=\${LIBOBJDIR}alloca.$ac_objext
   1.368 -+
   1.369 -+$as_echo "#define C_ALLOCA 1" >>confdefs.h
   1.370 -+
   1.371 -+
   1.372 -+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether \`alloca.c' needs Cray hooks" >&5
   1.373 -+$as_echo_n "checking whether \`alloca.c' needs Cray hooks... " >&6; }
   1.374 -+if test "${ac_cv_os_cray+set}" = set; then :
   1.375 -+  $as_echo_n "(cached) " >&6
   1.376 -+else
   1.377 -+  cat confdefs.h - <<_ACEOF >conftest.$ac_ext
   1.378 -+/* end confdefs.h.  */
   1.379 -+#if defined CRAY && ! defined CRAY2
   1.380 -+webecray
   1.381 -+#else
   1.382 -+wenotbecray
   1.383 -+#endif
   1.384 -+
   1.385 -+_ACEOF
   1.386 -+if (eval "$ac_cpp conftest.$ac_ext") 2>&5 |
   1.387 -+  $EGREP "webecray" >/dev/null 2>&1; then :
   1.388 -+  ac_cv_os_cray=yes
   1.389 -+else
   1.390 -+  ac_cv_os_cray=no
   1.391 -+fi
   1.392 -+rm -f conftest*
   1.393 -+
   1.394 -+fi
   1.395 -+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_os_cray" >&5
   1.396 -+$as_echo "$ac_cv_os_cray" >&6; }
   1.397 -+if test $ac_cv_os_cray = yes; then
   1.398 -+  for ac_func in _getb67 GETB67 getb67; do
   1.399 -+    as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh`
   1.400 -+ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var"
   1.401 -+eval as_val=\$$as_ac_var
   1.402 -+   if test "x$as_val" = x""yes; then :
   1.403 -+
   1.404 -+cat >>confdefs.h <<_ACEOF
   1.405 -+#define CRAY_STACKSEG_END $ac_func
   1.406 -+_ACEOF
   1.407 -+
   1.408 -+    break
   1.409 -+fi
   1.410 -+
   1.411 -+  done
   1.412 -+fi
   1.413 -+
   1.414 -+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking stack direction for C alloca" >&5
   1.415 -+$as_echo_n "checking stack direction for C alloca... " >&6; }
   1.416 -+if test "${ac_cv_c_stack_direction+set}" = set; then :
   1.417 -+  $as_echo_n "(cached) " >&6
   1.418 -+else
   1.419 -+  if test "$cross_compiling" = yes; then :
   1.420 -+  ac_cv_c_stack_direction=0
   1.421 -+else
   1.422 -+  cat confdefs.h - <<_ACEOF >conftest.$ac_ext
   1.423 -+/* end confdefs.h.  */
   1.424 -+$ac_includes_default
   1.425 -+int
   1.426 -+find_stack_direction ()
   1.427 -+{
   1.428 -+  static char *addr = 0;
   1.429 -+  auto char dummy;
   1.430 -+  if (addr == 0)
   1.431 -+    {
   1.432 -+      addr = &dummy;
   1.433 -+      return find_stack_direction ();
   1.434 -+    }
   1.435 -+  else
   1.436 -+    return (&dummy > addr) ? 1 : -1;
   1.437 -+}
   1.438 -+
   1.439 -+int
   1.440 -+main ()
   1.441 -+{
   1.442 -+  return find_stack_direction () < 0;
   1.443 -+}
   1.444 -+_ACEOF
   1.445 -+if ac_fn_c_try_run "$LINENO"; then :
   1.446 -+  ac_cv_c_stack_direction=1
   1.447 -+else
   1.448 -+  ac_cv_c_stack_direction=-1
   1.449 -+fi
   1.450 -+rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \
   1.451 -+  conftest.$ac_objext conftest.beam conftest.$ac_ext
   1.452 -+fi
   1.453 -+
   1.454 -+fi
   1.455 -+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_stack_direction" >&5
   1.456 -+$as_echo "$ac_cv_c_stack_direction" >&6; }
   1.457 -+cat >>confdefs.h <<_ACEOF
   1.458 -+#define STACK_DIRECTION $ac_cv_c_stack_direction
   1.459 -+_ACEOF
   1.460 -+
   1.461 -+
   1.462 -+fi
   1.463 -+
   1.464 -+
   1.465 - 
   1.466 -   for ac_header in stdint.h
   1.467 - do :
   1.468 -@@ -7564,13 +7756,13 @@
   1.469 - else
   1.470 -   lt_cv_nm_interface="BSD nm"
   1.471 -   echo "int some_variable = 0;" > conftest.$ac_ext
   1.472 --  (eval echo "\"\$as_me:7567: $ac_compile\"" >&5)
   1.473 -+  (eval echo "\"\$as_me:7759: $ac_compile\"" >&5)
   1.474 -   (eval "$ac_compile" 2>conftest.err)
   1.475 -   cat conftest.err >&5
   1.476 --  (eval echo "\"\$as_me:7570: $NM \\\"conftest.$ac_objext\\\"\"" >&5)
   1.477 -+  (eval echo "\"\$as_me:7762: $NM \\\"conftest.$ac_objext\\\"\"" >&5)
   1.478 -   (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out)
   1.479 -   cat conftest.err >&5
   1.480 --  (eval echo "\"\$as_me:7573: output\"" >&5)
   1.481 -+  (eval echo "\"\$as_me:7765: output\"" >&5)
   1.482 -   cat conftest.out >&5
   1.483 -   if $GREP 'External.*some_variable' conftest.out > /dev/null; then
   1.484 -     lt_cv_nm_interface="MS dumpbin"
   1.485 -@@ -8772,7 +8964,7 @@
   1.486 -   ;;
   1.487 - *-*-irix6*)
   1.488 -   # Find out which ABI we are using.
   1.489 --  echo '#line 8775 "configure"' > conftest.$ac_ext
   1.490 -+  echo '#line 8967 "configure"' > conftest.$ac_ext
   1.491 -   if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
   1.492 -   (eval $ac_compile) 2>&5
   1.493 -   ac_status=$?
   1.494 -@@ -10032,11 +10224,11 @@
   1.495 -    -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
   1.496 -    -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \
   1.497 -    -e 's:$: $lt_compiler_flag:'`
   1.498 --   (eval echo "\"\$as_me:10035: $lt_compile\"" >&5)
   1.499 -+   (eval echo "\"\$as_me:10227: $lt_compile\"" >&5)
   1.500 -    (eval "$lt_compile" 2>conftest.err)
   1.501 -    ac_status=$?
   1.502 -    cat conftest.err >&5
   1.503 --   echo "$as_me:10039: \$? = $ac_status" >&5
   1.504 -+   echo "$as_me:10231: \$? = $ac_status" >&5
   1.505 -    if (exit $ac_status) && test -s "$ac_outfile"; then
   1.506 -      # The compiler can only warn and ignore the option if not recognized
   1.507 -      # So say no if there are warnings other than the usual output.
   1.508 -@@ -10371,11 +10563,11 @@
   1.509 -    -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
   1.510 -    -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \
   1.511 -    -e 's:$: $lt_compiler_flag:'`
   1.512 --   (eval echo "\"\$as_me:10374: $lt_compile\"" >&5)
   1.513 -+   (eval echo "\"\$as_me:10566: $lt_compile\"" >&5)
   1.514 -    (eval "$lt_compile" 2>conftest.err)
   1.515 -    ac_status=$?
   1.516 -    cat conftest.err >&5
   1.517 --   echo "$as_me:10378: \$? = $ac_status" >&5
   1.518 -+   echo "$as_me:10570: \$? = $ac_status" >&5
   1.519 -    if (exit $ac_status) && test -s "$ac_outfile"; then
   1.520 -      # The compiler can only warn and ignore the option if not recognized
   1.521 -      # So say no if there are warnings other than the usual output.
   1.522 -@@ -10476,11 +10668,11 @@
   1.523 -    -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
   1.524 -    -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \
   1.525 -    -e 's:$: $lt_compiler_flag:'`
   1.526 --   (eval echo "\"\$as_me:10479: $lt_compile\"" >&5)
   1.527 -+   (eval echo "\"\$as_me:10671: $lt_compile\"" >&5)
   1.528 -    (eval "$lt_compile" 2>out/conftest.err)
   1.529 -    ac_status=$?
   1.530 -    cat out/conftest.err >&5
   1.531 --   echo "$as_me:10483: \$? = $ac_status" >&5
   1.532 -+   echo "$as_me:10675: \$? = $ac_status" >&5
   1.533 -    if (exit $ac_status) && test -s out/conftest2.$ac_objext
   1.534 -    then
   1.535 -      # The compiler can only warn and ignore the option if not recognized
   1.536 -@@ -10531,11 +10723,11 @@
   1.537 -    -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \
   1.538 -    -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \
   1.539 -    -e 's:$: $lt_compiler_flag:'`
   1.540 --   (eval echo "\"\$as_me:10534: $lt_compile\"" >&5)
   1.541 -+   (eval echo "\"\$as_me:10726: $lt_compile\"" >&5)
   1.542 -    (eval "$lt_compile" 2>out/conftest.err)
   1.543 -    ac_status=$?
   1.544 -    cat out/conftest.err >&5
   1.545 --   echo "$as_me:10538: \$? = $ac_status" >&5
   1.546 -+   echo "$as_me:10730: \$? = $ac_status" >&5
   1.547 -    if (exit $ac_status) && test -s out/conftest2.$ac_objext
   1.548 -    then
   1.549 -      # The compiler can only warn and ignore the option if not recognized
   1.550 -@@ -12915,7 +13107,7 @@
   1.551 -   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
   1.552 -   lt_status=$lt_dlunknown
   1.553 -   cat > conftest.$ac_ext <<_LT_EOF
   1.554 --#line 12918 "configure"
   1.555 -+#line 13110 "configure"
   1.556 - #include "confdefs.h"
   1.557 - 
   1.558 - #if HAVE_DLFCN_H
   1.559 -@@ -13011,7 +13203,7 @@
   1.560 -   lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
   1.561 -   lt_status=$lt_dlunknown
   1.562 -   cat > conftest.$ac_ext <<_LT_EOF
   1.563 --#line 13014 "configure"
   1.564 -+#line 13206 "configure"
   1.565 - #include "confdefs.h"
   1.566 - 
   1.567 - #if HAVE_DLFCN_H
   1.568 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h
   1.569 ---- mpfr-3.0.0-a/mpfr.h	2010-06-23 11:03:20.000000000 +0000
   1.570 -+++ mpfr-3.0.0-b/mpfr.h	2010-06-25 13:23:13.000000000 +0000
   1.571 -@@ -27,7 +27,7 @@
   1.572 - #define MPFR_VERSION_MAJOR 3
   1.573 - #define MPFR_VERSION_MINOR 0
   1.574 - #define MPFR_VERSION_PATCHLEVEL 0
   1.575 --#define MPFR_VERSION_STRING "3.0.0-p1"
   1.576 -+#define MPFR_VERSION_STRING "3.0.0-p2"
   1.577 - 
   1.578 - /* Macros dealing with MPFR VERSION */
   1.579 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   1.580 -diff -Naurd mpfr-3.0.0-a/tests/Makefile.in mpfr-3.0.0-b/tests/Makefile.in
   1.581 ---- mpfr-3.0.0-a/tests/Makefile.in	2010-06-10 11:00:52.000000000 +0000
   1.582 -+++ mpfr-3.0.0-b/tests/Makefile.in	2010-06-10 11:00:52.000000000 +0000
   1.583 -@@ -960,6 +960,7 @@
   1.584 - red=; grn=; lgn=; blu=; std=
   1.585 - DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
   1.586 - ACLOCAL = @ACLOCAL@
   1.587 -+ALLOCA = @ALLOCA@
   1.588 - AMTAR = @AMTAR@
   1.589 - AR = @AR@
   1.590 - AS = @AS@
   1.591 -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c
   1.592 ---- mpfr-3.0.0-a/version.c	2010-06-23 11:03:20.000000000 +0000
   1.593 -+++ mpfr-3.0.0-b/version.c	2010-06-25 13:23:13.000000000 +0000
   1.594 -@@ -25,5 +25,5 @@
   1.595 - const char *
   1.596 - mpfr_get_version (void)
   1.597 - {
   1.598 --  return "3.0.0-p1";
   1.599 -+  return "3.0.0-p2";
   1.600 - }
   1.601 -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES
   1.602 ---- mpfr-3.0.0-a/PATCHES	2010-07-10 00:11:19.000000000 +0000
   1.603 -+++ mpfr-3.0.0-b/PATCHES	2010-07-10 00:12:50.000000000 +0000
   1.604 -@@ -0,0 +1 @@
   1.605 -+gamma_underflow
   1.606 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION
   1.607 ---- mpfr-3.0.0-a/VERSION	2010-06-25 13:23:13.000000000 +0000
   1.608 -+++ mpfr-3.0.0-b/VERSION	2010-07-10 00:11:53.000000000 +0000
   1.609 -@@ -1 +1 @@
   1.610 --3.0.0-p2
   1.611 -+3.0.0-p3
   1.612 -diff -Naurd mpfr-3.0.0-a/gamma.c mpfr-3.0.0-b/gamma.c
   1.613 ---- mpfr-3.0.0-a/gamma.c	2010-06-10 11:00:14.000000000 +0000
   1.614 -+++ mpfr-3.0.0-b/gamma.c	2010-07-10 00:11:46.000000000 +0000
   1.615 -@@ -274,7 +274,7 @@
   1.616 -       /* we want an upper bound for x * [log(2-x)-1].
   1.617 -          since x < 0, we need a lower bound on log(2-x) */
   1.618 -       mpfr_ui_sub (xp, 2, x, MPFR_RNDD);
   1.619 --      mpfr_log (xp, xp, MPFR_RNDD);
   1.620 -+      mpfr_log2 (xp, xp, MPFR_RNDD);
   1.621 -       mpfr_sub_ui (xp, xp, 1, MPFR_RNDD);
   1.622 -       mpfr_mul (xp, xp, x, MPFR_RNDU);
   1.623 - 
   1.624 -@@ -303,8 +303,8 @@
   1.625 -         {
   1.626 -           mpfr_sub (tmp, tmp, tmp2, MPFR_RNDZ); /* low bnd on |sin(Pi*(2-x))| */
   1.627 -           mpfr_ui_div (tmp, 12, tmp, MPFR_RNDU); /* upper bound */
   1.628 --          mpfr_log (tmp, tmp, MPFR_RNDU);
   1.629 --          mpfr_add (tmp, tmp, xp, MPFR_RNDU);
   1.630 -+          mpfr_log2 (tmp, tmp, MPFR_RNDU);
   1.631 -+          mpfr_add (xp, tmp, xp, MPFR_RNDU);
   1.632 -           underflow = mpfr_cmp_si (xp, expo.saved_emin - 2) <= 0;
   1.633 -         }
   1.634 - 
   1.635 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h
   1.636 ---- mpfr-3.0.0-a/mpfr.h	2010-06-25 13:23:13.000000000 +0000
   1.637 -+++ mpfr-3.0.0-b/mpfr.h	2010-07-10 00:11:53.000000000 +0000
   1.638 -@@ -27,7 +27,7 @@
   1.639 - #define MPFR_VERSION_MAJOR 3
   1.640 - #define MPFR_VERSION_MINOR 0
   1.641 - #define MPFR_VERSION_PATCHLEVEL 0
   1.642 --#define MPFR_VERSION_STRING "3.0.0-p2"
   1.643 -+#define MPFR_VERSION_STRING "3.0.0-p3"
   1.644 - 
   1.645 - /* Macros dealing with MPFR VERSION */
   1.646 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   1.647 -diff -Naurd mpfr-3.0.0-a/tests/tgamma.c mpfr-3.0.0-b/tests/tgamma.c
   1.648 ---- mpfr-3.0.0-a/tests/tgamma.c	2010-06-10 11:00:13.000000000 +0000
   1.649 -+++ mpfr-3.0.0-b/tests/tgamma.c	2010-07-10 00:11:46.000000000 +0000
   1.650 -@@ -461,6 +461,20 @@
   1.651 -   mpfr_clear (x);
   1.652 - }
   1.653 - 
   1.654 -+/* bug found by Stathis, only occurs on 32-bit machines */
   1.655 -+static void
   1.656 -+test20100709 (void)
   1.657 -+{
   1.658 -+  mpfr_t x;
   1.659 -+  int inex;
   1.660 -+
   1.661 -+  mpfr_init2 (x, 100);
   1.662 -+  mpfr_set_str (x, "-4.6308260837372266e+07", 10, MPFR_RNDN);
   1.663 -+  inex = mpfr_gamma (x, x, MPFR_RNDN);
   1.664 -+  MPFR_ASSERTN(MPFR_IS_ZERO(x) && MPFR_IS_NEG(x) && inex > 0);
   1.665 -+  mpfr_clear (x);
   1.666 -+}
   1.667 -+
   1.668 - int
   1.669 - main (int argc, char *argv[])
   1.670 - {
   1.671 -@@ -471,6 +485,7 @@
   1.672 -   test_generic (2, 100, 2);
   1.673 -   gamma_integer ();
   1.674 -   test20071231 ();
   1.675 -+  test20100709 ();
   1.676 - 
   1.677 -   data_check ("data/gamma", mpfr_gamma, "mpfr_gamma");
   1.678 - 
   1.679 -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c
   1.680 ---- mpfr-3.0.0-a/version.c	2010-06-25 13:23:13.000000000 +0000
   1.681 -+++ mpfr-3.0.0-b/version.c	2010-07-10 00:11:53.000000000 +0000
   1.682 -@@ -25,5 +25,5 @@
   1.683 - const char *
   1.684 - mpfr_get_version (void)
   1.685 - {
   1.686 --  return "3.0.0-p2";
   1.687 -+  return "3.0.0-p3";
   1.688 - }
   1.689 -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES
   1.690 ---- mpfr-3.0.0-a/PATCHES	2010-09-07 08:44:01.000000000 +0000
   1.691 -+++ mpfr-3.0.0-b/PATCHES	2010-09-07 08:48:46.000000000 +0000
   1.692 -@@ -0,0 +1 @@
   1.693 -+mpfr_cmp/set_ui/si
   1.694 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION
   1.695 ---- mpfr-3.0.0-a/VERSION	2010-07-10 00:11:53.000000000 +0000
   1.696 -+++ mpfr-3.0.0-b/VERSION	2010-09-07 08:46:06.000000000 +0000
   1.697 -@@ -1 +1 @@
   1.698 --3.0.0-p3
   1.699 -+3.0.0-p4
   1.700 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h
   1.701 ---- mpfr-3.0.0-a/mpfr.h	2010-07-10 00:11:53.000000000 +0000
   1.702 -+++ mpfr-3.0.0-b/mpfr.h	2010-09-07 08:46:06.000000000 +0000
   1.703 -@@ -27,7 +27,7 @@
   1.704 - #define MPFR_VERSION_MAJOR 3
   1.705 - #define MPFR_VERSION_MINOR 0
   1.706 - #define MPFR_VERSION_PATCHLEVEL 0
   1.707 --#define MPFR_VERSION_STRING "3.0.0-p3"
   1.708 -+#define MPFR_VERSION_STRING "3.0.0-p4"
   1.709 - 
   1.710 - /* Macros dealing with MPFR VERSION */
   1.711 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   1.712 -@@ -798,35 +798,45 @@
   1.713 -      anyway. Checking with other ICC versions is needed. Possibly detect
   1.714 -      whether warnings are produced or not with a configure test.
   1.715 -    + Remove C++ too, since it complains too much. */
   1.716 -+/* Added casts to improve robustness in case of undefined behavior and
   1.717 -+   compiler extensions based on UB (in particular -fwrapv). MPFR doesn't
   1.718 -+   use such extensions, but these macros will be used by 3rd-party code,
   1.719 -+   where such extensions may be required.
   1.720 -+   Moreover casts to unsigned long have been added to avoid warnings in
   1.721 -+   programs that use MPFR and are compiled with -Wconversion; such casts
   1.722 -+   are OK since if X is a constant expression, then (unsigned long) X is
   1.723 -+   also a constant expression, so that the optimizations still work. */
   1.724 - #if defined (__GNUC__) && !defined(__ICC) && !defined(__cplusplus)
   1.725 - #if (__GNUC__ >= 2)
   1.726 - #undef mpfr_cmp_ui
   1.727 --/* We use the fact that mpfr_sgn on NaN sets the erange flag and returns 0. */
   1.728 --#define mpfr_cmp_ui(_f,_u)                 \
   1.729 -- (__builtin_constant_p (_u) && (_u) == 0 ? \
   1.730 --   mpfr_sgn (_f) :                         \
   1.731 --   mpfr_cmp_ui_2exp ((_f),(_u),0))
   1.732 -+/* We use the fact that mpfr_sgn on NaN sets the erange flag and returns 0.
   1.733 -+   But warning! mpfr_sgn is specified as a macro in the API, thus the macro
   1.734 -+   mustn't be used if side effects are possible, like here. */
   1.735 -+#define mpfr_cmp_ui(_f,_u)                                      \
   1.736 -+  (__builtin_constant_p (_u) && (unsigned long) (_u) == 0 ?     \
   1.737 -+   (mpfr_sgn) (_f) :                                            \
   1.738 -+   mpfr_cmp_ui_2exp ((_f), (unsigned long) (_u), 0))
   1.739 - #undef mpfr_cmp_si
   1.740 --#define mpfr_cmp_si(_f,_s)                 \
   1.741 -- (__builtin_constant_p (_s) && (_s) >= 0 ? \
   1.742 --   mpfr_cmp_ui ((_f), (_s)) :              \
   1.743 --   mpfr_cmp_si_2exp ((_f), (_s), 0))
   1.744 -+#define mpfr_cmp_si(_f,_s)                              \
   1.745 -+  (__builtin_constant_p (_s) && (long) (_s) >= 0 ?      \
   1.746 -+   mpfr_cmp_ui ((_f), (unsigned long) (long) (_s)) :    \
   1.747 -+   mpfr_cmp_si_2exp ((_f), (long) (_s), 0))
   1.748 - #if __GNUC__ > 2 || __GNUC_MINOR__ >= 95
   1.749 - #undef mpfr_set_ui
   1.750 --#define mpfr_set_ui(_f,_u,_r)              \
   1.751 -- (__builtin_constant_p (_u) && (_u) == 0 ? \
   1.752 --   __extension__ ({                        \
   1.753 --     mpfr_ptr _p = (_f);                   \
   1.754 --     _p->_mpfr_sign = 1;                   \
   1.755 --     _p->_mpfr_exp = __MPFR_EXP_ZERO;      \
   1.756 --     (void) (_r); 0; }) :                  \
   1.757 --   mpfr_set_ui_2exp ((_f), (_u), 0, (_r)))
   1.758 -+#define mpfr_set_ui(_f,_u,_r)                                   \
   1.759 -+  (__builtin_constant_p (_u) && (unsigned long) (_u) == 0 ?     \
   1.760 -+   __extension__ ({                                             \
   1.761 -+       mpfr_ptr _p = (_f);                                      \
   1.762 -+       _p->_mpfr_sign = 1;                                      \
   1.763 -+       _p->_mpfr_exp = __MPFR_EXP_ZERO;                         \
   1.764 -+       (void) (_r); 0; }) :                                     \
   1.765 -+   mpfr_set_ui_2exp ((_f), (unsigned long) (_u), 0, (_r)))
   1.766 - #endif
   1.767 - #undef mpfr_set_si
   1.768 --#define mpfr_set_si(_f,_s,_r)              \
   1.769 -- (__builtin_constant_p (_s) && (_s) >= 0 ? \
   1.770 --   mpfr_set_ui ((_f), (_s), (_r)) :        \
   1.771 --   mpfr_set_si_2exp ((_f), (_s), 0, (_r)))
   1.772 -+#define mpfr_set_si(_f,_s,_r)                                   \
   1.773 -+  (__builtin_constant_p (_s) && (long) (_s) >= 0 ?              \
   1.774 -+   mpfr_set_ui ((_f), (unsigned long) (long) (_s), (_r)) :      \
   1.775 -+   mpfr_set_si_2exp ((_f), (long) (_s), 0, (_r)))
   1.776 - #endif
   1.777 - #endif
   1.778 - 
   1.779 -diff -Naurd mpfr-3.0.0-a/tests/tcmp_ui.c mpfr-3.0.0-b/tests/tcmp_ui.c
   1.780 ---- mpfr-3.0.0-a/tests/tcmp_ui.c	2010-06-10 11:00:13.000000000 +0000
   1.781 -+++ mpfr-3.0.0-b/tests/tcmp_ui.c	2010-09-07 08:45:12.000000000 +0000
   1.782 -@@ -88,6 +88,126 @@
   1.783 -   mpfr_clear (x);
   1.784 - }
   1.785 - 
   1.786 -+/* Since mpfr_cmp_ui and mpfr_cmp_si are also implemented by a macro
   1.787 -+   with __builtin_constant_p for GCC, check that side effects are
   1.788 -+   handled correctly. */
   1.789 -+static void
   1.790 -+check_macros (void)
   1.791 -+{
   1.792 -+  mpfr_t x;
   1.793 -+  int c;
   1.794 -+
   1.795 -+  mpfr_init2 (x, 32);
   1.796 -+
   1.797 -+  c = 0;
   1.798 -+  mpfr_set_ui (x, 17, MPFR_RNDN);
   1.799 -+  if (mpfr_cmp_ui (x, 17) != 0)
   1.800 -+    {
   1.801 -+      printf ("Error 1 on mpfr_cmp_ui(x,17) in check_macros\n");
   1.802 -+      exit (1);
   1.803 -+    }
   1.804 -+  if (mpfr_cmp_ui (x, (c++, 17)) != 0)
   1.805 -+    {
   1.806 -+      printf ("Error 2 on mpfr_cmp_ui(x,17) in check_macros\n");
   1.807 -+      exit (1);
   1.808 -+    }
   1.809 -+  if (c != 1)
   1.810 -+    {
   1.811 -+      printf ("Error 3 on mpfr_cmp_ui(x,17) in check_macros\n"
   1.812 -+              "(c = %d instead of 1)\n", c);
   1.813 -+      exit (1);
   1.814 -+    }
   1.815 -+  if (mpfr_cmp_si (x, 17) != 0)
   1.816 -+    {
   1.817 -+      printf ("Error 1 on mpfr_cmp_si(x,17) in check_macros\n");
   1.818 -+      exit (1);
   1.819 -+    }
   1.820 -+  if (mpfr_cmp_si (x, (c++, 17)) != 0)
   1.821 -+    {
   1.822 -+      printf ("Error 2 on mpfr_cmp_si(x,17) in check_macros\n");
   1.823 -+      exit (1);
   1.824 -+    }
   1.825 -+  if (c != 2)
   1.826 -+    {
   1.827 -+      printf ("Error 3 on mpfr_cmp_si(x,17) in check_macros\n"
   1.828 -+              "(c = %d instead of 2)\n", c);
   1.829 -+      exit (1);
   1.830 -+    }
   1.831 -+
   1.832 -+  c = 0;
   1.833 -+  mpfr_set_ui (x, 0, MPFR_RNDN);
   1.834 -+  if (mpfr_cmp_ui (x, 0) != 0)
   1.835 -+    {
   1.836 -+      printf ("Error 1 on mpfr_cmp_ui(x,0) in check_macros\n");
   1.837 -+      exit (1);
   1.838 -+    }
   1.839 -+  if (mpfr_cmp_ui (x, (c++, 0)) != 0)
   1.840 -+    {
   1.841 -+      printf ("Error 2 on mpfr_cmp_ui(x,0) in check_macros\n");
   1.842 -+      exit (1);
   1.843 -+    }
   1.844 -+  if (c != 1)
   1.845 -+    {
   1.846 -+      printf ("Error 3 on mpfr_cmp_ui(x,0) in check_macros\n"
   1.847 -+              "(c = %d instead of 1)\n", c);
   1.848 -+      exit (1);
   1.849 -+    }
   1.850 -+  if (mpfr_cmp_si (x, 0) != 0)
   1.851 -+    {
   1.852 -+      printf ("Error 1 on mpfr_cmp_si(x,0) in check_macros\n");
   1.853 -+      exit (1);
   1.854 -+    }
   1.855 -+  if (mpfr_cmp_si (x, (c++, 0)) != 0)
   1.856 -+    {
   1.857 -+      printf ("Error 2 on mpfr_cmp_si(x,0) in check_macros\n");
   1.858 -+      exit (1);
   1.859 -+    }
   1.860 -+  if (c != 2)
   1.861 -+    {
   1.862 -+      printf ("Error 3 on mpfr_cmp_si(x,0) in check_macros\n"
   1.863 -+              "(c = %d instead of 2)\n", c);
   1.864 -+      exit (1);
   1.865 -+    }
   1.866 -+
   1.867 -+  mpfr_clear (x);
   1.868 -+}
   1.869 -+
   1.870 -+/* Bug in r7114 */
   1.871 -+static void
   1.872 -+test_macros (void)
   1.873 -+{
   1.874 -+  mpfr_t x[3];
   1.875 -+  mpfr_ptr p;
   1.876 -+
   1.877 -+  mpfr_inits (x[0], x[1], x[2], (mpfr_ptr) 0);
   1.878 -+  mpfr_set_ui (x[0], 0, MPFR_RNDN);
   1.879 -+  p = x[0];
   1.880 -+  if (mpfr_cmp_ui (p++, 0) != 0)
   1.881 -+    {
   1.882 -+      printf ("Error in mpfr_cmp_ui macro: result should be 0.\n");
   1.883 -+      exit (1);
   1.884 -+    }
   1.885 -+  if (p != x[1])
   1.886 -+    {
   1.887 -+      printf ("Error in mpfr_cmp_ui macro: p - x[0] = %d (expecting 1)\n",
   1.888 -+              (int) (p - x[0]));
   1.889 -+      exit (1);
   1.890 -+    }
   1.891 -+  p = x[0];
   1.892 -+  if (mpfr_cmp_si (p++, 0) != 0)
   1.893 -+    {
   1.894 -+      printf ("Error in mpfr_cmp_si macro: result should be 0.\n");
   1.895 -+      exit (1);
   1.896 -+    }
   1.897 -+  if (p != x[1])
   1.898 -+    {
   1.899 -+      printf ("Error in mpfr_cmp_si macro: p - x[0] = %d (expecting 1)\n",
   1.900 -+              (int) (p - x[0]));
   1.901 -+      exit (1);
   1.902 -+    }
   1.903 -+  mpfr_clears (x[0], x[1], x[2], (mpfr_ptr) 0);
   1.904 -+}
   1.905 -+
   1.906 - int
   1.907 - main (void)
   1.908 - {
   1.909 -@@ -216,6 +336,8 @@
   1.910 -   mpfr_clear (x);
   1.911 - 
   1.912 -   check_nan ();
   1.913 -+  check_macros ();
   1.914 -+  test_macros ();
   1.915 - 
   1.916 -   tests_end_mpfr ();
   1.917 -   return 0;
   1.918 -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c
   1.919 ---- mpfr-3.0.0-a/version.c	2010-07-10 00:11:53.000000000 +0000
   1.920 -+++ mpfr-3.0.0-b/version.c	2010-09-07 08:46:06.000000000 +0000
   1.921 -@@ -25,5 +25,5 @@
   1.922 - const char *
   1.923 - mpfr_get_version (void)
   1.924 - {
   1.925 --  return "3.0.0-p3";
   1.926 -+  return "3.0.0-p4";
   1.927 - }
   1.928 -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES
   1.929 ---- mpfr-3.0.0-a/PATCHES	2010-10-21 20:28:38.000000000 +0000
   1.930 -+++ mpfr-3.0.0-b/PATCHES	2010-10-21 20:28:38.000000000 +0000
   1.931 -@@ -0,0 +1 @@
   1.932 -+tcan_round
   1.933 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION
   1.934 ---- mpfr-3.0.0-a/VERSION	2010-09-07 08:46:06.000000000 +0000
   1.935 -+++ mpfr-3.0.0-b/VERSION	2010-10-21 20:28:38.000000000 +0000
   1.936 -@@ -1 +1 @@
   1.937 --3.0.0-p4
   1.938 -+3.0.0-p5
   1.939 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h
   1.940 ---- mpfr-3.0.0-a/mpfr.h	2010-09-07 08:46:06.000000000 +0000
   1.941 -+++ mpfr-3.0.0-b/mpfr.h	2010-10-21 20:28:38.000000000 +0000
   1.942 -@@ -27,7 +27,7 @@
   1.943 - #define MPFR_VERSION_MAJOR 3
   1.944 - #define MPFR_VERSION_MINOR 0
   1.945 - #define MPFR_VERSION_PATCHLEVEL 0
   1.946 --#define MPFR_VERSION_STRING "3.0.0-p4"
   1.947 -+#define MPFR_VERSION_STRING "3.0.0-p5"
   1.948 - 
   1.949 - /* Macros dealing with MPFR VERSION */
   1.950 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   1.951 -diff -Naurd mpfr-3.0.0-a/tests/tcan_round.c mpfr-3.0.0-b/tests/tcan_round.c
   1.952 ---- mpfr-3.0.0-a/tests/tcan_round.c	2010-06-10 11:00:13.000000000 +0000
   1.953 -+++ mpfr-3.0.0-b/tests/tcan_round.c	2010-10-21 20:28:38.000000000 +0000
   1.954 -@@ -41,7 +41,7 @@
   1.955 -       /* avoid mpn_random which leaks memory */
   1.956 -       for (i = 0; i < n; i++)
   1.957 -         buf[i] = randlimb ();
   1.958 --      p = (mpfr_prec_t) randlimb() % ((n-1) * GMP_NUMB_BITS) + MPFR_PREC_MIN;
   1.959 -+      p = randlimb() % ((n-1) * GMP_NUMB_BITS) + MPFR_PREC_MIN;
   1.960 -       err = p + randlimb () % GMP_NUMB_BITS;
   1.961 -       r1 = mpfr_round_p (buf, n, err, p);
   1.962 -       r2 = mpfr_can_round_raw (buf, n, MPFR_SIGN_POS, err,
   1.963 -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c
   1.964 ---- mpfr-3.0.0-a/version.c	2010-09-07 08:46:06.000000000 +0000
   1.965 -+++ mpfr-3.0.0-b/version.c	2010-10-21 20:28:38.000000000 +0000
   1.966 -@@ -25,5 +25,5 @@
   1.967 - const char *
   1.968 - mpfr_get_version (void)
   1.969 - {
   1.970 --  return "3.0.0-p4";
   1.971 -+  return "3.0.0-p5";
   1.972 - }
   1.973 -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES
   1.974 ---- mpfr-3.0.0-a/PATCHES	2010-10-21 20:59:32.000000000 +0000
   1.975 -+++ mpfr-3.0.0-b/PATCHES	2010-10-21 20:59:32.000000000 +0000
   1.976 -@@ -0,0 +1 @@
   1.977 -+mpfr_sub1
   1.978 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION
   1.979 ---- mpfr-3.0.0-a/VERSION	2010-10-21 20:28:38.000000000 +0000
   1.980 -+++ mpfr-3.0.0-b/VERSION	2010-10-21 20:59:32.000000000 +0000
   1.981 -@@ -1 +1 @@
   1.982 --3.0.0-p5
   1.983 -+3.0.0-p6
   1.984 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h
   1.985 ---- mpfr-3.0.0-a/mpfr.h	2010-10-21 20:28:38.000000000 +0000
   1.986 -+++ mpfr-3.0.0-b/mpfr.h	2010-10-21 20:59:32.000000000 +0000
   1.987 -@@ -27,7 +27,7 @@
   1.988 - #define MPFR_VERSION_MAJOR 3
   1.989 - #define MPFR_VERSION_MINOR 0
   1.990 - #define MPFR_VERSION_PATCHLEVEL 0
   1.991 --#define MPFR_VERSION_STRING "3.0.0-p5"
   1.992 -+#define MPFR_VERSION_STRING "3.0.0-p6"
   1.993 - 
   1.994 - /* Macros dealing with MPFR VERSION */
   1.995 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   1.996 -diff -Naurd mpfr-3.0.0-a/sub1.c mpfr-3.0.0-b/sub1.c
   1.997 ---- mpfr-3.0.0-a/sub1.c	2010-06-10 11:00:14.000000000 +0000
   1.998 -+++ mpfr-3.0.0-b/sub1.c	2010-10-21 20:59:32.000000000 +0000
   1.999 -@@ -37,7 +37,9 @@
  1.1000 -   mp_size_t cancel2, an, bn, cn, cn0;
  1.1001 -   mp_limb_t *ap, *bp, *cp;
  1.1002 -   mp_limb_t carry, bb, cc, borrow = 0;
  1.1003 --  int inexact, shift_b, shift_c, is_exact = 1, down = 0, add_exp = 0;
  1.1004 -+  int inexact, shift_b, shift_c, add_exp = 0;
  1.1005 -+  int cmp_low = 0; /* used for rounding to nearest: 0 if low(b) = low(c),
  1.1006 -+                      negative if low(b) < low(c), positive if low(b)>low(c) */
  1.1007 -   int sh, k;
  1.1008 -   MPFR_TMP_DECL(marker);
  1.1009 - 
  1.1010 -@@ -196,7 +198,8 @@
  1.1011 -     }
  1.1012 - 
  1.1013 - #ifdef DEBUG
  1.1014 --  printf ("shift_b=%d shift_c=%d diffexp=%lu\n", shift_b, shift_c,
  1.1015 -+  printf ("rnd=%s shift_b=%d shift_c=%d diffexp=%lu\n",
  1.1016 -+          mpfr_print_rnd_mode (rnd_mode), shift_b, shift_c,
  1.1017 -           (unsigned long) diff_exp);
  1.1018 - #endif
  1.1019 - 
  1.1020 -@@ -307,17 +310,18 @@
  1.1021 -     {
  1.1022 -       if (MPFR_LIKELY(sh))
  1.1023 -         {
  1.1024 --          is_exact = (carry == 0);
  1.1025 -           /* can decide except when carry = 2^(sh-1) [middle]
  1.1026 -              or carry = 0 [truncate, but cannot decide inexact flag] */
  1.1027 --          down = (carry < (MPFR_LIMB_ONE << (sh - 1)));
  1.1028 -           if (carry > (MPFR_LIMB_ONE << (sh - 1)))
  1.1029 -             goto add_one_ulp;
  1.1030 --          else if ((0 < carry) && down)
  1.1031 -+          else if ((0 < carry) && (carry < (MPFR_LIMB_ONE << (sh - 1))))
  1.1032 -             {
  1.1033 -               inexact = -1; /* result if smaller than exact value */
  1.1034 -               goto truncate;
  1.1035 -             }
  1.1036 -+          /* now carry = 2^(sh-1), in which case cmp_low=2,
  1.1037 -+             or carry = 0, in which case cmp_low=0 */
  1.1038 -+          cmp_low = (carry == 0) ? 0 : 2;
  1.1039 -         }
  1.1040 -     }
  1.1041 -   else /* directed rounding: set rnd_mode to RNDZ iff toward zero */
  1.1042 -@@ -344,12 +348,32 @@
  1.1043 -   cn -= (long int) an + cancel2;
  1.1044 - 
  1.1045 - #ifdef DEBUG
  1.1046 --  printf ("last %d bits from a are %lu, bn=%ld, cn=%ld\n",
  1.1047 -+  printf ("last sh=%d bits from a are %lu, bn=%ld, cn=%ld\n",
  1.1048 -           sh, (unsigned long) carry, (long) bn, (long) cn);
  1.1049 - #endif
  1.1050 - 
  1.1051 -+  /* for rounding to nearest, we couldn't conclude up to here in the following
  1.1052 -+     cases:
  1.1053 -+     1. sh = 0, then cmp_low=0: we can either truncate, subtract one ulp
  1.1054 -+        or add one ulp: -1 ulp < low(b)-low(c) < 1 ulp
  1.1055 -+     2. sh > 0 but the low sh bits from high(b)-high(c) equal 2^(sh-1):
  1.1056 -+        -0.5 ulp <= -1/2^sh < low(b)-low(c)-0.5 < 1/2^sh <= 0.5 ulp
  1.1057 -+        we can't decide the rounding, in that case cmp_low=2:
  1.1058 -+        either we truncate and flag=-1, or we add one ulp and flag=1
  1.1059 -+     3. the low sh>0 bits from high(b)-high(c) equal 0: we know we have to
  1.1060 -+        truncate but we can't decide the ternary value, here cmp_low=0:
  1.1061 -+        -0.5 ulp <= -1/2^sh < low(b)-low(c) < 1/2^sh <= 0.5 ulp
  1.1062 -+        we always truncate and inexact can be any of -1,0,1
  1.1063 -+  */
  1.1064 -+
  1.1065 -+  /* note: here cn might exceed cn0, in which case we consider a zero limb */
  1.1066 -   for (k = 0; (bn > 0) || (cn > 0); k = 1)
  1.1067 -     {
  1.1068 -+      /* if cmp_low < 0, we know low(b) - low(c) < 0
  1.1069 -+         if cmp_low > 0, we know low(b) - low(c) > 0
  1.1070 -+            (more precisely if cmp_low = 2, low(b) - low(c) = 0.5 ulp so far)
  1.1071 -+         if cmp_low = 0, so far low(b) - low(c) = 0 */
  1.1072 -+
  1.1073 -       /* get next limbs */
  1.1074 -       bb = (bn > 0) ? bp[--bn] : 0;
  1.1075 -       if ((cn > 0) && (cn-- <= cn0))
  1.1076 -@@ -357,76 +381,115 @@
  1.1077 -       else
  1.1078 -         cc = 0;
  1.1079 - 
  1.1080 --      /* down is set when low(b) < low(c) */
  1.1081 --      if (down == 0)
  1.1082 --        down = (bb < cc);
  1.1083 -+      /* cmp_low compares low(b) and low(c) */
  1.1084 -+      if (cmp_low == 0) /* case 1 or 3 */
  1.1085 -+        cmp_low = (bb < cc) ? -2+k : (bb > cc) ? 1 : 0;
  1.1086 -+
  1.1087 -+      /* Case 1 for k=0 splits into 7 subcases:
  1.1088 -+         1a: bb > cc + half
  1.1089 -+         1b: bb = cc + half
  1.1090 -+         1c: 0 < bb - cc < half
  1.1091 -+         1d: bb = cc
  1.1092 -+         1e: -half < bb - cc < 0
  1.1093 -+         1f: bb - cc = -half
  1.1094 -+         1g: bb - cc < -half
  1.1095 -+
  1.1096 -+         Case 2 splits into 3 subcases:
  1.1097 -+         2a: bb > cc
  1.1098 -+         2b: bb = cc
  1.1099 -+         2c: bb < cc
  1.1100 -+
  1.1101 -+         Case 3 splits into 3 subcases:
  1.1102 -+         3a: bb > cc
  1.1103 -+         3b: bb = cc
  1.1104 -+         3c: bb < cc
  1.1105 -+      */
  1.1106 - 
  1.1107 -       /* the case rounding to nearest with sh=0 is special since one couldn't
  1.1108 -          subtract above 1/2 ulp in the trailing limb of the result */
  1.1109 --      if ((rnd_mode == MPFR_RNDN) && sh == 0 && k == 0)
  1.1110 -+      if (rnd_mode == MPFR_RNDN && sh == 0 && k == 0) /* case 1 for k=0 */
  1.1111 -         {
  1.1112 -           mp_limb_t half = MPFR_LIMB_HIGHBIT;
  1.1113 - 
  1.1114 --          is_exact = (bb == cc);
  1.1115 --
  1.1116 -           /* add one ulp if bb > cc + half
  1.1117 -              truncate if cc - half < bb < cc + half
  1.1118 -              sub one ulp if bb < cc - half
  1.1119 -           */
  1.1120 - 
  1.1121 --          if (down)
  1.1122 -+          if (cmp_low < 0) /* bb < cc: -1 ulp < low(b) - low(c) < 0,
  1.1123 -+                              cases 1e, 1f and 1g */
  1.1124 -             {
  1.1125 -               if (cc >= half)
  1.1126 -                 cc -= half;
  1.1127 --              else
  1.1128 -+              else /* since bb < cc < half, bb+half < 2*half */
  1.1129 -                 bb += half;
  1.1130 -+              /* now we have bb < cc + half:
  1.1131 -+                 we have to subtract one ulp if bb < cc,
  1.1132 -+                 and truncate if bb > cc */
  1.1133 -             }
  1.1134 --          else /* bb >= cc */
  1.1135 -+          else if (cmp_low >= 0) /* bb >= cc, cases 1a to 1d */
  1.1136 -             {
  1.1137 -               if (cc < half)
  1.1138 -                 cc += half;
  1.1139 --              else
  1.1140 -+              else /* since bb >= cc >= half, bb - half >= 0 */
  1.1141 -                 bb -= half;
  1.1142 -+              /* now we have bb > cc - half: we have to add one ulp if bb > cc,
  1.1143 -+                 and truncate if bb < cc */
  1.1144 -+              if (cmp_low > 0)
  1.1145 -+                cmp_low = 2;
  1.1146 -             }
  1.1147 -         }
  1.1148 - 
  1.1149 - #ifdef DEBUG
  1.1150 --      printf ("    bb=%lu cc=%lu down=%d is_exact=%d\n",
  1.1151 --              (unsigned long) bb, (unsigned long) cc, down, is_exact);
  1.1152 -+      printf ("k=%u bb=%lu cc=%lu cmp_low=%d\n", k,
  1.1153 -+              (unsigned long) bb, (unsigned long) cc, cmp_low);
  1.1154 - #endif
  1.1155 --      if (bb < cc)
  1.1156 -+      if (cmp_low < 0) /* low(b) - low(c) < 0: either truncate or subtract
  1.1157 -+                          one ulp */
  1.1158 -         {
  1.1159 -           if (rnd_mode == MPFR_RNDZ)
  1.1160 --            goto sub_one_ulp;
  1.1161 -+            goto sub_one_ulp; /* set inexact=-1 */
  1.1162 -           else if (rnd_mode != MPFR_RNDN) /* round away */
  1.1163 -             {
  1.1164 -               inexact = 1;
  1.1165 -               goto truncate;
  1.1166 -             }
  1.1167 --          else /* round to nearest: special case here since for sh=k=0
  1.1168 --                  bb = bb0 - MPFR_LIMB_HIGHBIT */
  1.1169 -+          else /* round to nearest */
  1.1170 -             {
  1.1171 --              if (is_exact && sh == 0)
  1.1172 --                {
  1.1173 --                  /* For k=0 we can't decide exactness since it may depend
  1.1174 --                     from low order bits.
  1.1175 --                     For k=1, the first low limbs matched: low(b)-low(c)<0. */
  1.1176 --                  if (k)
  1.1177 --                    {
  1.1178 --                      inexact = 1;
  1.1179 --                      goto truncate;
  1.1180 --                    }
  1.1181 --                }
  1.1182 --              else if (down && sh == 0)
  1.1183 --                goto sub_one_ulp;
  1.1184 --              else
  1.1185 --                {
  1.1186 --                  inexact = (is_exact) ? 1 : -1;
  1.1187 -+              /* If cmp_low < 0 and bb > cc, then -0.5 ulp < low(b)-low(c) < 0,
  1.1188 -+                 whatever the value of sh.
  1.1189 -+                 If sh>0, then cmp_low < 0 implies that the initial neglected
  1.1190 -+                 sh bits were 0 (otherwise cmp_low=2 initially), thus the
  1.1191 -+                 weight of the new bits is less than 0.5 ulp too.
  1.1192 -+                 If k > 0 (and sh=0) this means that either the first neglected
  1.1193 -+                 limbs bb and cc were equal (thus cmp_low was 0 for k=0),
  1.1194 -+                 or we had bb - cc = -0.5 ulp or 0.5 ulp.
  1.1195 -+                 The last case is not possible here since we would have
  1.1196 -+                 cmp_low > 0 which is sticky.
  1.1197 -+                 In the first case (where we have cmp_low = -1), we truncate,
  1.1198 -+                 whereas in the 2nd case we have cmp_low = -2 and we subtract
  1.1199 -+                 one ulp.
  1.1200 -+              */
  1.1201 -+              if (bb > cc || sh > 0 || cmp_low == -1)
  1.1202 -+                {  /* -0.5 ulp < low(b)-low(c) < 0,
  1.1203 -+                      bb > cc corresponds to cases 1e and 1f1
  1.1204 -+                      sh > 0 corresponds to cases 3c and 3b3
  1.1205 -+                      cmp_low = -1 corresponds to case 1d3 (also 3b3) */
  1.1206 -+                  inexact = 1;
  1.1207 -                   goto truncate;
  1.1208 -                 }
  1.1209 -+              else if (bb < cc) /* here sh = 0 and low(b)-low(c) < -0.5 ulp,
  1.1210 -+                                   this corresponds to cases 1g and 1f3 */
  1.1211 -+                goto sub_one_ulp;
  1.1212 -+              /* the only case where we can't conclude is sh=0 and bb=cc,
  1.1213 -+                 i.e., we have low(b) - low(c) = -0.5 ulp (up to now), thus
  1.1214 -+                 we don't know if we must truncate or subtract one ulp.
  1.1215 -+                 Note: for sh=0 we can't have low(b) - low(c) = -0.5 ulp up to
  1.1216 -+                 now, since low(b) - low(c) > 1/2^sh */
  1.1217 -             }
  1.1218 -         }
  1.1219 --      else if (bb > cc)
  1.1220 -+      else if (cmp_low > 0) /* 0 < low(b) - low(c): either truncate or
  1.1221 -+                               add one ulp */
  1.1222 -         {
  1.1223 -           if (rnd_mode == MPFR_RNDZ)
  1.1224 -             {
  1.1225 -@@ -437,34 +500,70 @@
  1.1226 -             goto add_one_ulp;
  1.1227 -           else /* round to nearest */
  1.1228 -             {
  1.1229 --              if (is_exact)
  1.1230 -+              if (bb > cc)
  1.1231 -                 {
  1.1232 --                  inexact = -1;
  1.1233 --                  goto truncate;
  1.1234 -+                  /* if sh=0, then bb>cc means that low(b)-low(c) > 0.5 ulp,
  1.1235 -+                     and similarly when cmp_low=2 */
  1.1236 -+                  if (cmp_low == 2) /* cases 1a, 1b1, 2a and 2b1 */
  1.1237 -+                    goto add_one_ulp;
  1.1238 -+                  /* sh > 0 and cmp_low > 0: this implies that the sh initial
  1.1239 -+                     neglected bits were 0, and the remaining low(b)-low(c)>0,
  1.1240 -+                     but its weight is less than 0.5 ulp */
  1.1241 -+                  else /* 0 < low(b) - low(c) < 0.5 ulp, this corresponds to
  1.1242 -+                          cases 3a, 1d1 and 3b1 */
  1.1243 -+                    {
  1.1244 -+                      inexact = -1;
  1.1245 -+                      goto truncate;
  1.1246 -+                    }
  1.1247 -                 }
  1.1248 --              else if (down)
  1.1249 -+              else if (bb < cc) /* 0 < low(b) - low(c) < 0.5 ulp, cases 1c,
  1.1250 -+                                   1b3, 2b3 and 2c */
  1.1251 -                 {
  1.1252 --                  inexact = 1;
  1.1253 -+                  inexact = -1;
  1.1254 -                   goto truncate;
  1.1255 -                 }
  1.1256 --              else
  1.1257 --                goto add_one_ulp;
  1.1258 -+              /* the only case where we can't conclude is bb=cc, i.e.,
  1.1259 -+                 low(b) - low(c) = 0.5 ulp (up to now), thus we don't know
  1.1260 -+                 if we must truncate or add one ulp. */
  1.1261 -             }
  1.1262 -         }
  1.1263 -+      /* after k=0, we cannot conclude in the following cases, we split them
  1.1264 -+         according to the values of bb and cc for k=1:
  1.1265 -+         1b. sh=0 and cmp_low = 1 and bb-cc = half [around 0.5 ulp]
  1.1266 -+             1b1. bb > cc: add one ulp, inex = 1
  1.1267 -+             1b2: bb = cc: cannot conclude
  1.1268 -+             1b3: bb < cc: truncate, inex = -1
  1.1269 -+         1d. sh=0 and cmp_low = 0 and bb-cc = 0 [around 0]
  1.1270 -+             1d1: bb > cc: truncate, inex = -1
  1.1271 -+             1d2: bb = cc: cannot conclude
  1.1272 -+             1d3: bb < cc: truncate, inex = +1
  1.1273 -+         1f. sh=0 and cmp_low = -1 and bb-cc = -half [around -0.5 ulp]
  1.1274 -+             1f1: bb > cc: truncate, inex = +1
  1.1275 -+             1f2: bb = cc: cannot conclude
  1.1276 -+             1f3: bb < cc: sub one ulp, inex = -1
  1.1277 -+         2b. sh > 0 and cmp_low = 2 and bb=cc [around 0.5 ulp]
  1.1278 -+             2b1. bb > cc: add one ulp, inex = 1
  1.1279 -+             2b2: bb = cc: cannot conclude
  1.1280 -+             2b3: bb < cc: truncate, inex = -1
  1.1281 -+         3b. sh > 0 and cmp_low = 0 [around 0]
  1.1282 -+             3b1. bb > cc: truncate, inex = -1
  1.1283 -+             3b2: bb = cc: cannot conclude
  1.1284 -+             3b3: bb < cc: truncate, inex = +1
  1.1285 -+      */
  1.1286 -     }
  1.1287 - 
  1.1288 --  if ((rnd_mode == MPFR_RNDN) && !is_exact)
  1.1289 -+  if ((rnd_mode == MPFR_RNDN) && cmp_low != 0)
  1.1290 -     {
  1.1291 -       /* even rounding rule */
  1.1292 -       if ((ap[0] >> sh) & 1)
  1.1293 -         {
  1.1294 --          if (down)
  1.1295 -+          if (cmp_low < 0)
  1.1296 -             goto sub_one_ulp;
  1.1297 -           else
  1.1298 -             goto add_one_ulp;
  1.1299 -         }
  1.1300 -       else
  1.1301 --        inexact = (down) ? 1 : -1;
  1.1302 -+        inexact = (cmp_low > 0) ? -1 : 1;
  1.1303 -     }
  1.1304 -   else
  1.1305 -     inexact = 0;
  1.1306 -diff -Naurd mpfr-3.0.0-a/tests/tfma.c mpfr-3.0.0-b/tests/tfma.c
  1.1307 ---- mpfr-3.0.0-a/tests/tfma.c	2010-06-10 11:00:13.000000000 +0000
  1.1308 -+++ mpfr-3.0.0-b/tests/tfma.c	2010-10-21 20:59:32.000000000 +0000
  1.1309 -@@ -337,6 +337,94 @@
  1.1310 -   mpfr_clears (x, y, z, r, (mpfr_ptr) 0);
  1.1311 - }
  1.1312 - 
  1.1313 -+static void
  1.1314 -+bug20101018 (void)
  1.1315 -+{
  1.1316 -+  mpfr_t x, y, z, t, u;
  1.1317 -+  int i;
  1.1318 -+
  1.1319 -+  mpfr_init2 (x, 64);
  1.1320 -+  mpfr_init2 (y, 64);
  1.1321 -+  mpfr_init2 (z, 64);
  1.1322 -+  mpfr_init2 (t, 64);
  1.1323 -+  mpfr_init2 (u, 64);
  1.1324 -+
  1.1325 -+  mpfr_set_str (x, "0xf.fffffffffffffffp-14766", 16, MPFR_RNDN);
  1.1326 -+  mpfr_set_str (y, "-0xf.fffffffffffffffp+317", 16, MPFR_RNDN);
  1.1327 -+  mpfr_set_str (z, "0x8.3ffffffffffe3ffp-14443", 16, MPFR_RNDN);
  1.1328 -+  mpfr_set_str (t, "0x8.7ffffffffffc7ffp-14444", 16, MPFR_RNDN);
  1.1329 -+  i = mpfr_fma (u, x, y, z, MPFR_RNDN);
  1.1330 -+  if (mpfr_cmp (u, t) != 0)
  1.1331 -+    {
  1.1332 -+      printf ("Wrong result in bug20101018 (a)\n");
  1.1333 -+      printf ("Expected ");
  1.1334 -+      mpfr_out_str (stdout, 16, 0, t, MPFR_RNDN);
  1.1335 -+      printf ("\nGot      ");
  1.1336 -+      mpfr_out_str (stdout, 16, 0, u, MPFR_RNDN);
  1.1337 -+      printf ("\n");
  1.1338 -+      exit (1);
  1.1339 -+    }
  1.1340 -+  if (i <= 0)
  1.1341 -+    {
  1.1342 -+      printf ("Wrong ternary value in bug20101018 (a)\n");
  1.1343 -+      printf ("Expected > 0\n");
  1.1344 -+      printf ("Got      %d\n", i);
  1.1345 -+      exit (1);
  1.1346 -+    }
  1.1347 -+
  1.1348 -+  mpfr_set_str (x, "-0xf.fffffffffffffffp-11420", 16, MPFR_RNDN);
  1.1349 -+  mpfr_set_str (y, "0xf.fffffffffffffffp+9863", 16, MPFR_RNDN);
  1.1350 -+  mpfr_set_str (z, "0x8.fffff80ffffffffp-1551", 16, MPFR_RNDN);
  1.1351 -+  mpfr_set_str (t, "0x9.fffff01ffffffffp-1552", 16, MPFR_RNDN);
  1.1352 -+  i = mpfr_fma (u, x, y, z, MPFR_RNDN);
  1.1353 -+  if (mpfr_cmp (u, t) != 0)
  1.1354 -+    {
  1.1355 -+      printf ("Wrong result in bug20101018 (b)\n");
  1.1356 -+      printf ("Expected ");
  1.1357 -+      mpfr_out_str (stdout, 16, 0, t, MPFR_RNDN);
  1.1358 -+      printf ("\nGot      ");
  1.1359 -+      mpfr_out_str (stdout, 16, 0, u, MPFR_RNDN);
  1.1360 -+      printf ("\n");
  1.1361 -+      exit (1);
  1.1362 -+    }
  1.1363 -+  if (i <= 0)
  1.1364 -+    {
  1.1365 -+      printf ("Wrong ternary value in bug20101018 (b)\n");
  1.1366 -+      printf ("Expected > 0\n");
  1.1367 -+      printf ("Got      %d\n", i);
  1.1368 -+      exit (1);
  1.1369 -+    }
  1.1370 -+
  1.1371 -+  mpfr_set_str (x, "0xf.fffffffffffffffp-2125", 16, MPFR_RNDN);
  1.1372 -+  mpfr_set_str (y, "-0xf.fffffffffffffffp-6000", 16, MPFR_RNDN);
  1.1373 -+  mpfr_set_str (z, "0x8p-8119", 16, MPFR_RNDN);
  1.1374 -+  mpfr_set_str (t, "0x8.000000000000001p-8120", 16, MPFR_RNDN);
  1.1375 -+  i = mpfr_fma (u, x, y, z, MPFR_RNDN);
  1.1376 -+  if (mpfr_cmp (u, t) != 0)
  1.1377 -+    {
  1.1378 -+      printf ("Wrong result in bug20101018 (c)\n");
  1.1379 -+      printf ("Expected ");
  1.1380 -+      mpfr_out_str (stdout, 16, 0, t, MPFR_RNDN);
  1.1381 -+      printf ("\nGot      ");
  1.1382 -+      mpfr_out_str (stdout, 16, 0, u, MPFR_RNDN);
  1.1383 -+      printf ("\n");
  1.1384 -+      exit (1);
  1.1385 -+    }
  1.1386 -+  if (i <= 0)
  1.1387 -+    {
  1.1388 -+      printf ("Wrong ternary value in bug20101018 (c)\n");
  1.1389 -+      printf ("Expected > 0\n");
  1.1390 -+      printf ("Got      %d\n", i);
  1.1391 -+      exit (1);
  1.1392 -+    }
  1.1393 -+
  1.1394 -+  mpfr_clear (x);
  1.1395 -+  mpfr_clear (y);
  1.1396 -+  mpfr_clear (z);
  1.1397 -+  mpfr_clear (t);
  1.1398 -+  mpfr_clear (u);
  1.1399 -+}
  1.1400 -+
  1.1401 - int
  1.1402 - main (int argc, char *argv[])
  1.1403 - {
  1.1404 -@@ -345,6 +433,8 @@
  1.1405 - 
  1.1406 -   tests_start_mpfr ();
  1.1407 - 
  1.1408 -+  bug20101018 ();
  1.1409 -+
  1.1410 -   mpfr_init (x);
  1.1411 -   mpfr_init (s);
  1.1412 -   mpfr_init (y);
  1.1413 -diff -Naurd mpfr-3.0.0-a/tests/tsub.c mpfr-3.0.0-b/tests/tsub.c
  1.1414 ---- mpfr-3.0.0-a/tests/tsub.c	2010-06-10 11:00:13.000000000 +0000
  1.1415 -+++ mpfr-3.0.0-b/tests/tsub.c	2010-10-21 20:59:32.000000000 +0000
  1.1416 -@@ -201,6 +201,8 @@
  1.1417 -   if (mpfr_cmp (z, x))
  1.1418 -     {
  1.1419 -       printf ("Error in mpfr_sub (2)\n");
  1.1420 -+      printf ("Expected "); mpfr_print_binary (x); puts ("");
  1.1421 -+      printf ("Got      "); mpfr_print_binary (z); puts ("");
  1.1422 -       exit (1);
  1.1423 -     }
  1.1424 -   mpfr_set_str_binary (x, "1.1110111011110001110111011111111111101000011001011100101100101101");
  1.1425 -@@ -478,6 +480,156 @@
  1.1426 -   mpfr_clear (u);
  1.1427 - }
  1.1428 - 
  1.1429 -+/* Bug found by Jakub Jelinek
  1.1430 -+ * http://bugzilla.redhat.com/643657
  1.1431 -+ * https://gforge.inria.fr/tracker/index.php?func=detail&aid=11301
  1.1432 -+ * The consequence can be either an assertion failure (i = 2 in the
  1.1433 -+ * testcase below, in debug mode) or an incorrectly rounded value.
  1.1434 -+ */
  1.1435 -+static void
  1.1436 -+bug20101017 (void)
  1.1437 -+{
  1.1438 -+  mpfr_t a, b, c;
  1.1439 -+  int inex;
  1.1440 -+  int i;
  1.1441 -+
  1.1442 -+  mpfr_init2 (a, GMP_NUMB_BITS * 2);
  1.1443 -+  mpfr_init2 (b, GMP_NUMB_BITS);
  1.1444 -+  mpfr_init2 (c, GMP_NUMB_BITS);
  1.1445 -+
  1.1446 -+  /* a = 2^(2N) + k.2^(2N-1) + 2^N and b = 1
  1.1447 -+     with N = GMP_NUMB_BITS and k = 0 or 1.
  1.1448 -+     c = a - b should round to the same value as a. */
  1.1449 -+
  1.1450 -+  for (i = 2; i <= 3; i++)
  1.1451 -+    {
  1.1452 -+      mpfr_set_ui_2exp (a, i, GMP_NUMB_BITS - 1, MPFR_RNDN);
  1.1453 -+      mpfr_add_ui (a, a, 1, MPFR_RNDN);
  1.1454 -+      mpfr_mul_2ui (a, a, GMP_NUMB_BITS, MPFR_RNDN);
  1.1455 -+      mpfr_set_ui (b, 1, MPFR_RNDN);
  1.1456 -+      inex = mpfr_sub (c, a, b, MPFR_RNDN);
  1.1457 -+      mpfr_set (b, a, MPFR_RNDN);
  1.1458 -+      if (! mpfr_equal_p (c, b))
  1.1459 -+        {
  1.1460 -+          printf ("Error in bug20101017 for i = %d.\n", i);
  1.1461 -+          printf ("Expected ");
  1.1462 -+          mpfr_out_str (stdout, 16, 0, b, MPFR_RNDN);
  1.1463 -+          putchar ('\n');
  1.1464 -+          printf ("Got      ");
  1.1465 -+          mpfr_out_str (stdout, 16, 0, c, MPFR_RNDN);
  1.1466 -+          putchar ('\n');
  1.1467 -+          exit (1);
  1.1468 -+        }
  1.1469 -+      if (inex >= 0)
  1.1470 -+        {
  1.1471 -+          printf ("Error in bug20101017 for i = %d: bad inex value.\n", i);
  1.1472 -+          printf ("Expected negative, got %d.\n", inex);
  1.1473 -+          exit (1);
  1.1474 -+        }
  1.1475 -+    }
  1.1476 -+
  1.1477 -+  mpfr_set_prec (a, 64);
  1.1478 -+  mpfr_set_prec (b, 129);
  1.1479 -+  mpfr_set_prec (c, 2);
  1.1480 -+  mpfr_set_str_binary (b, "0.100000000000000000000000000000000000000000000000000000000000000010000000000000000000000000000000000000000000000000000000000000001E65");
  1.1481 -+  mpfr_set_str_binary (c, "0.10E1");
  1.1482 -+  inex = mpfr_sub (a, b, c, MPFR_RNDN);
  1.1483 -+  if (mpfr_cmp_ui_2exp (a, 1, 64) != 0 || inex >= 0)
  1.1484 -+    {
  1.1485 -+      printf ("Error in mpfr_sub for b-c for b=2^64+1+2^(-64), c=1\n");
  1.1486 -+      printf ("Expected result 2^64 with inex < 0\n");
  1.1487 -+      printf ("Got "); mpfr_print_binary (a);
  1.1488 -+      printf (" with inex=%d\n", inex);
  1.1489 -+      exit (1);
  1.1490 -+    }
  1.1491 -+
  1.1492 -+  mpfr_clears (a, b, c, (mpfr_ptr) 0);
  1.1493 -+}
  1.1494 -+
  1.1495 -+/* hard test of rounding */
  1.1496 -+static void
  1.1497 -+check_rounding (void)
  1.1498 -+{
  1.1499 -+  mpfr_t a, b, c, res;
  1.1500 -+  mpfr_prec_t p;
  1.1501 -+  long k, l;
  1.1502 -+  int i;
  1.1503 -+
  1.1504 -+#define MAXKL (2 * GMP_NUMB_BITS)
  1.1505 -+  for (p = MPFR_PREC_MIN; p <= GMP_NUMB_BITS; p++)
  1.1506 -+    {
  1.1507 -+      mpfr_init2 (a, p);
  1.1508 -+      mpfr_init2 (res, p);
  1.1509 -+      mpfr_init2 (b, p + 1 + MAXKL);
  1.1510 -+      mpfr_init2 (c, MPFR_PREC_MIN);
  1.1511 -+
  1.1512 -+      /* b = 2^p + 1 + 2^(-k), c = 2^(-l) */
  1.1513 -+      for (k = 0; k <= MAXKL; k++)
  1.1514 -+        for (l = 0; l <= MAXKL; l++)
  1.1515 -+          {
  1.1516 -+            mpfr_set_ui_2exp (b, 1, p, MPFR_RNDN);
  1.1517 -+            mpfr_add_ui (b, b, 1, MPFR_RNDN);
  1.1518 -+            mpfr_mul_2ui (b, b, k, MPFR_RNDN);
  1.1519 -+            mpfr_add_ui (b, b, 1, MPFR_RNDN);
  1.1520 -+            mpfr_div_2ui (b, b, k, MPFR_RNDN);
  1.1521 -+            mpfr_set_ui_2exp (c, 1, -l, MPFR_RNDN);
  1.1522 -+            i = mpfr_sub (a, b, c, MPFR_RNDN);
  1.1523 -+            /* b - c = 2^p + 1 + 2^(-k) - 2^(-l), should be rounded to
  1.1524 -+               2^p for l <= k, and 2^p+2 for l < k */
  1.1525 -+            if (l <= k)
  1.1526 -+              {
  1.1527 -+                if (mpfr_cmp_ui_2exp (a, 1, p) != 0)
  1.1528 -+                  {
  1.1529 -+                    printf ("Wrong result in check_rounding\n");
  1.1530 -+                    printf ("p=%lu k=%ld l=%ld\n", p, k, l);
  1.1531 -+                    printf ("b="); mpfr_print_binary (b); puts ("");
  1.1532 -+                    printf ("c="); mpfr_print_binary (c); puts ("");
  1.1533 -+                    printf ("Expected 2^%lu\n", p);
  1.1534 -+                    printf ("Got      "); mpfr_print_binary (a); puts ("");
  1.1535 -+                    exit (1);
  1.1536 -+                  }
  1.1537 -+                if (i >= 0)
  1.1538 -+                  {
  1.1539 -+                    printf ("Wrong ternary value in check_rounding\n");
  1.1540 -+                    printf ("p=%lu k=%ld l=%ld\n", p, k, l);
  1.1541 -+                    printf ("b="); mpfr_print_binary (b); puts ("");
  1.1542 -+                    printf ("c="); mpfr_print_binary (c); puts ("");
  1.1543 -+                    printf ("a="); mpfr_print_binary (a); puts ("");
  1.1544 -+                    printf ("Expected < 0, got %d\n", i);
  1.1545 -+                    exit (1);
  1.1546 -+                  }
  1.1547 -+              }
  1.1548 -+            else /* l < k */
  1.1549 -+              {
  1.1550 -+                mpfr_set_ui_2exp (res, 1, p, MPFR_RNDN);
  1.1551 -+                mpfr_add_ui (res, res, 2, MPFR_RNDN);
  1.1552 -+                if (mpfr_cmp (a, res) != 0)
  1.1553 -+                  {
  1.1554 -+                    printf ("Wrong result in check_rounding\n");
  1.1555 -+                    printf ("b="); mpfr_print_binary (b); puts ("");
  1.1556 -+                    printf ("c="); mpfr_print_binary (c); puts ("");
  1.1557 -+                    printf ("Expected "); mpfr_print_binary (res); puts ("");
  1.1558 -+                    printf ("Got      "); mpfr_print_binary (a); puts ("");
  1.1559 -+                    exit (1);
  1.1560 -+                  }
  1.1561 -+                if (i <= 0)
  1.1562 -+                  {
  1.1563 -+                    printf ("Wrong ternary value in check_rounding\n");
  1.1564 -+                    printf ("b="); mpfr_print_binary (b); puts ("");
  1.1565 -+                    printf ("c="); mpfr_print_binary (c); puts ("");
  1.1566 -+                    printf ("Expected > 0, got %d\n", i);
  1.1567 -+                    exit (1);
  1.1568 -+                  }
  1.1569 -+              }
  1.1570 -+          }
  1.1571 -+
  1.1572 -+      mpfr_clear (a);
  1.1573 -+      mpfr_clear (res);
  1.1574 -+      mpfr_clear (b);
  1.1575 -+      mpfr_clear (c);
  1.1576 -+    }
  1.1577 -+}
  1.1578 -+
  1.1579 - #define TEST_FUNCTION test_sub
  1.1580 - #define TWO_ARGS
  1.1581 - #define RAND_FUNCTION(x) mpfr_random2(x, MPFR_LIMB_SIZE (x), randlimb () % 100, RANDS)
  1.1582 -@@ -491,6 +643,8 @@
  1.1583 - 
  1.1584 -   tests_start_mpfr ();
  1.1585 - 
  1.1586 -+  bug20101017 ();
  1.1587 -+  check_rounding ();
  1.1588 -   check_diverse ();
  1.1589 -   check_inexact ();
  1.1590 -   bug_ddefour ();
  1.1591 -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c
  1.1592 ---- mpfr-3.0.0-a/version.c	2010-10-21 20:28:38.000000000 +0000
  1.1593 -+++ mpfr-3.0.0-b/version.c	2010-10-21 20:59:32.000000000 +0000
  1.1594 -@@ -25,5 +25,5 @@
  1.1595 - const char *
  1.1596 - mpfr_get_version (void)
  1.1597 - {
  1.1598 --  return "3.0.0-p5";
  1.1599 -+  return "3.0.0-p6";
  1.1600 - }
  1.1601 -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES
  1.1602 ---- mpfr-3.0.0-a/PATCHES	2010-10-21 21:18:26.000000000 +0000
  1.1603 -+++ mpfr-3.0.0-b/PATCHES	2010-10-21 21:18:26.000000000 +0000
  1.1604 -@@ -0,0 +1 @@
  1.1605 -+mpfr_set_ld
  1.1606 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION
  1.1607 ---- mpfr-3.0.0-a/VERSION	2010-10-21 20:59:32.000000000 +0000
  1.1608 -+++ mpfr-3.0.0-b/VERSION	2010-10-21 21:18:26.000000000 +0000
  1.1609 -@@ -1 +1 @@
  1.1610 --3.0.0-p6
  1.1611 -+3.0.0-p7
  1.1612 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h
  1.1613 ---- mpfr-3.0.0-a/mpfr.h	2010-10-21 20:59:32.000000000 +0000
  1.1614 -+++ mpfr-3.0.0-b/mpfr.h	2010-10-21 21:18:26.000000000 +0000
  1.1615 -@@ -27,7 +27,7 @@
  1.1616 - #define MPFR_VERSION_MAJOR 3
  1.1617 - #define MPFR_VERSION_MINOR 0
  1.1618 - #define MPFR_VERSION_PATCHLEVEL 0
  1.1619 --#define MPFR_VERSION_STRING "3.0.0-p6"
  1.1620 -+#define MPFR_VERSION_STRING "3.0.0-p7"
  1.1621 - 
  1.1622 - /* Macros dealing with MPFR VERSION */
  1.1623 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
  1.1624 -diff -Naurd mpfr-3.0.0-a/set_ld.c mpfr-3.0.0-b/set_ld.c
  1.1625 ---- mpfr-3.0.0-a/set_ld.c	2010-06-10 11:00:14.000000000 +0000
  1.1626 -+++ mpfr-3.0.0-b/set_ld.c	2010-10-21 21:18:26.000000000 +0000
  1.1627 -@@ -102,21 +102,25 @@
  1.1628 -             {
  1.1629 -               x /= div13; /* exact */
  1.1630 -               shift_exp += 8192;
  1.1631 -+              mpfr_div_2si (t, t, 8192, MPFR_RNDZ);
  1.1632 -             }
  1.1633 -           if (ABS (x) >= div12)
  1.1634 -             {
  1.1635 -               x /= div12; /* exact */
  1.1636 -               shift_exp += 4096;
  1.1637 -+              mpfr_div_2si (t, t, 4096, MPFR_RNDZ);
  1.1638 -             }
  1.1639 -           if (ABS (x) >= div11)
  1.1640 -             {
  1.1641 -               x /= div11; /* exact */
  1.1642 -               shift_exp += 2048;
  1.1643 -+              mpfr_div_2si (t, t, 2048, MPFR_RNDZ);
  1.1644 -             }
  1.1645 -           if (ABS (x) >= div10)
  1.1646 -             {
  1.1647 -               x /= div10; /* exact */
  1.1648 -               shift_exp += 1024;
  1.1649 -+              mpfr_div_2si (t, t, 1024, MPFR_RNDZ);
  1.1650 -             }
  1.1651 -           /* warning: we may have DBL_MAX=2^1024*(1-2^(-53)) < x < 2^1024,
  1.1652 -              therefore we have one extra exponent reduction step */
  1.1653 -@@ -124,9 +128,10 @@
  1.1654 -             {
  1.1655 -               x /= div9; /* exact */
  1.1656 -               shift_exp += 512;
  1.1657 -+              mpfr_div_2si (t, t, 512, MPFR_RNDZ);
  1.1658 -             }
  1.1659 -         } /* Check overflow of double */
  1.1660 --      else
  1.1661 -+      else /* no overflow on double */
  1.1662 -         {
  1.1663 -           long double div9, div10, div11;
  1.1664 - 
  1.1665 -@@ -149,29 +154,34 @@
  1.1666 -                 {
  1.1667 -                   x /= div13; /* exact */
  1.1668 -                   shift_exp -= 8192;
  1.1669 -+                  mpfr_mul_2si (t, t, 8192, MPFR_RNDZ);
  1.1670 -                 }
  1.1671 -               if (ABS (x) <= div12)
  1.1672 -                 {
  1.1673 -                   x /= div12; /* exact */
  1.1674 -                   shift_exp -= 4096;
  1.1675 -+                  mpfr_mul_2si (t, t, 4096, MPFR_RNDZ);
  1.1676 -                 }
  1.1677 -               if (ABS (x) <= div11)
  1.1678 -                 {
  1.1679 -                   x /= div11; /* exact */
  1.1680 -                   shift_exp -= 2048;
  1.1681 -+                  mpfr_mul_2si (t, t, 2048, MPFR_RNDZ);
  1.1682 -                 }
  1.1683 -               if (ABS (x) <= div10)
  1.1684 -                 {
  1.1685 -                   x /= div10; /* exact */
  1.1686 -                   shift_exp -= 1024;
  1.1687 -+                  mpfr_mul_2si (t, t, 1024, MPFR_RNDZ);
  1.1688 -                 }
  1.1689 -               if (ABS(x) <= div9)
  1.1690 -                 {
  1.1691 -                   x /= div9;  /* exact */
  1.1692 -                   shift_exp -= 512;
  1.1693 -+                  mpfr_mul_2si (t, t, 512, MPFR_RNDZ);
  1.1694 -                 }
  1.1695 -             }
  1.1696 --          else
  1.1697 -+          else /* no underflow */
  1.1698 -             {
  1.1699 -               inexact = mpfr_set_d (u, (double) x, MPFR_RNDZ);
  1.1700 -               MPFR_ASSERTD (inexact == 0);
  1.1701 -diff -Naurd mpfr-3.0.0-a/tests/tset_ld.c mpfr-3.0.0-b/tests/tset_ld.c
  1.1702 ---- mpfr-3.0.0-a/tests/tset_ld.c	2010-06-10 11:00:13.000000000 +0000
  1.1703 -+++ mpfr-3.0.0-b/tests/tset_ld.c	2010-10-21 21:18:26.000000000 +0000
  1.1704 -@@ -147,12 +147,39 @@
  1.1705 - test_fixed_bugs (void)
  1.1706 - {
  1.1707 -   mpfr_t x;
  1.1708 --  long double d;
  1.1709 -+  long double l, m;
  1.1710 - 
  1.1711 -   /* bug found by Steve Kargl (2009-03-14) */
  1.1712 -   mpfr_init2 (x, 64);
  1.1713 -   mpfr_set_ui_2exp (x, 1, -16447, MPFR_RNDN);
  1.1714 --  d = mpfr_get_ld (x, MPFR_RNDN);  /* an assertion failed in init2.c:50 */
  1.1715 -+  mpfr_get_ld (x, MPFR_RNDN);  /* an assertion failed in init2.c:50 */
  1.1716 -+
  1.1717 -+  /* bug reported by Jakub Jelinek (2010-10-17)
  1.1718 -+     https://gforge.inria.fr/tracker/?func=detail&aid=11300 */
  1.1719 -+  mpfr_set_prec (x, MPFR_LDBL_MANT_DIG);
  1.1720 -+  /* l = 0x1.23456789abcdef0123456789abcdp-914L; */
  1.1721 -+  l = 8.215640181713713164092636634579e-276;
  1.1722 -+  mpfr_set_ld (x, l, MPFR_RNDN);
  1.1723 -+  m = mpfr_get_ld (x, MPFR_RNDN);
  1.1724 -+  if (m != l)
  1.1725 -+    {
  1.1726 -+      printf ("Error in get_ld o set_ld for l=%Le\n", l);
  1.1727 -+      printf ("Got m=%Le instead of l\n", m);
  1.1728 -+      exit (1);
  1.1729 -+    }
  1.1730 -+
  1.1731 -+  /* another similar test which failed with extended double precision and the
  1.1732 -+     generic code for mpfr_set_ld */
  1.1733 -+  /* l = 0x1.23456789abcdef0123456789abcdp-968L; */
  1.1734 -+  l = 4.560596445887084662336528403703e-292;
  1.1735 -+  mpfr_set_ld (x, l, MPFR_RNDN);
  1.1736 -+  m = mpfr_get_ld (x, MPFR_RNDN);
  1.1737 -+  if (m != l)
  1.1738 -+    {
  1.1739 -+      printf ("Error in get_ld o set_ld for l=%Le\n", l);
  1.1740 -+      printf ("Got m=%Le instead of l\n", m);
  1.1741 -+      exit (1);
  1.1742 -+    }
  1.1743 - 
  1.1744 -   mpfr_clear (x);
  1.1745 - }
  1.1746 -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c
  1.1747 ---- mpfr-3.0.0-a/version.c	2010-10-21 20:59:32.000000000 +0000
  1.1748 -+++ mpfr-3.0.0-b/version.c	2010-10-21 21:18:26.000000000 +0000
  1.1749 -@@ -25,5 +25,5 @@
  1.1750 - const char *
  1.1751 - mpfr_get_version (void)
  1.1752 - {
  1.1753 --  return "3.0.0-p6";
  1.1754 -+  return "3.0.0-p7";
  1.1755 - }
  1.1756 -diff -Naurd mpfr-3.0.0-a/PATCHES mpfr-3.0.0-b/PATCHES
  1.1757 ---- mpfr-3.0.0-a/PATCHES	2010-11-09 15:15:07.000000000 +0000
  1.1758 -+++ mpfr-3.0.0-b/PATCHES	2010-11-09 15:15:07.000000000 +0000
  1.1759 -@@ -0,0 +1 @@
  1.1760 -+macros
  1.1761 -diff -Naurd mpfr-3.0.0-a/VERSION mpfr-3.0.0-b/VERSION
  1.1762 ---- mpfr-3.0.0-a/VERSION	2010-10-21 21:18:26.000000000 +0000
  1.1763 -+++ mpfr-3.0.0-b/VERSION	2010-11-09 15:15:07.000000000 +0000
  1.1764 -@@ -1 +1 @@
  1.1765 --3.0.0-p7
  1.1766 -+3.0.0-p8
  1.1767 -diff -Naurd mpfr-3.0.0-a/mpfr.h mpfr-3.0.0-b/mpfr.h
  1.1768 ---- mpfr-3.0.0-a/mpfr.h	2010-10-21 21:18:26.000000000 +0000
  1.1769 -+++ mpfr-3.0.0-b/mpfr.h	2010-11-09 15:15:07.000000000 +0000
  1.1770 -@@ -27,7 +27,7 @@
  1.1771 - #define MPFR_VERSION_MAJOR 3
  1.1772 - #define MPFR_VERSION_MINOR 0
  1.1773 - #define MPFR_VERSION_PATCHLEVEL 0
  1.1774 --#define MPFR_VERSION_STRING "3.0.0-p7"
  1.1775 -+#define MPFR_VERSION_STRING "3.0.0-p8"
  1.1776 - 
  1.1777 - /* Macros dealing with MPFR VERSION */
  1.1778 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
  1.1779 -@@ -67,6 +67,16 @@
  1.1780 - # define _MPFR_H_HAVE_INTMAX_T 1
  1.1781 - #endif
  1.1782 - 
  1.1783 -+/* Avoid some problems with macro expansion if the user defines macros
  1.1784 -+   with the same name as keywords. By convention, identifiers and macro
  1.1785 -+   names starting with mpfr_ are reserved by MPFR. */
  1.1786 -+typedef void            mpfr_void;
  1.1787 -+typedef int             mpfr_int;
  1.1788 -+typedef unsigned int    mpfr_uint;
  1.1789 -+typedef long            mpfr_long;
  1.1790 -+typedef unsigned long   mpfr_ulong;
  1.1791 -+typedef size_t          mpfr_size_t;
  1.1792 -+
  1.1793 - /* Definition of rounding modes (DON'T USE MPFR_RNDNA!).
  1.1794 -    Warning! Changing the contents of this enum should be seen as an
  1.1795 -    interface change since the old and the new types are not compatible
  1.1796 -@@ -136,7 +146,7 @@
  1.1797 - typedef mp_exp_t     mpfr_exp_t;
  1.1798 - 
  1.1799 - /* Definition of the standard exponent limits */
  1.1800 --#define MPFR_EMAX_DEFAULT ((mpfr_exp_t) (((unsigned long) 1 << 30) - 1))
  1.1801 -+#define MPFR_EMAX_DEFAULT ((mpfr_exp_t) (((mpfr_ulong) 1 << 30) - 1))
  1.1802 - #define MPFR_EMIN_DEFAULT (-(MPFR_EMAX_DEFAULT))
  1.1803 - 
  1.1804 - /* Definition of the main structure */
  1.1805 -@@ -725,13 +735,13 @@
  1.1806 -    unexpected results with future compilers and aggressive optimisations.
  1.1807 -    Why not working only with signed types, using INT_MIN and LONG_MIN? */
  1.1808 - #if __GMP_MP_SIZE_T_INT
  1.1809 --#define __MPFR_EXP_NAN  ((mpfr_exp_t)((~((~(unsigned int)0)>>1))+2))
  1.1810 --#define __MPFR_EXP_ZERO ((mpfr_exp_t)((~((~(unsigned int)0)>>1))+1))
  1.1811 --#define __MPFR_EXP_INF  ((mpfr_exp_t)((~((~(unsigned int)0)>>1))+3))
  1.1812 -+#define __MPFR_EXP_NAN  ((mpfr_exp_t)((~((~(mpfr_uint)0)>>1))+2))
  1.1813 -+#define __MPFR_EXP_ZERO ((mpfr_exp_t)((~((~(mpfr_uint)0)>>1))+1))
  1.1814 -+#define __MPFR_EXP_INF  ((mpfr_exp_t)((~((~(mpfr_uint)0)>>1))+3))
  1.1815 - #else
  1.1816 --#define __MPFR_EXP_NAN  ((mpfr_exp_t)((~((~(unsigned long)0)>>1))+2))
  1.1817 --#define __MPFR_EXP_ZERO ((mpfr_exp_t)((~((~(unsigned long)0)>>1))+1))
  1.1818 --#define __MPFR_EXP_INF  ((mpfr_exp_t)((~((~(unsigned long)0)>>1))+3))
  1.1819 -+#define __MPFR_EXP_NAN  ((mpfr_exp_t)((~((~(mpfr_ulong)0)>>1))+2))
  1.1820 -+#define __MPFR_EXP_ZERO ((mpfr_exp_t)((~((~(mpfr_ulong)0)>>1))+1))
  1.1821 -+#define __MPFR_EXP_INF  ((mpfr_exp_t)((~((~(mpfr_ulong)0)>>1))+3))
  1.1822 - #endif
  1.1823 - 
  1.1824 - /* Define MPFR_USE_EXTENSION to avoid "gcc -pedantic" warnings. */
  1.1825 -@@ -760,9 +770,9 @@
  1.1826 - #define mpfr_inf_p(_x)      ((_x)->_mpfr_exp == __MPFR_EXP_INF)
  1.1827 - #define mpfr_zero_p(_x)     ((_x)->_mpfr_exp == __MPFR_EXP_ZERO)
  1.1828 - #define mpfr_regular_p(_x)  ((_x)->_mpfr_exp >  __MPFR_EXP_INF)
  1.1829 --#define mpfr_sgn(_x)                                          \
  1.1830 --  ((_x)->_mpfr_exp < __MPFR_EXP_INF ?                         \
  1.1831 --   (mpfr_nan_p (_x) ? mpfr_set_erangeflag () : (void) 0), 0 : \
  1.1832 -+#define mpfr_sgn(_x)                                               \
  1.1833 -+  ((_x)->_mpfr_exp < __MPFR_EXP_INF ?                              \
  1.1834 -+   (mpfr_nan_p (_x) ? mpfr_set_erangeflag () : (mpfr_void) 0), 0 : \
  1.1835 -    MPFR_SIGN (_x))
  1.1836 - 
  1.1837 - /* Prevent them from using as lvalues */
  1.1838 -@@ -805,7 +815,19 @@
  1.1839 -    Moreover casts to unsigned long have been added to avoid warnings in
  1.1840 -    programs that use MPFR and are compiled with -Wconversion; such casts
  1.1841 -    are OK since if X is a constant expression, then (unsigned long) X is
  1.1842 --   also a constant expression, so that the optimizations still work. */
  1.1843 -+   also a constant expression, so that the optimizations still work. The
  1.1844 -+   warnings are probably related to the following two bugs:
  1.1845 -+     http://gcc.gnu.org/bugzilla/show_bug.cgi?id=4210
  1.1846 -+     http://gcc.gnu.org/bugzilla/show_bug.cgi?id=38470 (possibly a variant)
  1.1847 -+   and the casts could be removed once these bugs are fixed.
  1.1848 -+   Casts shouldn't be used on the generic calls (to the ..._2exp functions),
  1.1849 -+   where implicit conversions are performed. Indeed, having at least one
  1.1850 -+   implicit conversion in the macro allows the compiler to emit diagnostics
  1.1851 -+   when normally expected, for instance in the following call:
  1.1852 -+     mpfr_set_ui (x, "foo", MPFR_RNDN);
  1.1853 -+   If this is not possible (for future macros), one of the tricks described
  1.1854 -+   on http://groups.google.com/group/comp.std.c/msg/e92abd24bf9eaf7b could
  1.1855 -+   be used. */
  1.1856 - #if defined (__GNUC__) && !defined(__ICC) && !defined(__cplusplus)
  1.1857 - #if (__GNUC__ >= 2)
  1.1858 - #undef mpfr_cmp_ui
  1.1859 -@@ -813,45 +835,45 @@
  1.1860 -    But warning! mpfr_sgn is specified as a macro in the API, thus the macro
  1.1861 -    mustn't be used if side effects are possible, like here. */
  1.1862 - #define mpfr_cmp_ui(_f,_u)                                      \
  1.1863 --  (__builtin_constant_p (_u) && (unsigned long) (_u) == 0 ?     \
  1.1864 -+  (__builtin_constant_p (_u) && (mpfr_ulong) (_u) == 0 ?        \
  1.1865 -    (mpfr_sgn) (_f) :                                            \
  1.1866 --   mpfr_cmp_ui_2exp ((_f), (unsigned long) (_u), 0))
  1.1867 -+   mpfr_cmp_ui_2exp ((_f), (_u), 0))
  1.1868 - #undef mpfr_cmp_si
  1.1869 --#define mpfr_cmp_si(_f,_s)                              \
  1.1870 --  (__builtin_constant_p (_s) && (long) (_s) >= 0 ?      \
  1.1871 --   mpfr_cmp_ui ((_f), (unsigned long) (long) (_s)) :    \
  1.1872 --   mpfr_cmp_si_2exp ((_f), (long) (_s), 0))
  1.1873 -+#define mpfr_cmp_si(_f,_s)                                      \
  1.1874 -+  (__builtin_constant_p (_s) && (mpfr_long) (_s) >= 0 ?         \
  1.1875 -+   mpfr_cmp_ui ((_f), (mpfr_ulong) (mpfr_long) (_s)) :          \
  1.1876 -+   mpfr_cmp_si_2exp ((_f), (_s), 0))
  1.1877 - #if __GNUC__ > 2 || __GNUC_MINOR__ >= 95
  1.1878 - #undef mpfr_set_ui
  1.1879 - #define mpfr_set_ui(_f,_u,_r)                                   \
  1.1880 --  (__builtin_constant_p (_u) && (unsigned long) (_u) == 0 ?     \
  1.1881 -+  (__builtin_constant_p (_u) && (mpfr_ulong) (_u) == 0 ?        \
  1.1882 -    __extension__ ({                                             \
  1.1883 -        mpfr_ptr _p = (_f);                                      \
  1.1884 -        _p->_mpfr_sign = 1;                                      \
  1.1885 -        _p->_mpfr_exp = __MPFR_EXP_ZERO;                         \
  1.1886 --       (void) (_r); 0; }) :                                     \
  1.1887 --   mpfr_set_ui_2exp ((_f), (unsigned long) (_u), 0, (_r)))
  1.1888 -+       (mpfr_void) (_r); 0; }) :                                \
  1.1889 -+   mpfr_set_ui_2exp ((_f), (_u), 0, (_r)))
  1.1890 - #endif
  1.1891 - #undef mpfr_set_si
  1.1892 - #define mpfr_set_si(_f,_s,_r)                                   \
  1.1893 --  (__builtin_constant_p (_s) && (long) (_s) >= 0 ?              \
  1.1894 --   mpfr_set_ui ((_f), (unsigned long) (long) (_s), (_r)) :      \
  1.1895 --   mpfr_set_si_2exp ((_f), (long) (_s), 0, (_r)))
  1.1896 -+  (__builtin_constant_p (_s) && (mpfr_long) (_s) >= 0 ?         \
  1.1897 -+   mpfr_set_ui ((_f), (mpfr_ulong) (mpfr_long) (_s), (_r)) :    \
  1.1898 -+   mpfr_set_si_2exp ((_f), (_s), 0, (_r)))
  1.1899 - #endif
  1.1900 - #endif
  1.1901 - 
  1.1902 - /* Macro version of mpfr_stack interface for fast access */
  1.1903 --#define mpfr_custom_get_size(p) ((size_t)                            \
  1.1904 -+#define mpfr_custom_get_size(p) ((mpfr_size_t)                          \
  1.1905 -        (((p)+GMP_NUMB_BITS-1)/GMP_NUMB_BITS*sizeof (mp_limb_t)))
  1.1906 - #define mpfr_custom_init(m,p) do {} while (0)
  1.1907 --#define mpfr_custom_get_significand(x) ((void*)((x)->_mpfr_d))
  1.1908 -+#define mpfr_custom_get_significand(x) ((mpfr_void*)((x)->_mpfr_d))
  1.1909 - #define mpfr_custom_get_exp(x) ((x)->_mpfr_exp)
  1.1910 - #define mpfr_custom_move(x,m) do { ((x)->_mpfr_d = (mp_limb_t*)(m)); } while (0)
  1.1911 - #define mpfr_custom_init_set(x,k,e,p,m) do {                   \
  1.1912 -   mpfr_ptr _x = (x);                                           \
  1.1913 -   mpfr_exp_t _e;                                               \
  1.1914 -   mpfr_kind_t _t;                                              \
  1.1915 --  int _s, _k;                                                  \
  1.1916 -+  mpfr_int _s, _k;                                             \
  1.1917 -   _k = (k);                                                    \
  1.1918 -   if (_k >= 0)  {                                              \
  1.1919 -     _t = (mpfr_kind_t) _k;                                     \
  1.1920 -@@ -868,11 +890,13 @@
  1.1921 -   _x->_mpfr_exp  = _e;                                         \
  1.1922 -   _x->_mpfr_d    = (mp_limb_t*) (m);                           \
  1.1923 -  } while (0)
  1.1924 --#define mpfr_custom_get_kind(x)                                              \
  1.1925 --  ( (x)->_mpfr_exp >  __MPFR_EXP_INF ? (int)MPFR_REGULAR_KIND*MPFR_SIGN (x) \
  1.1926 --  : (x)->_mpfr_exp == __MPFR_EXP_INF ? (int)MPFR_INF_KIND*MPFR_SIGN (x)     \
  1.1927 --  : (x)->_mpfr_exp == __MPFR_EXP_NAN ? (int)MPFR_NAN_KIND                   \
  1.1928 --  : (int) MPFR_ZERO_KIND * MPFR_SIGN (x) )
  1.1929 -+#define mpfr_custom_get_kind(x)                                         \
  1.1930 -+  ( (x)->_mpfr_exp >  __MPFR_EXP_INF ?                                  \
  1.1931 -+    (mpfr_int) MPFR_REGULAR_KIND * MPFR_SIGN (x)                        \
  1.1932 -+  : (x)->_mpfr_exp == __MPFR_EXP_INF ?                                  \
  1.1933 -+    (mpfr_int) MPFR_INF_KIND * MPFR_SIGN (x)                            \
  1.1934 -+  : (x)->_mpfr_exp == __MPFR_EXP_NAN ? (mpfr_int) MPFR_NAN_KIND         \
  1.1935 -+  : (mpfr_int) MPFR_ZERO_KIND * MPFR_SIGN (x) )
  1.1936 - 
  1.1937 - 
  1.1938 - #endif /* MPFR_USE_NO_MACRO */
  1.1939 -diff -Naurd mpfr-3.0.0-a/version.c mpfr-3.0.0-b/version.c
  1.1940 ---- mpfr-3.0.0-a/version.c	2010-10-21 21:18:26.000000000 +0000
  1.1941 -+++ mpfr-3.0.0-b/version.c	2010-11-09 15:15:07.000000000 +0000
  1.1942 -@@ -25,5 +25,5 @@
  1.1943 - const char *
  1.1944 - mpfr_get_version (void)
  1.1945 - {
  1.1946 --  return "3.0.0-p7";
  1.1947 -+  return "3.0.0-p8";
  1.1948 - }
     2.1 --- a/mpfr/stuff/mpfr-3.0.1.patch	Thu Apr 12 13:04:07 2012 +0200
     2.2 +++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
     2.3 @@ -1,367 +0,0 @@
     2.4 -diff -Naurd mpfr-3.0.1-a/PATCHES mpfr-3.0.1-b/PATCHES
     2.5 ---- mpfr-3.0.1-a/PATCHES	2011-04-12 10:50:02.000000000 +0000
     2.6 -+++ mpfr-3.0.1-b/PATCHES	2011-04-12 10:50:02.000000000 +0000
     2.7 -@@ -0,0 +1 @@
     2.8 -+asin_exprange
     2.9 -diff -Naurd mpfr-3.0.1-a/VERSION mpfr-3.0.1-b/VERSION
    2.10 ---- mpfr-3.0.1-a/VERSION	2011-04-04 10:19:18.000000000 +0000
    2.11 -+++ mpfr-3.0.1-b/VERSION	2011-04-12 10:50:02.000000000 +0000
    2.12 -@@ -1 +1 @@
    2.13 --3.0.1
    2.14 -+3.0.1-p1
    2.15 -diff -Naurd mpfr-3.0.1-a/asin.c mpfr-3.0.1-b/asin.c
    2.16 ---- mpfr-3.0.1-a/asin.c	2011-04-04 10:19:18.000000000 +0000
    2.17 -+++ mpfr-3.0.1-b/asin.c	2011-04-12 10:50:02.000000000 +0000
    2.18 -@@ -63,11 +63,14 @@
    2.19 - 
    2.20 -   compared = mpfr_cmp_ui (xp, 1);
    2.21 - 
    2.22 -+  MPFR_SAVE_EXPO_MARK (expo);
    2.23 -+
    2.24 -   if (MPFR_UNLIKELY (compared >= 0))
    2.25 -     {
    2.26 -       mpfr_clear (xp);
    2.27 -       if (compared > 0)                  /* asin(x) = NaN for |x| > 1 */
    2.28 -         {
    2.29 -+          MPFR_SAVE_EXPO_FREE (expo);
    2.30 -           MPFR_SET_NAN (asin);
    2.31 -           MPFR_RET_NAN;
    2.32 -         }
    2.33 -@@ -80,13 +83,11 @@
    2.34 -               inexact = -mpfr_const_pi (asin, MPFR_INVERT_RND(rnd_mode));
    2.35 -               MPFR_CHANGE_SIGN (asin);
    2.36 -             }
    2.37 --          mpfr_div_2ui (asin, asin, 1, rnd_mode); /* May underflow */
    2.38 --          return inexact;
    2.39 -+          mpfr_div_2ui (asin, asin, 1, rnd_mode);
    2.40 -         }
    2.41 -     }
    2.42 --
    2.43 --  MPFR_SAVE_EXPO_MARK (expo);
    2.44 --
    2.45 -+  else
    2.46 -+    {
    2.47 -   /* Compute exponent of 1 - ABS(x) */
    2.48 -   mpfr_ui_sub (xp, 1, xp, MPFR_RNDD);
    2.49 -   MPFR_ASSERTD (MPFR_GET_EXP (xp) <= 0);
    2.50 -@@ -115,6 +116,7 @@
    2.51 -   inexact = mpfr_set (asin, xp, rnd_mode);
    2.52 - 
    2.53 -   mpfr_clear (xp);
    2.54 -+    }
    2.55 - 
    2.56 -   MPFR_SAVE_EXPO_FREE (expo);
    2.57 -   return mpfr_check_range (asin, inexact, rnd_mode);
    2.58 -diff -Naurd mpfr-3.0.1-a/mpfr.h mpfr-3.0.1-b/mpfr.h
    2.59 ---- mpfr-3.0.1-a/mpfr.h	2011-04-04 10:19:18.000000000 +0000
    2.60 -+++ mpfr-3.0.1-b/mpfr.h	2011-04-12 10:50:02.000000000 +0000
    2.61 -@@ -27,7 +27,7 @@
    2.62 - #define MPFR_VERSION_MAJOR 3
    2.63 - #define MPFR_VERSION_MINOR 0
    2.64 - #define MPFR_VERSION_PATCHLEVEL 1
    2.65 --#define MPFR_VERSION_STRING "3.0.1"
    2.66 -+#define MPFR_VERSION_STRING "3.0.1-p1"
    2.67 - 
    2.68 - /* Macros dealing with MPFR VERSION */
    2.69 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
    2.70 -diff -Naurd mpfr-3.0.1-a/tests/tasin.c mpfr-3.0.1-b/tests/tasin.c
    2.71 ---- mpfr-3.0.1-a/tests/tasin.c	2011-04-04 10:19:17.000000000 +0000
    2.72 -+++ mpfr-3.0.1-b/tests/tasin.c	2011-04-12 10:50:02.000000000 +0000
    2.73 -@@ -219,6 +219,49 @@
    2.74 -   mpfr_clear (y);
    2.75 - }
    2.76 - 
    2.77 -+static void
    2.78 -+reduced_expo_range (void)
    2.79 -+{
    2.80 -+  mpfr_exp_t emin, emax;
    2.81 -+  mpfr_t x, y, ex_y;
    2.82 -+  int inex, ex_inex;
    2.83 -+  unsigned int flags, ex_flags;
    2.84 -+
    2.85 -+  emin = mpfr_get_emin ();
    2.86 -+  emax = mpfr_get_emax ();
    2.87 -+
    2.88 -+  mpfr_inits2 (4, x, y, ex_y, (mpfr_ptr) 0);
    2.89 -+  mpfr_set_str (x, "-0.1e1", 2, MPFR_RNDN);
    2.90 -+
    2.91 -+  mpfr_set_emin (1);
    2.92 -+  mpfr_set_emax (1);
    2.93 -+  mpfr_clear_flags ();
    2.94 -+  inex = mpfr_asin (y, x, MPFR_RNDA);
    2.95 -+  flags = __gmpfr_flags;
    2.96 -+  mpfr_set_emin (emin);
    2.97 -+  mpfr_set_emax (emax);
    2.98 -+
    2.99 -+  mpfr_set_str (ex_y, "-0.1101e1", 2, MPFR_RNDN);
   2.100 -+  ex_inex = -1;
   2.101 -+  ex_flags = MPFR_FLAGS_INEXACT;
   2.102 -+
   2.103 -+  if (SIGN (inex) != ex_inex || flags != ex_flags ||
   2.104 -+      ! mpfr_equal_p (y, ex_y))
   2.105 -+    {
   2.106 -+      printf ("Error in reduced_expo_range\non x = ");
   2.107 -+      mpfr_dump (x);
   2.108 -+      printf ("Expected y = ");
   2.109 -+      mpfr_out_str (stdout, 2, 0, ex_y, MPFR_RNDN);
   2.110 -+      printf ("\n         inex = %d, flags = %u\n", ex_inex, ex_flags);
   2.111 -+      printf ("Got      y = ");
   2.112 -+      mpfr_out_str (stdout, 2, 0, y, MPFR_RNDN);
   2.113 -+      printf ("\n         inex = %d, flags = %u\n", SIGN (inex), flags);
   2.114 -+      exit (1);
   2.115 -+    }
   2.116 -+
   2.117 -+  mpfr_clears (x, y, ex_y, (mpfr_ptr) 0);
   2.118 -+}
   2.119 -+
   2.120 - int
   2.121 - main (void)
   2.122 - {
   2.123 -@@ -226,6 +269,7 @@
   2.124 - 
   2.125 -   special ();
   2.126 -   special_overflow ();
   2.127 -+  reduced_expo_range ();
   2.128 - 
   2.129 -   test_generic (2, 100, 15);
   2.130 - 
   2.131 -diff -Naurd mpfr-3.0.1-a/version.c mpfr-3.0.1-b/version.c
   2.132 ---- mpfr-3.0.1-a/version.c	2011-04-04 10:19:18.000000000 +0000
   2.133 -+++ mpfr-3.0.1-b/version.c	2011-04-12 10:50:02.000000000 +0000
   2.134 -@@ -25,5 +25,5 @@
   2.135 - const char *
   2.136 - mpfr_get_version (void)
   2.137 - {
   2.138 --  return "3.0.1";
   2.139 -+  return "3.0.1-p1";
   2.140 - }
   2.141 -diff -Naurd mpfr-3.0.1-a/PATCHES mpfr-3.0.1-b/PATCHES
   2.142 ---- mpfr-3.0.1-a/PATCHES	2011-05-04 11:18:33.000000000 +0000
   2.143 -+++ mpfr-3.0.1-b/PATCHES	2011-05-04 11:18:33.000000000 +0000
   2.144 -@@ -0,0 +1 @@
   2.145 -+rec_sqrt-carry
   2.146 -diff -Naurd mpfr-3.0.1-a/VERSION mpfr-3.0.1-b/VERSION
   2.147 ---- mpfr-3.0.1-a/VERSION	2011-04-12 10:50:02.000000000 +0000
   2.148 -+++ mpfr-3.0.1-b/VERSION	2011-05-04 11:18:33.000000000 +0000
   2.149 -@@ -1 +1 @@
   2.150 --3.0.1-p1
   2.151 -+3.0.1-p2
   2.152 -diff -Naurd mpfr-3.0.1-a/mpfr.h mpfr-3.0.1-b/mpfr.h
   2.153 ---- mpfr-3.0.1-a/mpfr.h	2011-04-12 10:50:02.000000000 +0000
   2.154 -+++ mpfr-3.0.1-b/mpfr.h	2011-05-04 11:18:33.000000000 +0000
   2.155 -@@ -27,7 +27,7 @@
   2.156 - #define MPFR_VERSION_MAJOR 3
   2.157 - #define MPFR_VERSION_MINOR 0
   2.158 - #define MPFR_VERSION_PATCHLEVEL 1
   2.159 --#define MPFR_VERSION_STRING "3.0.1-p1"
   2.160 -+#define MPFR_VERSION_STRING "3.0.1-p2"
   2.161 - 
   2.162 - /* Macros dealing with MPFR VERSION */
   2.163 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   2.164 -diff -Naurd mpfr-3.0.1-a/rec_sqrt.c mpfr-3.0.1-b/rec_sqrt.c
   2.165 ---- mpfr-3.0.1-a/rec_sqrt.c	2011-04-04 10:19:18.000000000 +0000
   2.166 -+++ mpfr-3.0.1-b/rec_sqrt.c	2011-05-04 11:18:33.000000000 +0000
   2.167 -@@ -375,20 +375,37 @@
   2.168 -       MPFR_ASSERTD(un == ln + 1 || un == ln + 2);
   2.169 -       /* the high un-ln limbs of u will overlap the low part of {x+ln,xn},
   2.170 -          we need to add or subtract the overlapping part {u + ln, un - ln} */
   2.171 -+      /* Warning! th may be 0, in which case the mpn_add_1 and mpn_sub_1
   2.172 -+         below (with size = th) mustn't be used. In such a case, the limb
   2.173 -+         (carry) will be 0, so that this is semantically a no-op, but if
   2.174 -+         mpn_add_1 and mpn_sub_1 are used, GMP (currently) still does a
   2.175 -+         non-atomic read/write in a place that is not always allocated,
   2.176 -+         with the possible consequences: a crash if the corresponding
   2.177 -+         address is not mapped, or (rather unlikely) memory corruption
   2.178 -+         if another process/thread writes at the same place; things may
   2.179 -+         be worse with future GMP versions. Hence the tests carry != 0. */
   2.180 -       if (neg == 0)
   2.181 -         {
   2.182 -           if (ln > 0)
   2.183 -             MPN_COPY (x, u, ln);
   2.184 -           cy = mpn_add (x + ln, x + ln, xn, u + ln, un - ln);
   2.185 -           /* add cu at x+un */
   2.186 --          cy += mpn_add_1 (x + un, x + un, th, cu);
   2.187 -+          if (cu != 0)
   2.188 -+            {
   2.189 -+              MPFR_ASSERTD (th != 0);
   2.190 -+              cy += mpn_add_1 (x + un, x + un, th, cu);
   2.191 -+            }
   2.192 -         }
   2.193 -       else /* negative case */
   2.194 -         {
   2.195 -           /* subtract {u+ln, un-ln} from {x+ln,un} */
   2.196 -           cy = mpn_sub (x + ln, x + ln, xn, u + ln, un - ln);
   2.197 -           /* carry cy is at x+un, like cu */
   2.198 --          cy = mpn_sub_1 (x + un, x + un, th, cy + cu); /* n - un = th */
   2.199 -+          if (cy + cu != 0)
   2.200 -+            {
   2.201 -+              MPFR_ASSERTD (th != 0);
   2.202 -+              cy = mpn_sub_1 (x + un, x + un, th, cy + cu); /* n - un = th */
   2.203 -+            }
   2.204 -           /* cy cannot be zero, since the most significant bit of Xh is 1,
   2.205 -              and the correction is bounded by 2^{-h+3} */
   2.206 -           MPFR_ASSERTD(cy == 0);
   2.207 -diff -Naurd mpfr-3.0.1-a/version.c mpfr-3.0.1-b/version.c
   2.208 ---- mpfr-3.0.1-a/version.c	2011-04-12 10:50:02.000000000 +0000
   2.209 -+++ mpfr-3.0.1-b/version.c	2011-05-04 11:18:33.000000000 +0000
   2.210 -@@ -25,5 +25,5 @@
   2.211 - const char *
   2.212 - mpfr_get_version (void)
   2.213 - {
   2.214 --  return "3.0.1-p1";
   2.215 -+  return "3.0.1-p2";
   2.216 - }
   2.217 -diff -Naurd mpfr-3.0.1-a/PATCHES mpfr-3.0.1-b/PATCHES
   2.218 ---- mpfr-3.0.1-a/PATCHES	2011-05-05 00:00:35.000000000 +0000
   2.219 -+++ mpfr-3.0.1-b/PATCHES	2011-05-05 00:00:35.000000000 +0000
   2.220 -@@ -0,0 +1 @@
   2.221 -+atan-expo-range
   2.222 -diff -Naurd mpfr-3.0.1-a/VERSION mpfr-3.0.1-b/VERSION
   2.223 ---- mpfr-3.0.1-a/VERSION	2011-05-04 11:18:33.000000000 +0000
   2.224 -+++ mpfr-3.0.1-b/VERSION	2011-05-05 00:00:35.000000000 +0000
   2.225 -@@ -1 +1 @@
   2.226 --3.0.1-p2
   2.227 -+3.0.1-p3
   2.228 -diff -Naurd mpfr-3.0.1-a/atan.c mpfr-3.0.1-b/atan.c
   2.229 ---- mpfr-3.0.1-a/atan.c	2011-04-04 10:19:18.000000000 +0000
   2.230 -+++ mpfr-3.0.1-b/atan.c	2011-05-05 00:00:35.000000000 +0000
   2.231 -@@ -431,5 +431,5 @@
   2.232 -   MPFR_GROUP_CLEAR (group);
   2.233 - 
   2.234 -   MPFR_SAVE_EXPO_FREE (expo);
   2.235 --  return mpfr_check_range (arctgt, inexact, rnd_mode);
   2.236 -+  return mpfr_check_range (atan, inexact, rnd_mode);
   2.237 - }
   2.238 -diff -Naurd mpfr-3.0.1-a/mpfr.h mpfr-3.0.1-b/mpfr.h
   2.239 ---- mpfr-3.0.1-a/mpfr.h	2011-05-04 11:18:33.000000000 +0000
   2.240 -+++ mpfr-3.0.1-b/mpfr.h	2011-05-05 00:00:35.000000000 +0000
   2.241 -@@ -27,7 +27,7 @@
   2.242 - #define MPFR_VERSION_MAJOR 3
   2.243 - #define MPFR_VERSION_MINOR 0
   2.244 - #define MPFR_VERSION_PATCHLEVEL 1
   2.245 --#define MPFR_VERSION_STRING "3.0.1-p2"
   2.246 -+#define MPFR_VERSION_STRING "3.0.1-p3"
   2.247 - 
   2.248 - /* Macros dealing with MPFR VERSION */
   2.249 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   2.250 -diff -Naurd mpfr-3.0.1-a/tests/tatan.c mpfr-3.0.1-b/tests/tatan.c
   2.251 ---- mpfr-3.0.1-a/tests/tatan.c	2011-04-04 10:19:17.000000000 +0000
   2.252 -+++ mpfr-3.0.1-b/tests/tatan.c	2011-05-05 00:00:35.000000000 +0000
   2.253 -@@ -535,6 +535,52 @@
   2.254 -   mpfr_clears (a, x, y, (mpfr_ptr) 0);
   2.255 - }
   2.256 - 
   2.257 -+/* http://websympa.loria.fr/wwsympa/arc/mpfr/2011-05/msg00008.html
   2.258 -+ * Incorrect flags (in debug mode on a 32-bit machine, assertion failure).
   2.259 -+ */
   2.260 -+static void
   2.261 -+reduced_expo_range (void)
   2.262 -+{
   2.263 -+  mpfr_exp_t emin, emax;
   2.264 -+  mpfr_t x, y, ex_y;
   2.265 -+  int inex, ex_inex;
   2.266 -+  unsigned int flags, ex_flags;
   2.267 -+
   2.268 -+  emin = mpfr_get_emin ();
   2.269 -+  emax = mpfr_get_emax ();
   2.270 -+
   2.271 -+  mpfr_inits2 (12, x, y, ex_y, (mpfr_ptr) 0);
   2.272 -+  mpfr_set_str (x, "0.1e-5", 2, MPFR_RNDN);
   2.273 -+
   2.274 -+  mpfr_set_emin (-5);
   2.275 -+  mpfr_set_emax (-5);
   2.276 -+  mpfr_clear_flags ();
   2.277 -+  inex = mpfr_atan (y, x, MPFR_RNDN);
   2.278 -+  flags = __gmpfr_flags;
   2.279 -+  mpfr_set_emin (emin);
   2.280 -+  mpfr_set_emax (emax);
   2.281 -+
   2.282 -+  mpfr_set_str (ex_y, "0.1e-5", 2, MPFR_RNDN);
   2.283 -+  ex_inex = 1;
   2.284 -+  ex_flags = MPFR_FLAGS_INEXACT;
   2.285 -+
   2.286 -+  if (SIGN (inex) != ex_inex || flags != ex_flags ||
   2.287 -+      ! mpfr_equal_p (y, ex_y))
   2.288 -+    {
   2.289 -+      printf ("Error in reduced_expo_range\non x = ");
   2.290 -+      mpfr_dump (x);
   2.291 -+      printf ("Expected y = ");
   2.292 -+      mpfr_out_str (stdout, 2, 0, ex_y, MPFR_RNDN);
   2.293 -+      printf ("\n         inex = %d, flags = %u\n", ex_inex, ex_flags);
   2.294 -+      printf ("Got      y = ");
   2.295 -+      mpfr_out_str (stdout, 2, 0, y, MPFR_RNDN);
   2.296 -+      printf ("\n         inex = %d, flags = %u\n", SIGN (inex), flags);
   2.297 -+      exit (1);
   2.298 -+    }
   2.299 -+
   2.300 -+  mpfr_clears (x, y, ex_y, (mpfr_ptr) 0);
   2.301 -+}
   2.302 -+
   2.303 - int
   2.304 - main (int argc, char *argv[])
   2.305 - {
   2.306 -@@ -546,6 +592,7 @@
   2.307 -   smallvals_atan2 ();
   2.308 -   atan2_bug_20071003 ();
   2.309 -   atan2_different_prec ();
   2.310 -+  reduced_expo_range ();
   2.311 - 
   2.312 -   test_generic_atan  (2, 200, 17);
   2.313 -   test_generic_atan2 (2, 200, 17);
   2.314 -diff -Naurd mpfr-3.0.1-a/version.c mpfr-3.0.1-b/version.c
   2.315 ---- mpfr-3.0.1-a/version.c	2011-05-04 11:18:33.000000000 +0000
   2.316 -+++ mpfr-3.0.1-b/version.c	2011-05-05 00:00:35.000000000 +0000
   2.317 -@@ -25,5 +25,5 @@
   2.318 - const char *
   2.319 - mpfr_get_version (void)
   2.320 - {
   2.321 --  return "3.0.1-p2";
   2.322 -+  return "3.0.1-p3";
   2.323 - }
   2.324 -diff -Naurd mpfr-3.0.1-a/PATCHES mpfr-3.0.1-b/PATCHES
   2.325 ---- mpfr-3.0.1-a/PATCHES	2011-05-09 14:48:24.000000000 +0000
   2.326 -+++ mpfr-3.0.1-b/PATCHES	2011-05-09 14:48:24.000000000 +0000
   2.327 -@@ -0,0 +1 @@
   2.328 -+texp-zero
   2.329 -diff -Naurd mpfr-3.0.1-a/VERSION mpfr-3.0.1-b/VERSION
   2.330 ---- mpfr-3.0.1-a/VERSION	2011-05-05 00:00:35.000000000 +0000
   2.331 -+++ mpfr-3.0.1-b/VERSION	2011-05-09 14:48:24.000000000 +0000
   2.332 -@@ -1 +1 @@
   2.333 --3.0.1-p3
   2.334 -+3.0.1-p4
   2.335 -diff -Naurd mpfr-3.0.1-a/mpfr.h mpfr-3.0.1-b/mpfr.h
   2.336 ---- mpfr-3.0.1-a/mpfr.h	2011-05-05 00:00:35.000000000 +0000
   2.337 -+++ mpfr-3.0.1-b/mpfr.h	2011-05-09 14:48:24.000000000 +0000
   2.338 -@@ -27,7 +27,7 @@
   2.339 - #define MPFR_VERSION_MAJOR 3
   2.340 - #define MPFR_VERSION_MINOR 0
   2.341 - #define MPFR_VERSION_PATCHLEVEL 1
   2.342 --#define MPFR_VERSION_STRING "3.0.1-p3"
   2.343 -+#define MPFR_VERSION_STRING "3.0.1-p4"
   2.344 - 
   2.345 - /* Macros dealing with MPFR VERSION */
   2.346 - #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   2.347 -diff -Naurd mpfr-3.0.1-a/tests/texp.c mpfr-3.0.1-b/tests/texp.c
   2.348 ---- mpfr-3.0.1-a/tests/texp.c	2011-04-04 10:19:17.000000000 +0000
   2.349 -+++ mpfr-3.0.1-b/tests/texp.c	2011-05-09 14:48:24.000000000 +0000
   2.350 -@@ -170,7 +170,9 @@
   2.351 -       mpfr_set_prec (x, prec);
   2.352 -       mpfr_set_prec (y, prec);
   2.353 -       mpfr_set_prec (z, prec);
   2.354 --      mpfr_urandomb (x, RANDS);
   2.355 -+      do
   2.356 -+        mpfr_urandomb (x, RANDS);
   2.357 -+      while (MPFR_IS_ZERO (x));  /* 0 is handled by mpfr_exp only */
   2.358 -       rnd = RND_RAND ();
   2.359 -       mpfr_exp_2 (y, x, rnd);
   2.360 -       mpfr_exp_3 (z, x, rnd);
   2.361 -diff -Naurd mpfr-3.0.1-a/version.c mpfr-3.0.1-b/version.c
   2.362 ---- mpfr-3.0.1-a/version.c	2011-05-05 00:00:35.000000000 +0000
   2.363 -+++ mpfr-3.0.1-b/version.c	2011-05-09 14:48:24.000000000 +0000
   2.364 -@@ -25,5 +25,5 @@
   2.365 - const char *
   2.366 - mpfr_get_version (void)
   2.367 - {
   2.368 --  return "3.0.1-p3";
   2.369 -+  return "3.0.1-p4";
   2.370 - }
     3.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     3.2 +++ b/mpfr/stuff/mpfr-3.1.0.patch	Thu Apr 12 14:35:51 2012 +0200
     3.3 @@ -0,0 +1,473 @@
     3.4 +Submitted By:            Matt Burgess <matthew_at_linuxfromscratch_dot_org>
     3.5 +Date:                    2011-12-22
     3.6 +Initial Package Version: 3.1.0
     3.7 +Upstream Status:         Already in upstream patch repo
     3.8 +Origin:                  Upstream
     3.9 +Description:             This patch contains patches for several bugs in MPFR,
    3.10 +                         the main one being a rounding related error with the
    3.11 +                         mpfr_*printf functions.
    3.12 +
    3.13 +diff -Naur mpfr-3.1.0.orig/PATCHES mpfr-3.1.0/PATCHES
    3.14 +--- mpfr-3.1.0.orig/PATCHES	2011-10-03 08:17:15.000000000 +0000
    3.15 ++++ mpfr-3.1.0/PATCHES	2011-12-22 11:08:42.188819413 +0000
    3.16 +@@ -0,0 +1,4 @@
    3.17 ++gmp41compat
    3.18 ++vasprintf
    3.19 ++lib-search-path
    3.20 ++mpfr_unlikely
    3.21 +diff -Naur mpfr-3.1.0.orig/VERSION mpfr-3.1.0/VERSION
    3.22 +--- mpfr-3.1.0.orig/VERSION	2011-10-03 08:17:15.000000000 +0000
    3.23 ++++ mpfr-3.1.0/VERSION	2011-11-28 12:22:52.000000000 +0000
    3.24 +@@ -1 +1 @@
    3.25 +-3.1.0
    3.26 ++3.1.0-p4
    3.27 +diff -Naur mpfr-3.1.0.orig/doc/mpfr.info mpfr-3.1.0/doc/mpfr.info
    3.28 +--- mpfr-3.1.0.orig/doc/mpfr.info	2011-10-03 09:43:04.000000000 +0000
    3.29 ++++ mpfr-3.1.0/doc/mpfr.info	2011-11-28 12:22:52.000000000 +0000
    3.30 +@@ -2994,11 +2994,12 @@
    3.31 + 
    3.32 +    * `mpfr_urandom' and `mpfr_urandomb' changed in MPFR 3.1.  Their
    3.33 +      behavior no longer depends on the platform (assuming this is also
    3.34 +-     true for GMP's random generator).  As a consequence, the returned
    3.35 +-     values can be different between MPFR 3.1 and previous MPFR
    3.36 +-     versions.  Note: as the reproducibility of these functions was not
    3.37 +-     specified before MPFR 3.1, the MPFR 3.1 behavior is _not_ regarded
    3.38 +-     as backward incompatible with previous versions.
    3.39 ++     true for GMP's random generator, which is not the case between GMP
    3.40 ++     4.1 and 4.2 if `gmp_randinit_default' is used).  As a consequence,
    3.41 ++     the returned values can be different between MPFR 3.1 and previous
    3.42 ++     MPFR versions.  Note: as the reproducibility of these functions
    3.43 ++     was not specified before MPFR 3.1, the MPFR 3.1 behavior is _not_
    3.44 ++     regarded as backward incompatible with previous versions.
    3.45 + 
    3.46 + 
    3.47 + 
    3.48 +@@ -4239,13 +4240,13 @@
    3.49 + Node: Type and Macro Changes129308
    3.50 + Node: Added Functions132029
    3.51 + Node: Changed Functions134972
    3.52 +-Node: Removed Functions139167
    3.53 +-Node: Other Changes139579
    3.54 +-Node: Contributors141108
    3.55 +-Node: References143574
    3.56 +-Node: GNU Free Documentation License145315
    3.57 +-Node: Concept Index167758
    3.58 +-Node: Function and Type Index173677
    3.59 ++Node: Removed Functions139253
    3.60 ++Node: Other Changes139665
    3.61 ++Node: Contributors141194
    3.62 ++Node: References143660
    3.63 ++Node: GNU Free Documentation License145401
    3.64 ++Node: Concept Index167844
    3.65 ++Node: Function and Type Index173763
    3.66 + 
    3.67 + End Tag Table
    3.68 + 
    3.69 +diff -Naur mpfr-3.1.0.orig/doc/mpfr.texi mpfr-3.1.0/doc/mpfr.texi
    3.70 +--- mpfr-3.1.0.orig/doc/mpfr.texi	2011-10-03 08:17:14.000000000 +0000
    3.71 ++++ mpfr-3.1.0/doc/mpfr.texi	2011-11-28 12:22:52.000000000 +0000
    3.72 +@@ -3466,8 +3466,9 @@
    3.73 + a lack of specification.
    3.74 + 
    3.75 + @item @code{mpfr_urandom} and @code{mpfr_urandomb} changed in MPFR 3.1.
    3.76 +-Their behavior no longer depends on the platform (assuming this is also
    3.77 +-true for GMP's random generator).  As a consequence, the returned values
    3.78 ++Their behavior no longer depends on the platform (assuming this is also true
    3.79 ++for GMP's random generator, which is not the case between GMP 4.1 and 4.2 if
    3.80 ++@code{gmp_randinit_default} is used).  As a consequence, the returned values
    3.81 + can be different between MPFR 3.1 and previous MPFR versions.
    3.82 + Note: as the reproducibility of these functions was not specified
    3.83 + before MPFR 3.1, the MPFR 3.1 behavior is @emph{not} regarded as
    3.84 +diff -Naur mpfr-3.1.0.orig/src/mpfr-impl.h mpfr-3.1.0/src/mpfr-impl.h
    3.85 +--- mpfr-3.1.0.orig/src/mpfr-impl.h	2011-10-03 08:17:09.000000000 +0000
    3.86 ++++ mpfr-3.1.0/src/mpfr-impl.h	2011-10-05 21:39:57.000000000 +0000
    3.87 +@@ -988,10 +988,11 @@
    3.88 +  ******************************************************/
    3.89 + 
    3.90 + /* Theses macros help the compiler to determine if a test is
    3.91 +- * likely or unlikely. */
    3.92 ++   likely or unlikely. The !! is necessary in case x is larger
    3.93 ++   than a long. */
    3.94 + #if __MPFR_GNUC(3,0) || __MPFR_ICC(8,1,0)
    3.95 + # define MPFR_LIKELY(x) (__builtin_expect(!!(x),1))
    3.96 +-# define MPFR_UNLIKELY(x) (__builtin_expect((x),0))
    3.97 ++# define MPFR_UNLIKELY(x) (__builtin_expect(!!(x),0))
    3.98 + #else
    3.99 + # define MPFR_LIKELY(x) (x)
   3.100 + # define MPFR_UNLIKELY(x) (x)
   3.101 +diff -Naur mpfr-3.1.0.orig/src/mpfr.h mpfr-3.1.0/src/mpfr.h
   3.102 +--- mpfr-3.1.0.orig/src/mpfr.h	2011-10-03 08:17:09.000000000 +0000
   3.103 ++++ mpfr-3.1.0/src/mpfr.h	2011-11-28 12:22:52.000000000 +0000
   3.104 +@@ -27,7 +27,7 @@
   3.105 + #define MPFR_VERSION_MAJOR 3
   3.106 + #define MPFR_VERSION_MINOR 1
   3.107 + #define MPFR_VERSION_PATCHLEVEL 0
   3.108 +-#define MPFR_VERSION_STRING "3.1.0"
   3.109 ++#define MPFR_VERSION_STRING "3.1.0-p4"
   3.110 + 
   3.111 + /* Macros dealing with MPFR VERSION */
   3.112 + #define MPFR_VERSION_NUM(a,b,c) (((a) << 16L) | ((b) << 8) | (c))
   3.113 +diff -Naur mpfr-3.1.0.orig/src/vasprintf.c mpfr-3.1.0/src/vasprintf.c
   3.114 +--- mpfr-3.1.0.orig/src/vasprintf.c	2011-10-03 08:17:09.000000000 +0000
   3.115 ++++ mpfr-3.1.0/src/vasprintf.c	2011-11-03 15:15:11.000000000 +0000
   3.116 +@@ -1178,7 +1178,7 @@
   3.117 +   mpfr_exp_t exp;
   3.118 +   char * str;
   3.119 +   const int spec_g = (spec.spec == 'g' || spec.spec == 'G');
   3.120 +-  const int keep_trailing_zeros = spec_g && spec.alt;
   3.121 ++  const int keep_trailing_zeros = !spec_g || spec.alt;
   3.122 + 
   3.123 +   /* WARNING: an empty precision field is forbidden (it means precision = 6
   3.124 +      and it should have been changed to 6 before the function call) */
   3.125 +@@ -1356,7 +1356,7 @@
   3.126 +   else
   3.127 +     /* 1 <= |p| */
   3.128 +     {
   3.129 +-      size_t nsd;  /* Number of significant digits */
   3.130 ++      size_t str_len;
   3.131 + 
   3.132 +       /* Determine the position of the most significant decimal digit. */
   3.133 +       exp = floor_log10 (p);
   3.134 +@@ -1365,12 +1365,10 @@
   3.135 +         /* P is too large to print all its integral part digits */
   3.136 +         return -1;
   3.137 + 
   3.138 +-      np->ip_size = exp + 1;
   3.139 +-
   3.140 +-      nsd = spec.prec + np->ip_size;
   3.141 +       if (dec_info == NULL)
   3.142 +-        {
   3.143 +-          str = mpfr_get_str (NULL, &exp, 10, nsd, p, spec.rnd_mode);
   3.144 ++        { /* this case occurs with mpfr_printf ("%.0RUf", x) with x=9.5 */
   3.145 ++          str =
   3.146 ++            mpfr_get_str (NULL, &exp, 10, spec.prec+exp+1, p, spec.rnd_mode);
   3.147 +           register_string (np->sl, str);
   3.148 +         }
   3.149 +       else
   3.150 +@@ -1379,81 +1377,60 @@
   3.151 +           str = dec_info->str;
   3.152 +         }
   3.153 +       np->ip_ptr = MPFR_IS_NEG (p) ? ++str : str; /* skip sign */
   3.154 ++      str_len = strlen (str);
   3.155 ++
   3.156 ++      /* integral part */
   3.157 ++      if (exp > str_len)
   3.158 ++        /* mpfr_get_str gives no trailing zero when p is rounded up to the next
   3.159 ++           power of 10 (p integer, so no fractional part) */
   3.160 ++        {
   3.161 ++          np->ip_trailing_zeros = exp - str_len;
   3.162 ++          np->ip_size = str_len;
   3.163 ++        }
   3.164 ++      else
   3.165 ++        np->ip_size = exp;
   3.166 + 
   3.167 +       if (spec.group)
   3.168 +         /* thousands separator in integral part */
   3.169 +         np->thousands_sep = MPFR_THOUSANDS_SEPARATOR;
   3.170 + 
   3.171 +-      if (nsd == 0 || (spec_g && !spec.alt))
   3.172 +-        /* compute how much non-zero digits in integral and fractional
   3.173 +-           parts */
   3.174 ++      /* fractional part */
   3.175 ++      str += np->ip_size;
   3.176 ++      str_len -= np->ip_size;
   3.177 ++      if (!keep_trailing_zeros)
   3.178 ++        /* remove trailing zeros, if any */
   3.179 +         {
   3.180 +-          size_t str_len;
   3.181 +-          str_len = strlen (str); /* note: the sign has been skipped */
   3.182 +-
   3.183 +-          if (exp > str_len)
   3.184 +-            /* mpfr_get_str doesn't give the trailing zeros when p is a
   3.185 +-               multiple of 10 (p integer, so no fractional part) */
   3.186 ++          char *ptr = str + str_len - 1; /* pointer to the last digit of
   3.187 ++                                            str */
   3.188 ++          while ((*ptr == '0') && (str_len != 0))
   3.189 +             {
   3.190 +-              np->ip_trailing_zeros = exp - str_len;
   3.191 +-              np->ip_size = str_len;
   3.192 +-              if (spec.alt)
   3.193 +-                np->point = MPFR_DECIMAL_POINT;
   3.194 +-            }
   3.195 +-          else
   3.196 +-            /* str may contain some digits which are in fractional part */
   3.197 +-            {
   3.198 +-              char *ptr;
   3.199 +-
   3.200 +-              ptr = str + str_len - 1; /* points to the end of str */
   3.201 +-              str_len -= np->ip_size;  /* number of digits in fractional
   3.202 +-                                          part */
   3.203 +-
   3.204 +-              if (!keep_trailing_zeros)
   3.205 +-                /* remove trailing zeros, if any */
   3.206 +-                {
   3.207 +-                  while ((*ptr == '0') && (str_len != 0))
   3.208 +-                    {
   3.209 +-                      --ptr;
   3.210 +-                      --str_len;
   3.211 +-                    }
   3.212 +-                }
   3.213 +-
   3.214 +-              if (str_len > INT_MAX)
   3.215 +-                /* too many digits in fractional part */
   3.216 +-                return -1;
   3.217 +-
   3.218 +-              if (str_len != 0)
   3.219 +-                /* some digits in fractional part */
   3.220 +-                {
   3.221 +-                  np->point = MPFR_DECIMAL_POINT;
   3.222 +-                  np->fp_ptr = str + np->ip_size;
   3.223 +-                  np->fp_size = str_len;
   3.224 +-                }
   3.225 ++              --ptr;
   3.226 ++              --str_len;
   3.227 +             }
   3.228 +         }
   3.229 +-      else
   3.230 +-        /* spec.prec digits in fractional part */
   3.231 +-        {
   3.232 +-          if (np->ip_size == exp - 1)
   3.233 +-            /* the absolute value of the number has been rounded up to a power
   3.234 +-               of ten.
   3.235 +-               Insert an additional zero in integral part and put the rest of
   3.236 +-               them in fractional part. */
   3.237 +-            np->ip_trailing_zeros = 1;
   3.238 + 
   3.239 +-          if (spec.prec != 0)
   3.240 +-            {
   3.241 +-              MPFR_ASSERTD (np->ip_size + np->ip_trailing_zeros == exp);
   3.242 +-              MPFR_ASSERTD (np->ip_size + spec.prec == nsd);
   3.243 ++      if (str_len > 0)
   3.244 ++        /* some nonzero digits in fractional part */
   3.245 ++        {
   3.246 ++          if (str_len > INT_MAX)
   3.247 ++            /* too many digits in fractional part */
   3.248 ++            return -1;
   3.249 ++
   3.250 ++          np->point = MPFR_DECIMAL_POINT;
   3.251 ++          np->fp_ptr = str;
   3.252 ++          np->fp_size = str_len;
   3.253 ++        }
   3.254 + 
   3.255 +-              np->point = MPFR_DECIMAL_POINT;
   3.256 +-              np->fp_ptr = str + np->ip_size;
   3.257 +-              np->fp_size = spec.prec;
   3.258 +-            }
   3.259 +-          else if (spec.alt)
   3.260 +-            np->point = MPFR_DECIMAL_POINT;
   3.261 ++      if (keep_trailing_zeros && str_len < spec.prec)
   3.262 ++        /* add missing trailing zeros */
   3.263 ++        {
   3.264 ++          np->point = MPFR_DECIMAL_POINT;
   3.265 ++          np->fp_trailing_zeros = spec.prec - np->fp_size;
   3.266 +         }
   3.267 ++
   3.268 ++      if (spec.alt)
   3.269 ++        /* add decimal point even if no digits follow it */
   3.270 ++        np->point = MPFR_DECIMAL_POINT;
   3.271 +     }
   3.272 + 
   3.273 +   return 0;
   3.274 +diff -Naur mpfr-3.1.0.orig/src/version.c mpfr-3.1.0/src/version.c
   3.275 +--- mpfr-3.1.0.orig/src/version.c	2011-10-03 08:17:09.000000000 +0000
   3.276 ++++ mpfr-3.1.0/src/version.c	2011-11-28 12:22:52.000000000 +0000
   3.277 +@@ -25,5 +25,5 @@
   3.278 + const char *
   3.279 + mpfr_get_version (void)
   3.280 + {
   3.281 +-  return "3.1.0";
   3.282 ++  return "3.1.0-p4";
   3.283 + }
   3.284 +diff -Naur mpfr-3.1.0.orig/tests/Makefile.am mpfr-3.1.0/tests/Makefile.am
   3.285 +--- mpfr-3.1.0.orig/tests/Makefile.am	2011-10-03 08:17:14.000000000 +0000
   3.286 ++++ mpfr-3.1.0/tests/Makefile.am	2011-10-03 08:17:14.000000000 +0000
   3.287 +@@ -65,8 +65,24 @@
   3.288 + TESTS = $(check_PROGRAMS)
   3.289 + TESTS_ENVIRONMENT = MPFR_QUIET=1 $(VALGRIND)
   3.290 + 
   3.291 +-# Option to prevent libtool from generating wrapper scripts for the tests.
   3.292 ++# The -no-install option prevents libtool from generating wrapper scripts
   3.293 ++# for the tests.
   3.294 + # This is useful to easily run the test scripts under valgrind or gdb.
   3.295 + # See discussion http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/28033
   3.296 + # http://article.gmane.org/gmane.comp.lib.gnulib.bugs/28140 in particular.
   3.297 +-AM_LDFLAGS = -no-install
   3.298 ++#
   3.299 ++# The -L$(top_builddir)/src/.libs option is necessary for some platforms,
   3.300 ++# such as HP-UX, when --with-gmp or --with-gmp-lib is used and an old MPFR
   3.301 ++# library is already installed in the corresponding lib directory: its
   3.302 ++# purpose is to make sure that the local .libs comes first in the library
   3.303 ++# search path (otherwise the tests are linked against the old MPFR library
   3.304 ++# by the LINK command -- see the generated Makefile). See:
   3.305 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00042.html
   3.306 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00043.html
   3.307 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00044.html
   3.308 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00066.html
   3.309 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00065.html
   3.310 ++# and
   3.311 ++#   http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9728
   3.312 ++#
   3.313 ++AM_LDFLAGS = -no-install -L$(top_builddir)/src/.libs
   3.314 +diff -Naur mpfr-3.1.0.orig/tests/Makefile.in mpfr-3.1.0/tests/Makefile.in
   3.315 +--- mpfr-3.1.0.orig/tests/Makefile.in	2011-10-03 08:17:35.000000000 +0000
   3.316 ++++ mpfr-3.1.0/tests/Makefile.in	2011-10-03 08:17:35.000000000 +0000
   3.317 +@@ -1124,11 +1124,27 @@
   3.318 + TESTS = $(check_PROGRAMS)
   3.319 + TESTS_ENVIRONMENT = MPFR_QUIET=1 $(VALGRIND)
   3.320 + 
   3.321 +-# Option to prevent libtool from generating wrapper scripts for the tests.
   3.322 ++# The -no-install option prevents libtool from generating wrapper scripts
   3.323 ++# for the tests.
   3.324 + # This is useful to easily run the test scripts under valgrind or gdb.
   3.325 + # See discussion http://thread.gmane.org/gmane.comp.lib.gnulib.bugs/28033
   3.326 + # http://article.gmane.org/gmane.comp.lib.gnulib.bugs/28140 in particular.
   3.327 +-AM_LDFLAGS = -no-install
   3.328 ++#
   3.329 ++# The -L$(top_builddir)/src/.libs option is necessary for some platforms,
   3.330 ++# such as HP-UX, when --with-gmp or --with-gmp-lib is used and an old MPFR
   3.331 ++# library is already installed in the corresponding lib directory: its
   3.332 ++# purpose is to make sure that the local .libs comes first in the library
   3.333 ++# search path (otherwise the tests are linked against the old MPFR library
   3.334 ++# by the LINK command -- see the generated Makefile). See:
   3.335 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00042.html
   3.336 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00043.html
   3.337 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00044.html
   3.338 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00066.html
   3.339 ++#   http://websympa.loria.fr/wwsympa/arc/mpfr/2011-10/msg00065.html
   3.340 ++# and
   3.341 ++#   http://debbugs.gnu.org/cgi/bugreport.cgi?bug=9728
   3.342 ++#
   3.343 ++AM_LDFLAGS = -no-install -L$(top_builddir)/src/.libs
   3.344 + all: all-am
   3.345 + 
   3.346 + .SUFFIXES:
   3.347 +diff -Naur mpfr-3.1.0.orig/tests/trandom.c mpfr-3.1.0/tests/trandom.c
   3.348 +--- mpfr-3.1.0.orig/tests/trandom.c	2011-10-03 08:17:14.000000000 +0000
   3.349 ++++ mpfr-3.1.0/tests/trandom.c	2011-11-28 12:22:52.000000000 +0000
   3.350 +@@ -114,21 +114,29 @@
   3.351 +   mpfr_t x;
   3.352 +   gmp_randstate_t s;
   3.353 + 
   3.354 ++#if __MPFR_GMP(4,2,0)
   3.355 ++# define C1 "0.895943"
   3.356 ++# define C2 "0.848824"
   3.357 ++#else
   3.358 ++# define C1 "0.479652"
   3.359 ++# define C2 "0.648529"
   3.360 ++#endif
   3.361 ++
   3.362 +   gmp_randinit_default (s);
   3.363 +   gmp_randseed_ui (s, 42);
   3.364 +   mpfr_init2 (x, 17);
   3.365 +   mpfr_urandomb (x, s);
   3.366 +-  if (mpfr_cmp_str1 (x, "0.895943") != 0)
   3.367 ++  if (mpfr_cmp_str1 (x, C1) != 0)
   3.368 +     {
   3.369 +-      printf ("Error in bug20100914, expected 0.895943, got ");
   3.370 ++      printf ("Error in bug20100914, expected " C1 ", got ");
   3.371 +       mpfr_out_str (stdout, 10, 0, x, MPFR_RNDN);
   3.372 +       printf ("\n");
   3.373 +       exit (1);
   3.374 +     }
   3.375 +   mpfr_urandomb (x, s);
   3.376 +-  if (mpfr_cmp_str1 (x, "0.848824") != 0)
   3.377 ++  if (mpfr_cmp_str1 (x, C2) != 0)
   3.378 +     {
   3.379 +-      printf ("Error in bug20100914, expected 0.848824, got ");
   3.380 ++      printf ("Error in bug20100914, expected " C2 ", got ");
   3.381 +       mpfr_out_str (stdout, 10, 0, x, MPFR_RNDN);
   3.382 +       printf ("\n");
   3.383 +       exit (1);
   3.384 +diff -Naur mpfr-3.1.0.orig/tests/tsprintf.c mpfr-3.1.0/tests/tsprintf.c
   3.385 +--- mpfr-3.1.0.orig/tests/tsprintf.c	2011-10-03 08:17:14.000000000 +0000
   3.386 ++++ mpfr-3.1.0/tests/tsprintf.c	2011-11-03 15:15:11.000000000 +0000
   3.387 +@@ -475,6 +475,18 @@
   3.388 +   check_sprintf ("-1.", "%- #0.1RG", x);
   3.389 + 
   3.390 +   /* precision zero */
   3.391 ++  mpfr_set_d (x, 9.5, MPFR_RNDN);
   3.392 ++  check_sprintf ("9",    "%.0RDf", x);
   3.393 ++  check_sprintf ("10",    "%.0RUf", x);
   3.394 ++
   3.395 ++  mpfr_set_d (x, 19.5, MPFR_RNDN);
   3.396 ++  check_sprintf ("19",    "%.0RDf", x);
   3.397 ++  check_sprintf ("20",    "%.0RUf", x);
   3.398 ++
   3.399 ++  mpfr_set_d (x, 99.5, MPFR_RNDN);
   3.400 ++  check_sprintf ("99",    "%.0RDf", x);
   3.401 ++  check_sprintf ("100",   "%.0RUf", x);
   3.402 ++
   3.403 +   mpfr_set_d (x, -9.5, MPFR_RNDN);
   3.404 +   check_sprintf ("-10",    "%.0RDf", x);
   3.405 +   check_sprintf ("-10",    "%.0RYf", x);
   3.406 +@@ -1078,6 +1090,23 @@
   3.407 +   mpfr_clear (x);
   3.408 + }
   3.409 + 
   3.410 ++static void
   3.411 ++bug20111102 (void)
   3.412 ++{
   3.413 ++  mpfr_t t;
   3.414 ++  char s[100];
   3.415 ++
   3.416 ++  mpfr_init2 (t, 84);
   3.417 ++  mpfr_set_str (t, "999.99999999999999999999", 10, MPFR_RNDN);
   3.418 ++  mpfr_sprintf (s, "%.20RNg", t);
   3.419 ++  if (strcmp (s, "1000") != 0)
   3.420 ++    {
   3.421 ++      printf ("Error in bug20111102, expected 1000, got %s\n", s);
   3.422 ++      exit (1);
   3.423 ++    }
   3.424 ++  mpfr_clear (t);
   3.425 ++}
   3.426 ++
   3.427 + /* In particular, the following test makes sure that the rounding
   3.428 +  * for %Ra and %Rb is not done on the MPFR number itself (as it
   3.429 +  * would overflow). Note: it has been reported on comp.std.c that
   3.430 +@@ -1161,6 +1190,7 @@
   3.431 +   locale = setlocale (LC_ALL, "C");
   3.432 + #endif
   3.433 + 
   3.434 ++  bug20111102 ();
   3.435 +   native_types ();
   3.436 +   hexadecimal ();
   3.437 +   binary ();
   3.438 +diff -Naur mpfr-3.1.0.orig/tests/turandom.c mpfr-3.1.0/tests/turandom.c
   3.439 +--- mpfr-3.1.0.orig/tests/turandom.c	2011-10-03 08:17:14.000000000 +0000
   3.440 ++++ mpfr-3.1.0/tests/turandom.c	2011-11-28 12:22:52.000000000 +0000
   3.441 +@@ -160,23 +160,29 @@
   3.442 +   mpfr_t x;
   3.443 +   gmp_randstate_t s;
   3.444 + 
   3.445 ++#if __MPFR_GMP(4,2,0)
   3.446 ++# define C1 "0.8488312"
   3.447 ++# define C2 "0.8156509"
   3.448 ++#else
   3.449 ++# define C1 "0.6485367"
   3.450 ++# define C2 "0.9362717"
   3.451 ++#endif
   3.452 ++
   3.453 +   gmp_randinit_default (s);
   3.454 +   gmp_randseed_ui (s, 42);
   3.455 +   mpfr_init2 (x, 17);
   3.456 +   mpfr_urandom (x, s, MPFR_RNDN);
   3.457 +-  /* the following values are obtained on a 32-bit computer, we should get
   3.458 +-     the same values on a 64-bit computer */
   3.459 +-  if (mpfr_cmp_str1 (x, "0.8488312") != 0)
   3.460 ++  if (mpfr_cmp_str1 (x, C1) != 0)
   3.461 +     {
   3.462 +-      printf ("Error in bug20100914, expected 0.8488312, got ");
   3.463 ++      printf ("Error in bug20100914, expected " C1 ", got ");
   3.464 +       mpfr_out_str (stdout, 10, 0, x, MPFR_RNDN);
   3.465 +       printf ("\n");
   3.466 +       exit (1);
   3.467 +     }
   3.468 +   mpfr_urandom (x, s, MPFR_RNDN);
   3.469 +-  if (mpfr_cmp_str1 (x, "0.8156509") != 0)
   3.470 ++  if (mpfr_cmp_str1 (x, C2) != 0)
   3.471 +     {
   3.472 +-      printf ("Error in bug20100914, expected 0.8156509, got ");
   3.473 ++      printf ("Error in bug20100914, expected " C2 ", got ");
   3.474 +       mpfr_out_str (stdout, 10, 0, x, MPFR_RNDN);
   3.475 +       printf ("\n");
   3.476 +       exit (1);