summaryrefslogtreecommitdiff
path: root/newlib/libm/mathfp/s_numtest.c
diff options
context:
space:
mode:
Diffstat (limited to 'newlib/libm/mathfp/s_numtest.c')
-rw-r--r--newlib/libm/mathfp/s_numtest.c58
1 files changed, 58 insertions, 0 deletions
diff --git a/newlib/libm/mathfp/s_numtest.c b/newlib/libm/mathfp/s_numtest.c
new file mode 100644
index 00000000000..b41bb87f4d7
--- /dev/null
+++ b/newlib/libm/mathfp/s_numtest.c
@@ -0,0 +1,58 @@
+
+/* @(#)z_numtest.c 1.0 98/08/13 */
+/******************************************************************
+ * Numtest
+ *
+ * Input:
+ * x - pointer to a floating point value
+ *
+ * Output:
+ * An integer that indicates what kind of number was passed in:
+ * NUM = 3 - a finite value
+ * NAN = 2 - not a number
+ * INF = 1 - an infinite value
+ * 0 - zero
+ *
+ * Description:
+ * This routine returns an integer that indicates the character-
+ * istics of the number that was passed in.
+ *
+ *****************************************************************/
+
+#include "fdlibm.h"
+#include "zmath.h"
+
+#ifndef _DOUBLE_IS_32BITS
+
+int
+_DEFUN (numtest, (double),
+ double x)
+{
+ __uint32_t hx, lx;
+ int exp;
+
+ EXTRACT_WORDS (hx, lx, x);
+
+ exp = (hx & 0x7ff00000) >> 20;
+
+ /* Check for a zero input. */
+ if (x == 0.0)
+ {
+ return (0);
+ }
+
+ /* Check for not a number or infinity. */
+ if (exp == 0x7ff)
+ {
+ if(hx & 0xf0000 || lx)
+ return (NAN);
+ else
+ return (INF);
+ }
+
+ /* Otherwise it's a finite value. */
+ else
+ return (NUM);
+}
+
+#endif /* _DOUBLE_IS_32BITS */