summaryrefslogtreecommitdiff
path: root/newlib/libm/mathfp/s_numtest.c
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2017-12-15 09:38:53 -0500
committerPikalaxALT <pikalaxalt@gmail.com>2017-12-15 09:39:34 -0500
commitf95a4a932476be2ba99e2fd081e8d2bc6ea12813 (patch)
tree75f67192cb2d7b7b575c94edda318e475239b63c /newlib/libm/mathfp/s_numtest.c
parentf60aca96985e68c7d8a52eb7bc955fb80e132f73 (diff)
Import newlib and create makefile
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 0000000..b41bb87
--- /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 */