aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAurelien Jarno <aurelien@aurel32.net>2012-06-01 19:01:17 +0000
committerJoseph Myers <joseph@codesourcery.com>2012-06-01 19:01:17 +0000
commitefb734887e10cb5adb0e722012fd65df8d1f8ff5 (patch)
tree00e43dda8e6a89849f3566a9c806baf4838112f5
parent29bcce7ce456a9fe098793784b97c7e2cd446aca (diff)
downloadglibc-efb734887e10cb5adb0e722012fd65df8d1f8ff5.tar
glibc-efb734887e10cb5adb0e722012fd65df8d1f8ff5.tar.gz
glibc-efb734887e10cb5adb0e722012fd65df8d1f8ff5.tar.bz2
glibc-efb734887e10cb5adb0e722012fd65df8d1f8ff5.zip
Add a barrier in the double fma implementation.
-rw-r--r--ChangeLog5
-rw-r--r--sysdeps/ieee754/dbl-64/s_fma.c4
2 files changed, 8 insertions, 1 deletions
diff --git a/ChangeLog b/ChangeLog
index 8cc25ef497..f794e9ff4f 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2012-06-01 Aurelien Jarno <aurelien@aurel32.net>
+
+ * sysdeps/ieee754/dbl-64/s_fma.c (__fma): Ensure a1 + u.d
+ computation is not scheduled after fetestexcept.
+
2012-06-01 H.J. Lu <hongjiu.lu@intel.com>
[BZ #14117]
diff --git a/sysdeps/ieee754/dbl-64/s_fma.c b/sysdeps/ieee754/dbl-64/s_fma.c
index ab20a801a4..ce3bd36fac 100644
--- a/sysdeps/ieee754/dbl-64/s_fma.c
+++ b/sysdeps/ieee754/dbl-64/s_fma.c
@@ -1,5 +1,5 @@
/* Compute x * y + z as ternary operation.
- Copyright (C) 2010, 2011 Free Software Foundation, Inc.
+ Copyright (C) 2010-2012 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Jakub Jelinek <jakub@redhat.com>, 2010.
@@ -158,6 +158,8 @@ __fma (double x, double y, double z)
if ((u.ieee.mantissa1 & 1) == 0)
u.ieee.mantissa1 |= libc_fetestexcept (FE_INEXACT) != 0;
v.d = a1 + u.d;
+ /* Ensure the addition is not scheduled after fetestexcept call. */
+ math_force_eval (v.d);
}
/* Reset rounding mode and test for inexact simultaneously. */