]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
PowerPC floating point little-endian [7 of 15]
authorAnton Blanchard <anton@au1.ibm.com>
Sat, 17 Aug 2013 08:58:06 +0000 (18:28 +0930)
committerAlan Modra <amodra@gmail.com>
Fri, 4 Oct 2013 01:04:14 +0000 (10:34 +0930)
http://sourceware.org/ml/libc-alpha/2013-08/msg00086.html

* sysdeps/powerpc/bits/mathinline.h (__signbitf): Use builtin.
(__signbit): Likewise.  Correct for little-endian.
(__signbitl): Call __signbit.
(lrint): Correct for little-endian.
(lrintf): Call lrint.

ChangeLog
sysdeps/powerpc/bits/mathinline.h

index dcb7deef9b57bdb9bf4f5df38e8f9ee488d73aa4..f03095c54c56837b1cd200a30b80dd591fb929e2 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,11 @@
+2013-10-04  Anton Blanchard <anton@au1.ibm.com>
+
+       * sysdeps/powerpc/bits/mathinline.h (__signbitf): Use builtin.
+       (__signbit): Likewise.  Correct for little-endian.
+       (__signbitl): Call __signbit.
+       (lrint): Correct for little-endian.
+       (lrintf): Call lrint.
+
 2013-10-04  Alan Modra  <amodra@gmail.com>
 
        * sysdeps/ieee754/ldbl-128ibm/e_sqrtl.c (mynumber): Replace
index 140fff08ef3e33af6fb2cad39ce7407a01dda04a..cef5b29b1440ec3d1f16f49b37d2e2bef0d5406a 100644 (file)
 __MATH_INLINE int
 __NTH (__signbitf (float __x))
 {
+#if __GNUC_PREREQ (4, 0)
+  return __builtin_signbitf (__x);
+#else
   __extension__ union { float __f; int __i; } __u = { __f: __x };
   return __u.__i < 0;
+#endif
 }
 __MATH_INLINE int
 __NTH (__signbit (double __x))
 {
-  __extension__ union { double __d; int __i[2]; } __u = { __d: __x };
-  return __u.__i[0] < 0;
+#if __GNUC_PREREQ (4, 0)
+  return __builtin_signbit (__x);
+#else
+  __extension__ union { double __d; long long __i; } __u = { __d: __x };
+  return __u.__i < 0;
+#endif
 }
 #  ifdef __LONG_DOUBLE_128__
 __MATH_INLINE int
 __NTH (__signbitl (long double __x))
 {
-  __extension__ union { long double __d; int __i[4]; } __u = { __d: __x };
-  return __u.__i[0] < 0;
+  return __signbit ((double) __x);
 }
 #  endif
 # endif
@@ -92,22 +99,17 @@ __NTH (lrint (double __x))
 {
   union {
     double __d;
-    int __ll[2];
+    long long __ll;
   } __u;
   __asm__ ("fctiw %0,%1" : "=f"(__u.__d) : "f"(__x));
-  return __u.__ll[1];
+  return __u.__ll;
 }
 
 __MATH_INLINE long int lrintf (float __x) __THROW;
 __MATH_INLINE long int
 __NTH (lrintf (float __x))
 {
-  union {
-    double __d;
-    int __ll[2];
-  } __u;
-  __asm__ ("fctiw %0,%1" : "=f"(__u.__d) : "f"(__x));
-  return __u.__ll[1];
+  return lrint ((double) __x);
 }
 # endif