[git commit master] Revert "libm: fix C99_MATH on __NO_LONG_DOUBLE_MATH hosts"

Bernhard Reutner-Fischer rep.dot.nop at gmail.com
Sat Nov 14 16:52:05 UTC 2009


commit: http://git.uclibc.org/uClibc/commit/?id=53c9f62657f222a3fefed852e1b2029033ec4014
branch: http://git.uclibc.org/uClibc/commit/?id=refs/heads/master

This reverts commit 73d6e5c41b61633e22ea74e3aa2df721512dca57.

barking up the wrong tree

Signed-off-by: Bernhard Reutner-Fischer <rep.dot.nop at gmail.com>
---
 libm/Makefile.in        |    5 +++++
 libm/ldouble_wrappers.c |   39 +++++++++++++++++++++++++++++++++++++++
 libm/math_private.h     |   13 -------------
 libm/s_finite.c         |    3 ---
 libm/s_fpclassify.c     |    3 ---
 libm/s_isinf.c          |    3 ---
 libm/s_isnan.c          |    3 ---
 libm/s_signbit.c        |    3 ---
 8 files changed, 44 insertions(+), 28 deletions(-)

diff --git a/libm/Makefile.in b/libm/Makefile.in
index f1f42f6..d17d64f 100644
--- a/libm/Makefile.in
+++ b/libm/Makefile.in
@@ -129,6 +129,11 @@ FL_MOBJ := \
 
 # Not implemented [yet?]: nexttowardl.o
 LD_MOBJ := \
+	__finitel.o \
+	__fpclassifyl.o \
+	__isinfl.o \
+	__isnanl.o \
+	__signbitl.o \
 	acoshl.o \
 	acosl.o \
 	asinhl.o \
diff --git a/libm/ldouble_wrappers.c b/libm/ldouble_wrappers.c
index 9c2e522..c53b997 100644
--- a/libm/ldouble_wrappers.c
+++ b/libm/ldouble_wrappers.c
@@ -116,6 +116,16 @@ long long func##l(long double x) \
 }
 #endif /* __i386__ && __OPTIMIZE__ */
 
+#if defined __NO_LONG_DOUBLE_MATH
+# define int_WRAPPER_C99(func) /* not needed */
+# else
+# define int_WRAPPER_C99(func) \
+int func##l(long double x) \
+{ \
+    return func((double) x); \
+} \
+libm_hidden_def(func##l)
+#endif
 
 /* Implement the following, as defined by SuSv3 */
 #if 0
@@ -491,3 +501,32 @@ long double significandl(long double x)
 	return (long double) significand((double) x);
 }
 #endif
+
+#ifdef __DO_C99_MATH__
+
+#ifdef L___fpclassifyl
+int_WRAPPER1(__fpclassify)
+libm_hidden_def(__fpclassifyl)
+#endif
+
+#ifdef L___finitel
+int_WRAPPER1(__finite)
+libm_hidden_def(__finitel)
+#endif
+
+#ifdef L___signbitl
+int_WRAPPER1(__signbit)
+libm_hidden_def(__signbitl)
+#endif
+
+#ifdef L___isnanl
+int_WRAPPER1(__isnan)
+libm_hidden_def(__isnanl)
+#endif
+
+#ifdef L___isinfl
+int_WRAPPER1(__isinf)
+libm_hidden_def(__isinfl)
+#endif
+
+#endif
diff --git a/libm/math_private.h b/libm/math_private.h
index b6bea80..2c5a30a 100644
--- a/libm/math_private.h
+++ b/libm/math_private.h
@@ -255,18 +255,5 @@ extern int    __kernel_rem_pio2 (double*,double*,int,int,int,const int*) attribu
 #define math_force_eval(x)  do { __typeof(x) __x = (x); __asm __volatile ("" : : "m" (__x)); } while (0)
 #endif
 
-/* If we do not have long double support, then alias to the double variant.  */
-#if defined __NO_LONG_DOUBLE_MATH
-# define int_WRAPPER_C99(func) \
-weak_alias(func,func##l)
-# else
-# define int_WRAPPER_C99(func) \
-int func##l(long double x) \
-{ \
-    return func((double) x); \
-} \
-libm_hidden_def(func##l)
-#endif
-
 
 #endif /* _MATH_PRIVATE_H_ */
diff --git a/libm/s_finite.c b/libm/s_finite.c
index 5b2bc29..9bbc002 100644
--- a/libm/s_finite.c
+++ b/libm/s_finite.c
@@ -30,6 +30,3 @@ int __finite(double x)
 	return (hx | 0x800fffff) != 0xffffffff;
 }
 libm_hidden_def(__finite)
-#if defined __DO_C99_MATH__
-int_WRAPPER_C99(__finite)
-#endif
diff --git a/libm/s_fpclassify.c b/libm/s_fpclassify.c
index 99a6354..a05cd56 100644
--- a/libm/s_fpclassify.c
+++ b/libm/s_fpclassify.c
@@ -40,6 +40,3 @@ int __fpclassify(double x)
   return retval;
 }
 libm_hidden_def(__fpclassify)
-#if defined __DO_C99_MATH__
-int_WRAPPER_C99(__fpclassify)
-#endif
diff --git a/libm/s_isinf.c b/libm/s_isinf.c
index 1f65b83..62e5263 100644
--- a/libm/s_isinf.c
+++ b/libm/s_isinf.c
@@ -21,6 +21,3 @@ int __isinf(double x)
 	return ~(lx >> 31) & (hx >> 30);
 }
 libm_hidden_def(__isinf)
-#if defined __DO_C99_MATH__
-int_WRAPPER_C99(__isinf)
-#endif
diff --git a/libm/s_isnan.c b/libm/s_isnan.c
index fb44f6a..1bc49cb 100644
--- a/libm/s_isnan.c
+++ b/libm/s_isnan.c
@@ -27,6 +27,3 @@ int __isnan(double x)
 	return (int)(((u_int32_t)hx)>>31);
 }
 libm_hidden_def(__isnan)
-#if defined __DO_C99_MATH__
-int_WRAPPER_C99(__isnan)
-#endif
diff --git a/libm/s_signbit.c b/libm/s_signbit.c
index ca4144a..ee1b7c6 100644
--- a/libm/s_signbit.c
+++ b/libm/s_signbit.c
@@ -33,6 +33,3 @@ __signbit (double x)
   return hx & 0x80000000;
 }
 libm_hidden_def(__signbit)
-#if defined __DO_C99_MATH__
-int_WRAPPER_C99(__signbit)
-#endif
-- 
1.6.3.3



More information about the uClibc-cvs mailing list