]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Disable x87 inline functions for SSE2 math
authorH.J. Lu <hjl.tools@gmail.com>
Wed, 29 Jan 2014 15:51:41 +0000 (07:51 -0800)
committerH.J. Lu <hjl.tools@gmail.com>
Wed, 29 Jan 2014 20:04:47 +0000 (12:04 -0800)
When i386 and x86-64 mathinline.h was merged into a single mathinline.h,
"gcc -m32" enables x87 inline functions on x86-64 even when -mfpmath=sse
and SSE2 is enabled.  It is a regression on x86-64.  We should check
__SSE2_MATH__ instead of __x86_64__ when disabling x87 inline functions.

(cherry picked from commit 409e00bd69b8d8dd74d7327085351d26769ea6fc)

Conflicts:
ChangeLog
NEWS
sysdeps/x86/fpu/bits/mathinline.h

ChangeLog
NEWS
sysdeps/x86/fpu/bits/mathinline.h

index 49bf8f90010613b5dadc0a5ac5d4ba7d16d4250f..5246373ddae507c6fd6cfdedb741926cb0cdbd12 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,9 @@
+2014-01-29  H.J. Lu  <hongjiu.lu@intel.com>
+
+       [BZ #16510]
+       * sysdeps/x86/fpu/bits/mathinline.h: Check __SSE2_MATH__ instead
+       of __x86_64__ when disabling x87 inline functions.
+
 2014-01-04  Maxim Kuvyrkov  <maxim@kugelworks.com>
            Ondřej Bílka  <neleai@seznam.cz>
 
diff --git a/NEWS b/NEWS
index c9cf487624db564c102de853156363f358a18cca..9741841fc5462202d966ea8ab2bbb785f498484d 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -8,7 +8,7 @@ using `glibc' in the "product" field.
 Version 2.17.1
 
 * The following bugs are resolved with this release:
-  15003, 15006, 15073, 15122, 15759.
+  15003, 15006, 15073, 15122, 15759, 16510.
 
 \f
 Version 2.17
index 6446b1d8755f162883c5e549ec3ec364f3475938..aba0b77cdc6683bafd9ae622daf276559db52880 100644 (file)
@@ -1,5 +1,5 @@
 /* Inline math functions for i387 and SSE.
-   Copyright (C) 1995-2012 Free Software Foundation, Inc.
+   Copyright (C) 1995-2014 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
@@ -382,7 +382,7 @@ __END_NAMESPACE_C99
 # endif
 #endif
 
-#ifndef __x86_64__
+#ifndef __SSE2_MATH__
 # if ((!defined __NO_MATH_INLINES || defined __LIBC_INTERNAL_MATH_INLINES) \
      && defined __OPTIMIZE__)
 
@@ -965,4 +965,4 @@ __inline_mathcode2 (__ieee754_atan2, __y, __x,
                    return __value;)
 # endif
 
-#endif /* !__x86_64__ */
+#endif /* !__SSE2_MATH__ */