xref: /freebsd/lib/libc/tests/stdio/scanfloat_test.c (revision 1ee0219205d3794b5d0dc6d885fa8895a6ec1dbf)
1*1ee02192SEnji Cooper /*-
2*1ee02192SEnji Cooper  * Copyright (C) 2003, 2005 David Schultz <das@FreeBSD.org>
3*1ee02192SEnji Cooper  * All rights reserved.
4*1ee02192SEnji Cooper  *
5*1ee02192SEnji Cooper  * Redistribution and use in source and binary forms, with or without
6*1ee02192SEnji Cooper  * modification, are permitted provided that the following conditions
7*1ee02192SEnji Cooper  * are met:
8*1ee02192SEnji Cooper  * 1. Redistributions of source code must retain the above copyright
9*1ee02192SEnji Cooper  *    notice, this list of conditions and the following disclaimer.
10*1ee02192SEnji Cooper  * 2. Redistributions in binary form must reproduce the above copyright
11*1ee02192SEnji Cooper  *    notice, this list of conditions and the following disclaimer in the
12*1ee02192SEnji Cooper  *    documentation and/or other materials provided with the distribution.
13*1ee02192SEnji Cooper  *
14*1ee02192SEnji Cooper  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15*1ee02192SEnji Cooper  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16*1ee02192SEnji Cooper  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17*1ee02192SEnji Cooper  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18*1ee02192SEnji Cooper  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19*1ee02192SEnji Cooper  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20*1ee02192SEnji Cooper  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21*1ee02192SEnji Cooper  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22*1ee02192SEnji Cooper  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23*1ee02192SEnji Cooper  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24*1ee02192SEnji Cooper  * SUCH DAMAGE.
25*1ee02192SEnji Cooper  */
26*1ee02192SEnji Cooper 
27*1ee02192SEnji Cooper /*
28*1ee02192SEnji Cooper  * Test for scanf() floating point formats.
29*1ee02192SEnji Cooper  */
30*1ee02192SEnji Cooper 
31*1ee02192SEnji Cooper #include <sys/cdefs.h>
32*1ee02192SEnji Cooper __FBSDID("$FreeBSD$");
33*1ee02192SEnji Cooper 
34*1ee02192SEnji Cooper #include <fenv.h>
35*1ee02192SEnji Cooper #include <float.h>
36*1ee02192SEnji Cooper #include <locale.h>
37*1ee02192SEnji Cooper #include <math.h>
38*1ee02192SEnji Cooper #include <stdio.h>
39*1ee02192SEnji Cooper #include <stdlib.h>
40*1ee02192SEnji Cooper #include <string.h>
41*1ee02192SEnji Cooper 
42*1ee02192SEnji Cooper #include <atf-c.h>
43*1ee02192SEnji Cooper 
44*1ee02192SEnji Cooper #define	eq(type, a, b)	_eq(type##_EPSILON, (a), (b))
45*1ee02192SEnji Cooper static int
46*1ee02192SEnji Cooper _eq(long double epsilon, long double a, long double b)
47*1ee02192SEnji Cooper {
48*1ee02192SEnji Cooper 	long double delta;
49*1ee02192SEnji Cooper 
50*1ee02192SEnji Cooper 	delta = fabsl(a - b);
51*1ee02192SEnji Cooper 	return (delta <= epsilon);
52*1ee02192SEnji Cooper }
53*1ee02192SEnji Cooper 
54*1ee02192SEnji Cooper ATF_TC_WITHOUT_HEAD(normalized_numbers);
55*1ee02192SEnji Cooper ATF_TC_BODY(normalized_numbers, tc)
56*1ee02192SEnji Cooper {
57*1ee02192SEnji Cooper 	char buf[128];
58*1ee02192SEnji Cooper 	long double ld = 0.0;
59*1ee02192SEnji Cooper 	double d = 0.0;
60*1ee02192SEnji Cooper 	float f = 0.0;
61*1ee02192SEnji Cooper 	char *endp;
62*1ee02192SEnji Cooper 
63*1ee02192SEnji Cooper 	buf[0] = '\0';
64*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, ""));
65*1ee02192SEnji Cooper 
66*1ee02192SEnji Cooper 	sscanf("3.141592", "%e", &f);
67*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(FLT, f, 3.141592));
68*1ee02192SEnji Cooper 
69*1ee02192SEnji Cooper 	sscanf("3.141592653589793", "%lf", &d);
70*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 3.141592653589793));
71*1ee02192SEnji Cooper 
72*1ee02192SEnji Cooper 	sscanf("1.234568e+06", "%E", &f);
73*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(FLT, f, 1.234568e+06));
74*1ee02192SEnji Cooper 
75*1ee02192SEnji Cooper 	sscanf("-1.234568e6", "%lF", &d);
76*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, -1.234568e6));
77*1ee02192SEnji Cooper 
78*1ee02192SEnji Cooper 	sscanf("+1.234568e-52", "%LG", &ld);
79*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(LDBL, ld, 1.234568e-52L));
80*1ee02192SEnji Cooper 
81*1ee02192SEnji Cooper 	sscanf("0.1", "%la", &d);
82*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 0.1));
83*1ee02192SEnji Cooper 
84*1ee02192SEnji Cooper 	sscanf("00.2", "%lA", &d);
85*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 0.2));
86*1ee02192SEnji Cooper 
87*1ee02192SEnji Cooper 	sscanf("123456", "%5le%s", &d, buf);
88*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 12345.));
89*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "6") == 0);
90*1ee02192SEnji Cooper 
91*1ee02192SEnji Cooper 	sscanf("1.0Q", "%*5le%s", buf);
92*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "Q") == 0);
93*1ee02192SEnji Cooper 
94*1ee02192SEnji Cooper 	sscanf("-1.23e", "%e%s", &f, buf);
95*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(FLT, f, -1.23));
96*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "e") == 0);
97*1ee02192SEnji Cooper 
98*1ee02192SEnji Cooper 	sscanf("1.25e+", "%le%s", &d, buf);
99*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 1.25));
100*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "e+") == 0);
101*1ee02192SEnji Cooper 
102*1ee02192SEnji Cooper 	sscanf("1.23E4E5", "%le%s", &d, buf);
103*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 1.23e4));
104*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "E5") == 0);
105*1ee02192SEnji Cooper 
106*1ee02192SEnji Cooper 	sscanf("12e6", "%le", &d);
107*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 12e6));
108*1ee02192SEnji Cooper 
109*1ee02192SEnji Cooper 	sscanf("1.a", "%le%s", &d, buf);
110*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 1.0));
111*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "a") == 0);
112*1ee02192SEnji Cooper 
113*1ee02192SEnji Cooper 	sscanf(".0p4", "%le%s", &d, buf);
114*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 0.0));
115*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "p4") == 0);
116*1ee02192SEnji Cooper 
117*1ee02192SEnji Cooper 	d = 0.25;
118*1ee02192SEnji Cooper 	ATF_REQUIRE(sscanf(".", "%le", &d) == 0);
119*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.25);
120*1ee02192SEnji Cooper 
121*1ee02192SEnji Cooper 	sscanf("0x08", "%le", &d);
122*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x8p0);
123*1ee02192SEnji Cooper 
124*1ee02192SEnji Cooper 	sscanf("0x90a.bcdefP+09a", "%le%s", &d, buf);
125*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x90a.bcdefp+09);
126*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "a") == 0);
127*1ee02192SEnji Cooper 
128*1ee02192SEnji Cooper #if (LDBL_MANT_DIG > DBL_MANT_DIG) && !defined(__i386__)
129*1ee02192SEnji Cooper 	sscanf("3.14159265358979323846", "%Lg", &ld);
130*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(LDBL, ld, 3.14159265358979323846L));
131*1ee02192SEnji Cooper 
132*1ee02192SEnji Cooper 	sscanf("  0X.0123456789abcdefffp-3g", "%Le%s", &ld, buf);
133*1ee02192SEnji Cooper 	ATF_REQUIRE(ld == 0x0.0123456789abcdefffp-3L);
134*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "g") == 0);
135*1ee02192SEnji Cooper #endif
136*1ee02192SEnji Cooper 
137*1ee02192SEnji Cooper 	sscanf("0xg", "%le%s", &d, buf);
138*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.0);
139*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "xg") == 0);
140*1ee02192SEnji Cooper 
141*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, "ru_RU.ISO8859-5")); /* decimalpoint==, */
142*1ee02192SEnji Cooper 
143*1ee02192SEnji Cooper 	sscanf("1.23", "%le%s", &d, buf);
144*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 1.0);
145*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, ".23") == 0);
146*1ee02192SEnji Cooper 
147*1ee02192SEnji Cooper 	sscanf("1,23", "%le", &d);
148*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 1.23);
149*1ee02192SEnji Cooper 
150*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, ""));
151*1ee02192SEnji Cooper }
152*1ee02192SEnji Cooper 
153*1ee02192SEnji Cooper ATF_TC_WITHOUT_HEAD(infinities_and_nans);
154*1ee02192SEnji Cooper ATF_TC_BODY(infinities_and_nans, tc)
155*1ee02192SEnji Cooper {
156*1ee02192SEnji Cooper 	char buf[128];
157*1ee02192SEnji Cooper 	long double ld = 0.0;
158*1ee02192SEnji Cooper 	double d = 0.0;
159*1ee02192SEnji Cooper 	float f = 0.0;
160*1ee02192SEnji Cooper 	char *endp;
161*1ee02192SEnji Cooper 
162*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, "C"));
163*1ee02192SEnji Cooper 
164*1ee02192SEnji Cooper 	sscanf("-Inf", "%le", &d);
165*1ee02192SEnji Cooper 	ATF_REQUIRE(d < 0.0 && isinf(d));
166*1ee02192SEnji Cooper 
167*1ee02192SEnji Cooper 	sscanf("iNfInItY and beyond", "%le%s", &d, buf);
168*1ee02192SEnji Cooper 	ATF_REQUIRE(d > 0.0 && isinf(d));
169*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, " and beyond"));
170*1ee02192SEnji Cooper 
171*1ee02192SEnji Cooper 	sscanf("NaN", "%le", &d);
172*1ee02192SEnji Cooper 	ATF_REQUIRE(isnan(d));
173*1ee02192SEnji Cooper 
174*1ee02192SEnji Cooper 	sscanf("NAN(123Y", "%le%s", &d, buf);
175*1ee02192SEnji Cooper 	ATF_REQUIRE(isnan(d));
176*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "(123Y") == 0);
177*1ee02192SEnji Cooper 
178*1ee02192SEnji Cooper 	sscanf("nan(f00f)plugh", "%le%s", &d, buf);
179*1ee02192SEnji Cooper 	ATF_REQUIRE(isnan(d));
180*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "plugh") == 0);
181*1ee02192SEnji Cooper 
182*1ee02192SEnji Cooper 	sscanf("-nan", "%le", &d);
183*1ee02192SEnji Cooper 	ATF_REQUIRE(isnan(d));
184*1ee02192SEnji Cooper 
185*1ee02192SEnji Cooper 	/* Only quiet NaNs should be returned. */
186*1ee02192SEnji Cooper 	sscanf("NaN", "%e", &f);
187*1ee02192SEnji Cooper 	sscanf("nan", "%le", &d);
188*1ee02192SEnji Cooper 	sscanf("nan", "%Le", &ld);
189*1ee02192SEnji Cooper 	feclearexcept(FE_ALL_EXCEPT);
190*1ee02192SEnji Cooper 	ATF_REQUIRE(f != f);
191*1ee02192SEnji Cooper 	ATF_REQUIRE(d != d);
192*1ee02192SEnji Cooper 	ATF_REQUIRE(ld != ld);
193*1ee02192SEnji Cooper 	ATF_REQUIRE(fetestexcept(FE_INVALID) == 0);
194*1ee02192SEnji Cooper 	sscanf("nan(1234)", "%e", &f);
195*1ee02192SEnji Cooper 	sscanf("nan(1234)", "%le", &d);
196*1ee02192SEnji Cooper 	sscanf("nan(1234)", "%Le", &ld);
197*1ee02192SEnji Cooper 	feclearexcept(FE_ALL_EXCEPT);
198*1ee02192SEnji Cooper 	ATF_REQUIRE(f != f);
199*1ee02192SEnji Cooper 	ATF_REQUIRE(d != d);
200*1ee02192SEnji Cooper 	ATF_REQUIRE(ld != ld);
201*1ee02192SEnji Cooper 	/* POSIX says we should only generate quiet NaNs. */
202*1ee02192SEnji Cooper 	ATF_REQUIRE(fetestexcept(FE_INVALID) == 0);
203*1ee02192SEnji Cooper }
204*1ee02192SEnji Cooper 
205*1ee02192SEnji Cooper ATF_TC_WITHOUT_HEAD(rounding_tests);
206*1ee02192SEnji Cooper ATF_TC_BODY(rounding_tests, tc)
207*1ee02192SEnji Cooper {
208*1ee02192SEnji Cooper 	char buf[128];
209*1ee02192SEnji Cooper 	long double ld = 0.0;
210*1ee02192SEnji Cooper 	double d = 0.0;
211*1ee02192SEnji Cooper 	float f = 0.0;
212*1ee02192SEnji Cooper 	char *endp;
213*1ee02192SEnji Cooper 
214*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, "C"));
215*1ee02192SEnji Cooper 
216*1ee02192SEnji Cooper 	fesetround(FE_DOWNWARD);
217*1ee02192SEnji Cooper 
218*1ee02192SEnji Cooper 	sscanf("1.999999999999999999999999999999999", "%le", &d);
219*1ee02192SEnji Cooper 	ATF_REQUIRE(d < 2.0);
220*1ee02192SEnji Cooper 	sscanf("0x1.ffffffffffffffp0", "%le", &d);
221*1ee02192SEnji Cooper 	ATF_REQUIRE(d < 2.0);
222*1ee02192SEnji Cooper 	sscanf("1.999999999999999999999999999999999", "%Le", &ld);
223*1ee02192SEnji Cooper 	ATF_REQUIRE(ld < 2.0);
224*1ee02192SEnji Cooper 
225*1ee02192SEnji Cooper 	sscanf("1.0571892669084007", "%le", &d);
226*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc59p0);
227*1ee02192SEnji Cooper 	sscanf("-1.0571892669084007", "%le", &d);
228*1ee02192SEnji Cooper 	ATF_REQUIRE(d == -0x1.0ea3f4af0dc5ap0);
229*1ee02192SEnji Cooper 	sscanf("1.0571892669084010", "%le", &d);
230*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5ap0);
231*1ee02192SEnji Cooper 
232*1ee02192SEnji Cooper 	sscanf("0x1.23p-5000", "%le", &d);
233*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.0);
234*1ee02192SEnji Cooper 
235*1ee02192SEnji Cooper 	sscanf("0x1.2345678p-1050", "%le", &d);
236*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.234567p-1050);
237*1ee02192SEnji Cooper 
238*1ee02192SEnji Cooper 	fesetround(FE_UPWARD);
239*1ee02192SEnji Cooper 
240*1ee02192SEnji Cooper 	sscanf("1.0571892669084007", "%le", &d);
241*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5ap0);
242*1ee02192SEnji Cooper 	sscanf("-1.0571892669084007", "%le", &d);
243*1ee02192SEnji Cooper 	ATF_REQUIRE(d == -0x1.0ea3f4af0dc59p0);
244*1ee02192SEnji Cooper 	sscanf("1.0571892669084010", "%le", &d);
245*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5bp0);
246*1ee02192SEnji Cooper 
247*1ee02192SEnji Cooper 	sscanf("0x1.23p-5000", "%le", &d);
248*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1p-1074);
249*1ee02192SEnji Cooper 
250*1ee02192SEnji Cooper 	sscanf("0x1.2345678p-1050", "%le", &d);
251*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.234568p-1050);
252*1ee02192SEnji Cooper 
253*1ee02192SEnji Cooper 	fesetround(FE_TOWARDZERO);
254*1ee02192SEnji Cooper 
255*1ee02192SEnji Cooper 	sscanf("1.0571892669084007", "%le", &d);
256*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc59p0);
257*1ee02192SEnji Cooper 	sscanf("-1.0571892669084007", "%le", &d);
258*1ee02192SEnji Cooper 	ATF_REQUIRE(d == -0x1.0ea3f4af0dc59p0);
259*1ee02192SEnji Cooper 	sscanf("1.0571892669084010", "%le", &d);
260*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5ap0);
261*1ee02192SEnji Cooper 
262*1ee02192SEnji Cooper 	sscanf("0x1.23p-5000", "%le", &d);
263*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.0);
264*1ee02192SEnji Cooper 
265*1ee02192SEnji Cooper 	sscanf("0x1.2345678p-1050", "%le", &d);
266*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.234567p-1050);
267*1ee02192SEnji Cooper 
268*1ee02192SEnji Cooper 	fesetround(FE_TONEAREST);
269*1ee02192SEnji Cooper 
270*1ee02192SEnji Cooper 	/* 1.0571892669084007 is slightly closer to 0x1.0ea3f4af0dc59p0 */
271*1ee02192SEnji Cooper 	sscanf("1.0571892669084007", "%le", &d);
272*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc59p0);
273*1ee02192SEnji Cooper 	sscanf("-1.0571892669084007", "%le", &d);
274*1ee02192SEnji Cooper 	ATF_REQUIRE(d == -0x1.0ea3f4af0dc59p0);
275*1ee02192SEnji Cooper 	sscanf("1.0571892669084010", "%le", &d);
276*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5bp0);
277*1ee02192SEnji Cooper 
278*1ee02192SEnji Cooper 	/* strtod() should round small numbers to 0. */
279*1ee02192SEnji Cooper 	sscanf("0x1.23p-5000", "%le", &d);
280*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.0);
281*1ee02192SEnji Cooper 
282*1ee02192SEnji Cooper 	/* Extra digits in a denormal shouldn't break anything. */
283*1ee02192SEnji Cooper 	sscanf("0x1.2345678p-1050", "%le", &d);
284*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.234568p-1050);
285*1ee02192SEnji Cooper }
286*1ee02192SEnji Cooper 
287*1ee02192SEnji Cooper ATF_TC_WITHOUT_HEAD(strtod);
288*1ee02192SEnji Cooper ATF_TC_BODY(strtod, tc)
289*1ee02192SEnji Cooper {
290*1ee02192SEnji Cooper 	char buf[128];
291*1ee02192SEnji Cooper 	long double ld = 0.0;
292*1ee02192SEnji Cooper 	double d = 0.0;
293*1ee02192SEnji Cooper 	float f = 0.0;
294*1ee02192SEnji Cooper 	char *endp;
295*1ee02192SEnji Cooper 
296*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, "C"));
297*1ee02192SEnji Cooper 
298*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("0xy", &endp) == 0);
299*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp("xy", endp) == 0);
300*1ee02192SEnji Cooper 
301*1ee02192SEnji Cooper 	/* This used to cause an infinite loop and round the wrong way. */
302*1ee02192SEnji Cooper 	fesetround(FE_DOWNWARD);
303*1ee02192SEnji Cooper 	ATF_REQUIRE(strtof("3.5e38", &endp) == FLT_MAX);
304*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("2e308", &endp) == DBL_MAX);
305*1ee02192SEnji Cooper 	fesetround(FE_UPWARD);
306*1ee02192SEnji Cooper 	ATF_REQUIRE(strtof("3.5e38", &endp) == INFINITY);
307*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("2e308", &endp) == INFINITY);
308*1ee02192SEnji Cooper 	fesetround(FE_TOWARDZERO);
309*1ee02192SEnji Cooper 	ATF_REQUIRE(strtof("3.5e38", &endp) == FLT_MAX);
310*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("2e308", &endp) == DBL_MAX);
311*1ee02192SEnji Cooper 	fesetround(FE_TONEAREST);
312*1ee02192SEnji Cooper 	ATF_REQUIRE(strtof("3.5e38", &endp) == INFINITY);
313*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("2e308", &endp) == INFINITY);
314*1ee02192SEnji Cooper }
315*1ee02192SEnji Cooper 
316*1ee02192SEnji Cooper ATF_TP_ADD_TCS(tp)
317*1ee02192SEnji Cooper {
318*1ee02192SEnji Cooper 
319*1ee02192SEnji Cooper 	ATF_TP_ADD_TC(tp, normalized_numbers);
320*1ee02192SEnji Cooper 	ATF_TP_ADD_TC(tp, infinities_and_nans);
321*1ee02192SEnji Cooper 	ATF_TP_ADD_TC(tp, rounding_tests);
322*1ee02192SEnji Cooper 	ATF_TP_ADD_TC(tp, strtod);
323*1ee02192SEnji Cooper 
324*1ee02192SEnji Cooper 	return (atf_no_error());
325*1ee02192SEnji Cooper }
326