From: Jakub Jelinek Date: Tue, 1 Sep 2009 22:30:12 +0000 (-0700) Subject: Fix x86_64 bits/mathinline.h for -m32 compilation. X-Git-Tag: upstream/2.30~13307 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=240441038f2d2b1a32d4239270c7f76531a484f3;p=external%2Fglibc.git Fix x86_64 bits/mathinline.h for -m32 compilation. --- diff --git a/ChangeLog b/ChangeLog index d230db7..b4e6966 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2009-09-01 Jakub Jelinek + + * sysdeps/x86_64/fpu/bits/mathinline.h: Include bits/wordsize.h. + (__signbitf, __signbit): Only use SSE inline asm for 64-bit. + 2009-08-31 Andreas Schwab * sysdeps/x86_64/fpu/bits/mathinline.h: Use __asm instead of asm. diff --git a/sysdeps/x86_64/fpu/bits/mathinline.h b/sysdeps/x86_64/fpu/bits/mathinline.h index ece0f02..dc58f67 100644 --- a/sysdeps/x86_64/fpu/bits/mathinline.h +++ b/sysdeps/x86_64/fpu/bits/mathinline.h @@ -22,6 +22,8 @@ # error "Never use directly; include instead." #endif +#include + #ifndef __extern_inline # define __MATH_INLINE __inline #else @@ -35,16 +37,26 @@ __MATH_INLINE int __NTH (__signbitf (float __x)) { +#if __WORDSIZE == 32 + __extension__ union { float __f; int __i; } __u = { __f: __x }; + return __u.__i < 0; +#else int __m; __asm ("pmovmskb %1, %0" : "=r" (__m) : "x" (__x)); return __m & 0x8; +#endif } __MATH_INLINE int __NTH (__signbit (double __x)) { +#if __WORDSIZE == 32 + __extension__ union { double __d; int __i[2]; } __u = { __d: __x }; + return __u.__i[1] < 0; +#else int __m; __asm ("pmovmskb %1, %0" : "=r" (__m) : "x" (__x)); return __m & 0x80; +#endif } __MATH_INLINE int __NTH (__signbitl (long double __x))