olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone

Blame SOURCES/glibc-ppc64le-12.patch

00db10
# commit 2ca85d2bbbaa60b9c83bf1f57a2801c84e0a3625
00db10
# Author: Anton Blanchard <anton@au1.ibm.com>
00db10
# Date:   Sat Aug 17 18:28:06 2013 +0930
00db10
# 
00db10
#     PowerPC floating point little-endian [7 of 15]
00db10
#     http://sourceware.org/ml/libc-alpha/2013-08/msg00086.html
00db10
#     
00db10
#         * sysdeps/powerpc/bits/mathinline.h (__signbitf): Use builtin.
00db10
#         (__signbit): Likewise.  Correct for little-endian.
00db10
#         (__signbitl): Call __signbit.
00db10
#         (lrint): Correct for little-endian.
00db10
#         (lrintf): Call lrint.
00db10
# 
00db10
diff -urN glibc-2.17-c758a686/sysdeps/powerpc/fpu/bits/mathinline.h glibc-2.17-c758a686/sysdeps/powerpc/fpu/bits/mathinline.h
00db10
--- glibc-2.17-c758a686/sysdeps/powerpc/fpu/bits/mathinline.h	2014-05-27 22:28:12.000000000 -0500
00db10
+++ glibc-2.17-c758a686/sysdeps/powerpc/fpu/bits/mathinline.h	2014-05-27 22:28:37.000000000 -0500
00db10
@@ -62,21 +62,28 @@
00db10
 __MATH_INLINE int
00db10
 __NTH (__signbitf (float __x))
00db10
 {
00db10
+#if __GNUC_PREREQ (4, 0)
00db10
+  return __builtin_signbitf (__x);
00db10
+#else
00db10
   __extension__ union { float __f; int __i; } __u = { __f: __x };
00db10
   return __u.__i < 0;
00db10
+#endif
00db10
 }
00db10
 __MATH_INLINE int
00db10
 __NTH (__signbit (double __x))
00db10
 {
00db10
-  __extension__ union { double __d; int __i[2]; } __u = { __d: __x };
00db10
-  return __u.__i[0] < 0;
00db10
+#if __GNUC_PREREQ (4, 0)
00db10
+  return __builtin_signbit (__x);
00db10
+#else
00db10
+  __extension__ union { double __d; long long __i; } __u = { __d: __x };
00db10
+  return __u.__i < 0;
00db10
+#endif
00db10
 }
00db10
 #  ifdef __LONG_DOUBLE_128__
00db10
 __MATH_INLINE int
00db10
 __NTH (__signbitl (long double __x))
00db10
 {
00db10
-  __extension__ union { long double __d; int __i[4]; } __u = { __d: __x };
00db10
-  return __u.__i[0] < 0;
00db10
+  return __signbit ((double) __x);
00db10
 }
00db10
 #  endif
00db10
 # endif
00db10
@@ -93,22 +100,17 @@
00db10
 {
00db10
   union {
00db10
     double __d;
00db10
-    int __ll[2];
00db10
+    long long __ll;
00db10
   } __u;
00db10
   __asm__ ("fctiw %0,%1" : "=f"(__u.__d) : "f"(__x));
00db10
-  return __u.__ll[1];
00db10
+  return __u.__ll;
00db10
 }
00db10
 
00db10
 __MATH_INLINE long int lrintf (float __x) __THROW;
00db10
 __MATH_INLINE long int
00db10
 __NTH (lrintf (float __x))
00db10
 {
00db10
-  union {
00db10
-    double __d;
00db10
-    int __ll[2];
00db10
-  } __u;
00db10
-  __asm__ ("fctiw %0,%1" : "=f"(__u.__d) : "f"(__x));
00db10
-  return __u.__ll[1];
00db10
+  return lrint ((double) __x);
00db10
 }
00db10
 # endif
00db10