From 48252123bcf7a2ceed907a51fea74897fd601769 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Fri, 27 Nov 1998 11:34:40 +0000 Subject: Update. 1998-09-03 Philip Blundell * sysdeps/arm/bits/endian.h (__FLOAT_WORD_ORDER): Define to big endian. * math/math_private.h: Use __FLOAT_WORD_ORDER rather than BYTE_ORDER. * string/endian.h: If __FLOAT_WORD_ORDER wasn't defined by , make it the same as __BYTE_ORDER. 1998-11-27 Ulrich Drepper * math/math.h: Avoid using long double functions in generic macros if __NO_LONG_DOUBLE_MATH. * sysdeps/arm/dl-machine.h: Fix handling of weak undefined symbols during bootstrapping. * scripts/config.sub: Add Netwinder specific matches. Patch by Scott Bambrough . 1998-11-26 Andreas Schwab * Makeconfig ($(common-objpfx)sysd-dirs): Use automatic variables if possible. ($(common-objpfx)sysd-sorted): Likewise. 1998-11-27 Andreas Jaeger * sysdeps/libm-ieee754/e_log.c (__ieee754_log): Add declaration of local variables t1,t2 only if needed. * sysdeps/libm-ieee754/e_atan2.c: Added braces to avoid compiler warnings. * sysdeps/libm-ieee754/s_truncf.c (__truncf): Likewise. * sysdeps/libm-ieee754/s_trunc.c (__trunc): Likewise. * sysdeps/mips/mul_1.S (Loop): Add closing comment to avoid warning. 1998-11-27 Andreas Jaeger * math/math.h: Add brace to correct #if expression. --- math/math.h | 27 ++++++++++++++++++++++++++- math/math_private.h | 8 ++++---- 2 files changed, 30 insertions(+), 5 deletions(-) (limited to 'math') diff --git a/math/math.h b/math/math.h index 42f32ee..d95755f 100644 --- a/math/math.h +++ b/math/math.h @@ -83,7 +83,7 @@ __BEGIN_DECLS # undef _Mdouble_ # undef __MATH_PRECNAME -# if __STDC__ - 0 || __GNUC__ - 0 && !defined __NO_LONG_DOUBLE_MATH +# if (__STDC__ - 0 || __GNUC__ - 0) && !defined __NO_LONG_DOUBLE_MATH /* Include the file of declarations again, this time using `long double' instead of `double' and appending l to each function name. */ @@ -166,43 +166,68 @@ enum }; /* Return number of classification appropriate for X. */ +#ifdef __NO_LONG_DOUBLE_MATH +# define fpclassify(x) \ + (sizeof (x) == sizeof (float) ? __fpclassifyf (x) : __fpclassify (x)) +#else # define fpclassify(x) \ (sizeof (x) == sizeof (float) ? \ __fpclassifyf (x) \ : sizeof (x) == sizeof (double) ? \ __fpclassify (x) : __fpclassifyl (x)) +#endif /* Return nonzero value if sign of X is negative. */ +#ifdef __NO_LONG_DOUBLE_MATH +# define signbit(x) \ + (sizeof (x) == sizeof (float) ? __signbitf (x) : __signbit (x)) +#else # define signbit(x) \ (sizeof (x) == sizeof (float) ? \ __signbitf (x) \ : sizeof (x) == sizeof (double) ? \ __signbit (x) : __signbitl (x)) +#endif /* Return nonzero value if X is not +-Inf or NaN. */ +#ifdef __NO_LONG_DOUBLE_MATH +# define isfinite(x) \ + (sizeof (x) == sizeof (float) ? __finitef (x) : __finite (x)) +#else # define isfinite(x) \ (sizeof (x) == sizeof (float) ? \ __finitef (x) \ : sizeof (x) == sizeof (double) ? \ __finite (x) : __finitel (x)) +#endif /* Return nonzero value if X is neither zero, subnormal, Inf, nor NaN. */ # define isnormal(x) (fpclassify (x) == FP_NORMAL) /* Return nonzero value if X is a NaN. We could use `fpclassify' but we already have this functions `__isnan' and it is faster. */ +#ifdef __NO_LONG_DOUBLE_MATH +# define isnan(x) \ + (sizeof (x) == sizeof (float) ? __isnanf (x) : __isnan (x)) +#else # define isnan(x) \ (sizeof (x) == sizeof (float) ? \ __isnanf (x) \ : sizeof (x) == sizeof (double) ? \ __isnan (x) : __isnanl (x)) +#endif /* Return nonzero value is X is positive or negative infinity. */ +#ifdef __NO_LONG_DOUBLE_MATH +# define isinf(x) \ + (sizeof (x) == sizeof (float) ? __isinff (x) : __isinf (x)) +#else # define isinf(x) \ (sizeof (x) == sizeof (float) ? \ __isinff (x) \ : sizeof (x) == sizeof (double) ? \ __isinf (x) : __isinfl (x)) +#endif #endif /* Use ISO C 9X. */ diff --git a/math/math_private.h b/math/math_private.h index 6d51930..906b1da 100644 --- a/math/math_private.h +++ b/math/math_private.h @@ -34,7 +34,7 @@ /* A union which permits us to convert between a double and two 32 bit ints. */ -#if BYTE_ORDER == BIG_ENDIAN +#if __FLOAT_WORD_ORDER == BIG_ENDIAN typedef union { @@ -48,7 +48,7 @@ typedef union #endif -#if BYTE_ORDER == LITTLE_ENDIAN +#if __FLOAT_WORD_ORDER == LITTLE_ENDIAN typedef union { @@ -150,7 +150,7 @@ do { \ /* A union which permits us to convert between a long double and three 32 bit ints. */ -#if BYTE_ORDER == BIG_ENDIAN +#if __FLOAT_WORD_ORDER == BIG_ENDIAN typedef union { @@ -166,7 +166,7 @@ typedef union #endif -#if BYTE_ORDER == LITTLE_ENDIAN +#if __FLOAT_WORD_ORDER == LITTLE_ENDIAN typedef union { -- cgit v1.1