* sysdeps/alpha/fpu/bits/mathinline.h: Honor __LIBC_INTERNAL_MATH_INL...
authorRichard Henderson <rth@redhat.com>
Tue, 24 Jun 2003 16:33:49 +0000 (16:33 +0000)
committerRichard Henderson <rth@redhat.com>
Tue, 24 Jun 2003 16:33:49 +0000 (16:33 +0000)
* sysdeps/alpha/fpu/bits/mathinline.h: Honor
__LIBC_INTERNAL_MATH_INLINES.  Implement __signbitf, __signbit.

ChangeLog
sysdeps/alpha/fpu/bits/mathinline.h

index 9bb4556be9a278af4007a7dbb0e018f94068b274..e891c2c995dc6b42c3be14b4c655f8297d213591 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -5,6 +5,9 @@
 
        * sysdeps/alpha/setjmp.S (_setjmp, setjmp): Mark .prologue.
 
+       * sysdeps/alpha/fpu/bits/mathinline.h: Honor
+       __LIBC_INTERNAL_MATH_INLINES.  Implement __signbitf, __signbit.
+
 2003-06-24  Andreas Schwab  <schwab@suse.de>
 
        * sysdeps/m68k/fpu/libm-test-ulps: Update.
index 3fb6ec2f242672193e1bd57c91be09dacc048f87..8141485b47c2060864d31211dfed8b4a3101d0f4 100644 (file)
@@ -58,7 +58,8 @@
       !isunordered(__x, __y) && __x != __y; }))
 #endif /* ISO C99 */
 
-#if !defined __NO_MATH_INLINES && defined __OPTIMIZE__
+#if (!defined __NO_MATH_INLINES || defined __LIBC_INTERNAL_MATH_INLINES) \
+    && defined __OPTIMIZE__
 
 #define __inline_copysign(NAME, TYPE)                                  \
 __MATH_INLINE TYPE                                                     \
@@ -176,6 +177,19 @@ __MATH_INLINE double fdim (double __x, double __y) __THROW
   return __x < __y ? 0.0 : __x - __y;
 }
 
+/* Test for negative number.  Used in the signbit() macro.  */
+__MATH_INLINE int __signbitf (float __x) __THROW
+{
+  __extension__ union { float __f; int __i; } __u = { __f: __x };
+  return __u.__i < 0;
+}
+
+__MATH_INLINE int __signbit (double __x) __THROW
+{
+  __extension__ union { double __d; long __i; } __u = { __d: __x };
+  return __u.__i < 0;
+}
+
 #endif /* C99 */
 
 #endif /* __NO_MATH_INLINES */