diff options
author | Eric Andersen <andersen@codepoet.org> | 2005-12-14 02:33:36 +0000 |
---|---|---|
committer | Eric Andersen <andersen@codepoet.org> | 2005-12-14 02:33:36 +0000 |
commit | 7635b30f9d62e33b057d830780a937c6c1d140f5 (patch) | |
tree | 9991bb6bc9f6233ed784521c588cf9e90c8520b3 /libm/powerpc/s_floor.c | |
parent | f32600208f4e9db972eb47f7d4959994b31199e6 (diff) |
Fixup byte order handling. Not all architectures define __BIG_ENDIAN__ so i.e.
on big endian mips the code is compiled as little-endian and the wrong half of
the 64-bit point value is examined to check for NaN, etc. This bug also broke
fpclassify(), isfinite(), isnormal(), isinf(), finite(), and signbit().
Diffstat (limited to 'libm/powerpc/s_floor.c')
-rw-r--r-- | libm/powerpc/s_floor.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/libm/powerpc/s_floor.c b/libm/powerpc/s_floor.c index 94677b4d2..0ddbb9b66 100644 --- a/libm/powerpc/s_floor.c +++ b/libm/powerpc/s_floor.c @@ -21,13 +21,15 @@ * * *******************************************************************************/ +#include <endian.h> + static const double twoTo52 = 4503599627370496.0; static const unsigned long signMask = 0x80000000ul; typedef union { struct { -#if defined(__BIG_ENDIAN__) +#if (__BYTE_ORDER == __BIG_ENDIAN) unsigned long int hi; unsigned long int lo; #else |