From 804791474dc1f0904f6d91ef66dbbbc322991e0b Mon Sep 17 00:00:00 2001 From: Andreas Schwab Date: Wed, 26 Oct 2011 11:37:08 +0200 Subject: [PATCH] Fix uses of math_force_eval --- ChangeLog | 4 ++++ sysdeps/ieee754/dbl-64/s_round.c | 6 +++--- sysdeps/ieee754/flt-32/e_j0f.c | 2 +- sysdeps/ieee754/flt-32/s_roundf.c | 4 ++-- 4 files changed, 10 insertions(+), 6 deletions(-) diff --git a/ChangeLog b/ChangeLog index 68f7766119..57c4bbe3fe 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,5 +1,9 @@ 2011-10-26 Andreas Schwab + * sysdeps/ieee754/flt-32/e_j0f.c: Fix use of math_force_eval. + * sysdeps/ieee754/dbl-64/s_round.c: Likewise. + * sysdeps/ieee754/flt-32/s_roundf.c: Likewise. + * math/math_private.h (math_force_eval): Allow non-addressable arguments. * sysdeps/i386/fpu/math_private.h (math_force_eval): Likewise. diff --git a/sysdeps/ieee754/dbl-64/s_round.c b/sysdeps/ieee754/dbl-64/s_round.c index f8a38163fc..74461967fc 100644 --- a/sysdeps/ieee754/dbl-64/s_round.c +++ b/sysdeps/ieee754/dbl-64/s_round.c @@ -38,7 +38,7 @@ __round (double x) { if (j0 < 0) { - math_force_eval (huge + x > 0.0); + math_force_eval (huge + x); i0 &= 0x80000000; if (j0 == -1) @@ -51,7 +51,7 @@ __round (double x) if (((i0 & i) | i1) == 0) /* X is integral. */ return x; - math_force_eval (huge + x > 0.0); + math_force_eval (huge + x); /* Raise inexact if x != 0. */ i0 += 0x00080000 >> j0; @@ -74,7 +74,7 @@ __round (double x) /* X is integral. */ return x; - math_force_eval (huge + x > 0.0); + math_force_eval (huge + x); /* Raise inexact if x != 0. */ u_int32_t j = i1 + (1 << (51 - j0)); diff --git a/sysdeps/ieee754/flt-32/e_j0f.c b/sysdeps/ieee754/flt-32/e_j0f.c index 181c2e46d4..0cc52c94c4 100644 --- a/sysdeps/ieee754/flt-32/e_j0f.c +++ b/sysdeps/ieee754/flt-32/e_j0f.c @@ -66,7 +66,7 @@ __ieee754_j0f(float x) return z; } if(ix<0x39000000) { /* |x| < 2**-13 */ - math_force_eval(huge+x>one); /* raise inexact if x != 0 */ + math_force_eval(huge+x); /* raise inexact if x != 0 */ if(ix<0x32000000) return one; /* |x|<2**-27 */ else return one - (float)0.25*x*x; } diff --git a/sysdeps/ieee754/flt-32/s_roundf.c b/sysdeps/ieee754/flt-32/s_roundf.c index 09b38cdc2a..f4f9dd61d3 100644 --- a/sysdeps/ieee754/flt-32/s_roundf.c +++ b/sysdeps/ieee754/flt-32/s_roundf.c @@ -37,7 +37,7 @@ __roundf (float x) { if (j0 < 0) { - math_force_eval (huge + x > 0.0F); + math_force_eval (huge + x); i0 &= 0x80000000; if (j0 == -1) @@ -49,7 +49,7 @@ __roundf (float x) if ((i0 & i) == 0) /* X is integral. */ return x; - math_force_eval (huge + x > 0.0F); + math_force_eval (huge + x); /* Raise inexact if x != 0. */ i0 += 0x00400000 >> j0;