summaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authordas <das@FreeBSD.org>2005-03-01 01:43:20 +0000
committerdas <das@FreeBSD.org>2005-03-01 01:43:20 +0000
commit1f1be767596a0f106552beeca1d4544509f3a6de (patch)
treee6aa527f9ed0441ec2c9c47ad41009c228386101 /tools
parent8448d779357c1df239a3f3bb2a966a30d1547899 (diff)
downloadFreeBSD-src-1f1be767596a0f106552beeca1d4544509f3a6de.zip
FreeBSD-src-1f1be767596a0f106552beeca1d4544509f3a6de.tar.gz
- Split tests into three rough categories.
- Use fesetround() instead of fpsetround(), and add tests for various rounding modes. - Test that all NaNs generated are quiet. Some of these tests won't pass until problems in vendor sources (gdtoa and gcc) are fixed and new versions imported, but I want to get these changes into the tree before I accidentally blow them away again. :-(
Diffstat (limited to 'tools')
-rw-r--r--tools/regression/lib/libc/stdio/test-scanfloat.c104
1 files changed, 98 insertions, 6 deletions
diff --git a/tools/regression/lib/libc/stdio/test-scanfloat.c b/tools/regression/lib/libc/stdio/test-scanfloat.c
index 1071b2c..3d4e159 100644
--- a/tools/regression/lib/libc/stdio/test-scanfloat.c
+++ b/tools/regression/lib/libc/stdio/test-scanfloat.c
@@ -1,5 +1,5 @@
/*-
- * Copyright (C) 2003 David Schultz <das@FreeBSD.org>
+ * Copyright (C) 2003, 2005 David Schultz <das@FreeBSD.org>
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
@@ -32,8 +32,8 @@
__FBSDID("$FreeBSD$");
#include <assert.h>
+#include <fenv.h>
#include <float.h>
-#include <ieeefp.h>
#include <locale.h>
#include <math.h>
#include <stdio.h>
@@ -52,13 +52,16 @@ main(int argc, char *argv[])
double d = 0.0;
float f = 0.0;
- printf("1..1\n");
+ printf("1..3\n");
buf[0] = '\0';
assert(setlocale(LC_NUMERIC, ""));
__scanfdebug = 1;
+ /*
+ * Various tests for normalized numbers
+ */
sscanf("3.141592", "%e", &f);
assert(eq(FLT, f, 3.141592));
@@ -142,9 +145,14 @@ main(int argc, char *argv[])
sscanf("1,23", "%le", &d);
assert(d == 1.23);
-
+
assert(setlocale(LC_NUMERIC, ""));
+ printf("ok 1 - scanfloat\n");
+
+ /*
+ * Infinity and NaN tests
+ */
sscanf("-Inf", "%le", &d);
assert(d < 0.0 && isinf(d));
@@ -166,7 +174,91 @@ main(int argc, char *argv[])
sscanf("-nan", "%le", &d);
assert(isnan(d));
- fpsetround(FP_RN);
+ /* Only quiet NaNs should be returned. */
+ sscanf("NaN", "%e", &f);
+ sscanf("nan", "%le", &d);
+ sscanf("nan", "%Le", &ld);
+ feclearexcept(FE_ALL_EXCEPT);
+ assert(f != f);
+ assert(d != d);
+ assert(ld != ld);
+ assert(fetestexcept(FE_INVALID) == 0);
+ sscanf("nan(1234)", "%e", &f);
+ sscanf("nan(1234)", "%le", &d);
+ sscanf("nan(1234)", "%Le", &ld);
+ feclearexcept(FE_ALL_EXCEPT);
+ assert(f != f);
+ assert(d != d);
+ assert(ld != ld);
+ assert(fetestexcept(FE_INVALID) == 0);
+
+ printf("ok 2 - scanfloat\n");
+
+ /*
+ * Rounding tests
+ */
+
+ fesetround(FE_DOWNWARD);
+
+ sscanf("1.999999999999999999999999999999999", "%le", &d);
+ assert(d < 2.0);
+ sscanf("0x1.ffffffffffffffp0", "%le", &d);
+ assert(d < 2.0);
+ sscanf("1.999999999999999999999999999999999", "%Le", &ld);
+ assert(ld < 2.0);
+
+ sscanf("1.0571892669084007", "%le", &d);
+ assert(d == 0x1.0ea3f4af0dc59p0);
+ sscanf("-1.0571892669084007", "%le", &d);
+ assert(d == -0x1.0ea3f4af0dc5ap0);
+ sscanf("1.0571892669084010", "%le", &d);
+ assert(d == 0x1.0ea3f4af0dc5ap0);
+
+ sscanf("0x1.23p-5000", "%le", &d);
+ assert(d == 0.0);
+
+ sscanf("0x1.2345678p-1050", "%le", &d);
+ assert(d == 0x1.234568p-1050);
+
+ fesetround(FE_UPWARD);
+
+ sscanf("1.0571892669084007", "%le", &d);
+ assert(d == 0x1.0ea3f4af0dc5ap0);
+ sscanf("-1.0571892669084007", "%le", &d);
+ assert(d == -0x1.0ea3f4af0dc59p0);
+ sscanf("1.0571892669084010", "%le", &d);
+ assert(d == 0x1.0ea3f4af0dc5bp0);
+
+ sscanf("0x1.23p-5000", "%le", &d);
+ assert(d == 0x1p-1074);
+
+ sscanf("0x1.2345678p-1050", "%le", &d);
+ assert(d == 0x1.234568p-1050);
+
+ fesetround(FE_TOWARDZERO);
+
+ sscanf("1.0571892669084007", "%le", &d);
+ assert(d == 0x1.0ea3f4af0dc59p0);
+ sscanf("-1.0571892669084007", "%le", &d);
+ assert(d == -0x1.0ea3f4af0dc59p0);
+ sscanf("1.0571892669084010", "%le", &d);
+ assert(d == 0x1.0ea3f4af0dc5ap0);
+
+ sscanf("0x1.23p-5000", "%le", &d);
+ assert(d == 0.0);
+
+ sscanf("0x1.2345678p-1050", "%le", &d);
+ assert(d == 0x1.234568p-1050);
+
+ fesetround(FE_TONEAREST);
+
+ /* 1.0571892669084007 is slightly closer to 0x1.0ea3f4af0dc59p0 */
+ sscanf("1.0571892669084007", "%le", &d);
+ assert(d == 0x1.0ea3f4af0dc59p0);
+ sscanf("-1.0571892669084007", "%le", &d);
+ assert(d == -0x1.0ea3f4af0dc59p0);
+ sscanf("1.0571892669084010", "%le", &d);
+ assert(d == 0x1.0ea3f4af0dc5bp0);
/* strtod() should round small numbers to 0. */
sscanf("0x1.23p-5000", "%le", &d);
@@ -176,7 +268,7 @@ main(int argc, char *argv[])
sscanf("0x1.2345678p-1050", "%le", &d);
assert(d == 0x1.234568p-1050);
- printf("ok 1 - scanfloat\n");
+ printf("ok 3 - scanfloat\n");
return (0);
}
OpenPOWER on IntegriCloud