diff options
author | Andreas Schwab <schwab@redhat.com> | 2011-10-26 11:37:08 +0200 |
---|---|---|
committer | Andreas Schwab <schwab@redhat.com> | 2011-10-26 11:44:08 +0200 |
commit | 804791474dc1f0904f6d91ef66dbbbc322991e0b (patch) | |
tree | 45bbe2612165bf4b252de5e9efbdd8c214f62dfe | |
parent | f6ce9294b0a6c5a847109cc41b7ad0c838b9ccfe (diff) | |
download | glibc-804791474dc1f0904f6d91ef66dbbbc322991e0b.tar.gz glibc-804791474dc1f0904f6d91ef66dbbbc322991e0b.tar.xz glibc-804791474dc1f0904f6d91ef66dbbbc322991e0b.zip |
Fix uses of math_force_eval
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | sysdeps/ieee754/dbl-64/s_round.c | 6 | ||||
-rw-r--r-- | sysdeps/ieee754/flt-32/e_j0f.c | 2 | ||||
-rw-r--r-- | 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 <schwab@redhat.com> + * 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; |