xref: /freebsd/lib/libc/tests/stdio/scanfloat_test.c (revision 559a218c9b257775fb249b67945fe4a05b7a6b9f)
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 <fenv.h>
32*1ee02192SEnji Cooper #include <float.h>
33*1ee02192SEnji Cooper #include <locale.h>
34*1ee02192SEnji Cooper #include <math.h>
35*1ee02192SEnji Cooper #include <stdio.h>
36*1ee02192SEnji Cooper #include <stdlib.h>
37*1ee02192SEnji Cooper #include <string.h>
38*1ee02192SEnji Cooper 
39*1ee02192SEnji Cooper #include <atf-c.h>
40*1ee02192SEnji Cooper 
41*1ee02192SEnji Cooper #define	eq(type, a, b)	_eq(type##_EPSILON, (a), (b))
42*1ee02192SEnji Cooper static int
_eq(long double epsilon,long double a,long double b)43*1ee02192SEnji Cooper _eq(long double epsilon, long double a, long double b)
44*1ee02192SEnji Cooper {
45*1ee02192SEnji Cooper 	long double delta;
46*1ee02192SEnji Cooper 
47*1ee02192SEnji Cooper 	delta = fabsl(a - b);
48*1ee02192SEnji Cooper 	return (delta <= epsilon);
49*1ee02192SEnji Cooper }
50*1ee02192SEnji Cooper 
51*1ee02192SEnji Cooper ATF_TC_WITHOUT_HEAD(normalized_numbers);
ATF_TC_BODY(normalized_numbers,tc)52*1ee02192SEnji Cooper ATF_TC_BODY(normalized_numbers, tc)
53*1ee02192SEnji Cooper {
54*1ee02192SEnji Cooper 	char buf[128];
55*1ee02192SEnji Cooper 	long double ld = 0.0;
56*1ee02192SEnji Cooper 	double d = 0.0;
57*1ee02192SEnji Cooper 	float f = 0.0;
58*1ee02192SEnji Cooper 
59*1ee02192SEnji Cooper 	buf[0] = '\0';
60*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, ""));
61*1ee02192SEnji Cooper 
62*1ee02192SEnji Cooper 	sscanf("3.141592", "%e", &f);
63*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(FLT, f, 3.141592));
64*1ee02192SEnji Cooper 
65*1ee02192SEnji Cooper 	sscanf("3.141592653589793", "%lf", &d);
66*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 3.141592653589793));
67*1ee02192SEnji Cooper 
68*1ee02192SEnji Cooper 	sscanf("1.234568e+06", "%E", &f);
69*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(FLT, f, 1.234568e+06));
70*1ee02192SEnji Cooper 
71*1ee02192SEnji Cooper 	sscanf("-1.234568e6", "%lF", &d);
72*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, -1.234568e6));
73*1ee02192SEnji Cooper 
74*1ee02192SEnji Cooper 	sscanf("+1.234568e-52", "%LG", &ld);
75*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(LDBL, ld, 1.234568e-52L));
76*1ee02192SEnji Cooper 
77*1ee02192SEnji Cooper 	sscanf("0.1", "%la", &d);
78*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 0.1));
79*1ee02192SEnji Cooper 
80*1ee02192SEnji Cooper 	sscanf("00.2", "%lA", &d);
81*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 0.2));
82*1ee02192SEnji Cooper 
83*1ee02192SEnji Cooper 	sscanf("123456", "%5le%s", &d, buf);
84*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 12345.));
85*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "6") == 0);
86*1ee02192SEnji Cooper 
87*1ee02192SEnji Cooper 	sscanf("1.0Q", "%*5le%s", buf);
88*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "Q") == 0);
89*1ee02192SEnji Cooper 
90*1ee02192SEnji Cooper 	sscanf("-1.23e", "%e%s", &f, buf);
91*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(FLT, f, -1.23));
92*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "e") == 0);
93*1ee02192SEnji Cooper 
94*1ee02192SEnji Cooper 	sscanf("1.25e+", "%le%s", &d, buf);
95*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 1.25));
96*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "e+") == 0);
97*1ee02192SEnji Cooper 
98*1ee02192SEnji Cooper 	sscanf("1.23E4E5", "%le%s", &d, buf);
99*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 1.23e4));
100*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "E5") == 0);
101*1ee02192SEnji Cooper 
102*1ee02192SEnji Cooper 	sscanf("12e6", "%le", &d);
103*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 12e6));
104*1ee02192SEnji Cooper 
105*1ee02192SEnji Cooper 	sscanf("1.a", "%le%s", &d, buf);
106*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 1.0));
107*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "a") == 0);
108*1ee02192SEnji Cooper 
109*1ee02192SEnji Cooper 	sscanf(".0p4", "%le%s", &d, buf);
110*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(DBL, d, 0.0));
111*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "p4") == 0);
112*1ee02192SEnji Cooper 
113*1ee02192SEnji Cooper 	d = 0.25;
114*1ee02192SEnji Cooper 	ATF_REQUIRE(sscanf(".", "%le", &d) == 0);
115*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.25);
116*1ee02192SEnji Cooper 
117*1ee02192SEnji Cooper 	sscanf("0x08", "%le", &d);
118*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x8p0);
119*1ee02192SEnji Cooper 
120*1ee02192SEnji Cooper 	sscanf("0x90a.bcdefP+09a", "%le%s", &d, buf);
121*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x90a.bcdefp+09);
122*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "a") == 0);
123*1ee02192SEnji Cooper 
124*1ee02192SEnji Cooper #if (LDBL_MANT_DIG > DBL_MANT_DIG) && !defined(__i386__)
125*1ee02192SEnji Cooper 	sscanf("3.14159265358979323846", "%Lg", &ld);
126*1ee02192SEnji Cooper 	ATF_REQUIRE(eq(LDBL, ld, 3.14159265358979323846L));
127*1ee02192SEnji Cooper 
128*1ee02192SEnji Cooper 	sscanf("  0X.0123456789abcdefffp-3g", "%Le%s", &ld, buf);
129*1ee02192SEnji Cooper 	ATF_REQUIRE(ld == 0x0.0123456789abcdefffp-3L);
130*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "g") == 0);
131*1ee02192SEnji Cooper #endif
132*1ee02192SEnji Cooper 
133*1ee02192SEnji Cooper 	sscanf("0xg", "%le%s", &d, buf);
134*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.0);
135*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "xg") == 0);
136*1ee02192SEnji Cooper 
137*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, "ru_RU.ISO8859-5")); /* decimalpoint==, */
138*1ee02192SEnji Cooper 
139*1ee02192SEnji Cooper 	sscanf("1.23", "%le%s", &d, buf);
140*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 1.0);
141*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, ".23") == 0);
142*1ee02192SEnji Cooper 
143*1ee02192SEnji Cooper 	sscanf("1,23", "%le", &d);
144*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 1.23);
145*1ee02192SEnji Cooper 
146*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, ""));
147*1ee02192SEnji Cooper }
148*1ee02192SEnji Cooper 
149*1ee02192SEnji Cooper ATF_TC_WITHOUT_HEAD(infinities_and_nans);
ATF_TC_BODY(infinities_and_nans,tc)150*1ee02192SEnji Cooper ATF_TC_BODY(infinities_and_nans, tc)
151*1ee02192SEnji Cooper {
152*1ee02192SEnji Cooper 	char buf[128];
153*1ee02192SEnji Cooper 	long double ld = 0.0;
154*1ee02192SEnji Cooper 	double d = 0.0;
155*1ee02192SEnji Cooper 	float f = 0.0;
156*1ee02192SEnji Cooper 
157*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, "C"));
158*1ee02192SEnji Cooper 
159*1ee02192SEnji Cooper 	sscanf("-Inf", "%le", &d);
160*1ee02192SEnji Cooper 	ATF_REQUIRE(d < 0.0 && isinf(d));
161*1ee02192SEnji Cooper 
162*1ee02192SEnji Cooper 	sscanf("iNfInItY and beyond", "%le%s", &d, buf);
163*1ee02192SEnji Cooper 	ATF_REQUIRE(d > 0.0 && isinf(d));
164*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, " and beyond"));
165*1ee02192SEnji Cooper 
166*1ee02192SEnji Cooper 	sscanf("NaN", "%le", &d);
167*1ee02192SEnji Cooper 	ATF_REQUIRE(isnan(d));
168*1ee02192SEnji Cooper 
169*1ee02192SEnji Cooper 	sscanf("NAN(123Y", "%le%s", &d, buf);
170*1ee02192SEnji Cooper 	ATF_REQUIRE(isnan(d));
171*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "(123Y") == 0);
172*1ee02192SEnji Cooper 
173*1ee02192SEnji Cooper 	sscanf("nan(f00f)plugh", "%le%s", &d, buf);
174*1ee02192SEnji Cooper 	ATF_REQUIRE(isnan(d));
175*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp(buf, "plugh") == 0);
176*1ee02192SEnji Cooper 
177*1ee02192SEnji Cooper 	sscanf("-nan", "%le", &d);
178*1ee02192SEnji Cooper 	ATF_REQUIRE(isnan(d));
179*1ee02192SEnji Cooper 
180*1ee02192SEnji Cooper 	/* Only quiet NaNs should be returned. */
181*1ee02192SEnji Cooper 	sscanf("NaN", "%e", &f);
182*1ee02192SEnji Cooper 	sscanf("nan", "%le", &d);
183*1ee02192SEnji Cooper 	sscanf("nan", "%Le", &ld);
184*1ee02192SEnji Cooper 	feclearexcept(FE_ALL_EXCEPT);
185*1ee02192SEnji Cooper 	ATF_REQUIRE(f != f);
186*1ee02192SEnji Cooper 	ATF_REQUIRE(d != d);
187*1ee02192SEnji Cooper 	ATF_REQUIRE(ld != ld);
188*1ee02192SEnji Cooper 	ATF_REQUIRE(fetestexcept(FE_INVALID) == 0);
189*1ee02192SEnji Cooper 	sscanf("nan(1234)", "%e", &f);
190*1ee02192SEnji Cooper 	sscanf("nan(1234)", "%le", &d);
191*1ee02192SEnji Cooper 	sscanf("nan(1234)", "%Le", &ld);
192*1ee02192SEnji Cooper 	feclearexcept(FE_ALL_EXCEPT);
193*1ee02192SEnji Cooper 	ATF_REQUIRE(f != f);
194*1ee02192SEnji Cooper 	ATF_REQUIRE(d != d);
195*1ee02192SEnji Cooper 	ATF_REQUIRE(ld != ld);
196*1ee02192SEnji Cooper 	/* POSIX says we should only generate quiet NaNs. */
197*1ee02192SEnji Cooper 	ATF_REQUIRE(fetestexcept(FE_INVALID) == 0);
198*1ee02192SEnji Cooper }
199*1ee02192SEnji Cooper 
200*1ee02192SEnji Cooper ATF_TC_WITHOUT_HEAD(rounding_tests);
ATF_TC_BODY(rounding_tests,tc)201*1ee02192SEnji Cooper ATF_TC_BODY(rounding_tests, tc)
202*1ee02192SEnji Cooper {
203*1ee02192SEnji Cooper 	long double ld = 0.0;
204*1ee02192SEnji Cooper 	double d = 0.0;
205*1ee02192SEnji Cooper 
206*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, "C"));
207*1ee02192SEnji Cooper 
208*1ee02192SEnji Cooper 	fesetround(FE_DOWNWARD);
209*1ee02192SEnji Cooper 
210*1ee02192SEnji Cooper 	sscanf("1.999999999999999999999999999999999", "%le", &d);
211*1ee02192SEnji Cooper 	ATF_REQUIRE(d < 2.0);
212*1ee02192SEnji Cooper 	sscanf("0x1.ffffffffffffffp0", "%le", &d);
213*1ee02192SEnji Cooper 	ATF_REQUIRE(d < 2.0);
214*1ee02192SEnji Cooper 	sscanf("1.999999999999999999999999999999999", "%Le", &ld);
215*1ee02192SEnji Cooper 	ATF_REQUIRE(ld < 2.0);
216*1ee02192SEnji Cooper 
217*1ee02192SEnji Cooper 	sscanf("1.0571892669084007", "%le", &d);
218*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc59p0);
219*1ee02192SEnji Cooper 	sscanf("-1.0571892669084007", "%le", &d);
220*1ee02192SEnji Cooper 	ATF_REQUIRE(d == -0x1.0ea3f4af0dc5ap0);
221*1ee02192SEnji Cooper 	sscanf("1.0571892669084010", "%le", &d);
222*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5ap0);
223*1ee02192SEnji Cooper 
224*1ee02192SEnji Cooper 	sscanf("0x1.23p-5000", "%le", &d);
225*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.0);
226*1ee02192SEnji Cooper 
227*1ee02192SEnji Cooper 	sscanf("0x1.2345678p-1050", "%le", &d);
228*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.234567p-1050);
229*1ee02192SEnji Cooper 
230*1ee02192SEnji Cooper 	fesetround(FE_UPWARD);
231*1ee02192SEnji Cooper 
232*1ee02192SEnji Cooper 	sscanf("1.0571892669084007", "%le", &d);
233*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5ap0);
234*1ee02192SEnji Cooper 	sscanf("-1.0571892669084007", "%le", &d);
235*1ee02192SEnji Cooper 	ATF_REQUIRE(d == -0x1.0ea3f4af0dc59p0);
236*1ee02192SEnji Cooper 	sscanf("1.0571892669084010", "%le", &d);
237*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5bp0);
238*1ee02192SEnji Cooper 
239*1ee02192SEnji Cooper 	sscanf("0x1.23p-5000", "%le", &d);
240*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1p-1074);
241*1ee02192SEnji Cooper 
242*1ee02192SEnji Cooper 	sscanf("0x1.2345678p-1050", "%le", &d);
243*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.234568p-1050);
244*1ee02192SEnji Cooper 
245*1ee02192SEnji Cooper 	fesetround(FE_TOWARDZERO);
246*1ee02192SEnji Cooper 
247*1ee02192SEnji Cooper 	sscanf("1.0571892669084007", "%le", &d);
248*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc59p0);
249*1ee02192SEnji Cooper 	sscanf("-1.0571892669084007", "%le", &d);
250*1ee02192SEnji Cooper 	ATF_REQUIRE(d == -0x1.0ea3f4af0dc59p0);
251*1ee02192SEnji Cooper 	sscanf("1.0571892669084010", "%le", &d);
252*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5ap0);
253*1ee02192SEnji Cooper 
254*1ee02192SEnji Cooper 	sscanf("0x1.23p-5000", "%le", &d);
255*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.0);
256*1ee02192SEnji Cooper 
257*1ee02192SEnji Cooper 	sscanf("0x1.2345678p-1050", "%le", &d);
258*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.234567p-1050);
259*1ee02192SEnji Cooper 
260*1ee02192SEnji Cooper 	fesetround(FE_TONEAREST);
261*1ee02192SEnji Cooper 
262*1ee02192SEnji Cooper 	/* 1.0571892669084007 is slightly closer to 0x1.0ea3f4af0dc59p0 */
263*1ee02192SEnji Cooper 	sscanf("1.0571892669084007", "%le", &d);
264*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc59p0);
265*1ee02192SEnji Cooper 	sscanf("-1.0571892669084007", "%le", &d);
266*1ee02192SEnji Cooper 	ATF_REQUIRE(d == -0x1.0ea3f4af0dc59p0);
267*1ee02192SEnji Cooper 	sscanf("1.0571892669084010", "%le", &d);
268*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.0ea3f4af0dc5bp0);
269*1ee02192SEnji Cooper 
270*1ee02192SEnji Cooper 	/* strtod() should round small numbers to 0. */
271*1ee02192SEnji Cooper 	sscanf("0x1.23p-5000", "%le", &d);
272*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0.0);
273*1ee02192SEnji Cooper 
274*1ee02192SEnji Cooper 	/* Extra digits in a denormal shouldn't break anything. */
275*1ee02192SEnji Cooper 	sscanf("0x1.2345678p-1050", "%le", &d);
276*1ee02192SEnji Cooper 	ATF_REQUIRE(d == 0x1.234568p-1050);
277*1ee02192SEnji Cooper }
278*1ee02192SEnji Cooper 
279*1ee02192SEnji Cooper ATF_TC_WITHOUT_HEAD(strtod);
ATF_TC_BODY(strtod,tc)280*1ee02192SEnji Cooper ATF_TC_BODY(strtod, tc)
281*1ee02192SEnji Cooper {
282*1ee02192SEnji Cooper 	char *endp;
283*1ee02192SEnji Cooper 
284*1ee02192SEnji Cooper 	ATF_REQUIRE(setlocale(LC_NUMERIC, "C"));
285*1ee02192SEnji Cooper 
286*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("0xy", &endp) == 0);
287*1ee02192SEnji Cooper 	ATF_REQUIRE(strcmp("xy", endp) == 0);
288*1ee02192SEnji Cooper 
289*1ee02192SEnji Cooper 	/* This used to cause an infinite loop and round the wrong way. */
290*1ee02192SEnji Cooper 	fesetround(FE_DOWNWARD);
291*1ee02192SEnji Cooper 	ATF_REQUIRE(strtof("3.5e38", &endp) == FLT_MAX);
292*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("2e308", &endp) == DBL_MAX);
293*1ee02192SEnji Cooper 	fesetround(FE_UPWARD);
294*1ee02192SEnji Cooper 	ATF_REQUIRE(strtof("3.5e38", &endp) == INFINITY);
295*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("2e308", &endp) == INFINITY);
296*1ee02192SEnji Cooper 	fesetround(FE_TOWARDZERO);
297*1ee02192SEnji Cooper 	ATF_REQUIRE(strtof("3.5e38", &endp) == FLT_MAX);
298*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("2e308", &endp) == DBL_MAX);
299*1ee02192SEnji Cooper 	fesetround(FE_TONEAREST);
300*1ee02192SEnji Cooper 	ATF_REQUIRE(strtof("3.5e38", &endp) == INFINITY);
301*1ee02192SEnji Cooper 	ATF_REQUIRE(strtod("2e308", &endp) == INFINITY);
302*1ee02192SEnji Cooper }
303*1ee02192SEnji Cooper 
ATF_TP_ADD_TCS(tp)304*1ee02192SEnji Cooper ATF_TP_ADD_TCS(tp)
305*1ee02192SEnji Cooper {
306*1ee02192SEnji Cooper 
307*1ee02192SEnji Cooper 	ATF_TP_ADD_TC(tp, normalized_numbers);
308*1ee02192SEnji Cooper 	ATF_TP_ADD_TC(tp, infinities_and_nans);
309*1ee02192SEnji Cooper 	ATF_TP_ADD_TC(tp, rounding_tests);
310*1ee02192SEnji Cooper 	ATF_TP_ADD_TC(tp, strtod);
311*1ee02192SEnji Cooper 
312*1ee02192SEnji Cooper 	return (atf_no_error());
313*1ee02192SEnji Cooper }
314