1*b30d1939SAndy Fiddaman
2*b30d1939SAndy Fiddaman/* : : generated by proto : : */
3*b30d1939SAndy Fiddaman/* : : generated from contrib/ast/src/lib/libast/features/float by iffe version 2012-07-17 : : */
4*b30d1939SAndy Fiddaman
5*b30d1939SAndy Fiddaman#ifndef _def_float_ast
6*b30d1939SAndy Fiddaman#if !defined(__PROTO__)
7*b30d1939SAndy Fiddaman#  if defined(__STDC__) || defined(__cplusplus) || defined(_proto) || defined(c_plusplus)
8*b30d1939SAndy Fiddaman#    if defined(__cplusplus)
9*b30d1939SAndy Fiddaman#      define __LINKAGE__	"C"
10*b30d1939SAndy Fiddaman#    else
11*b30d1939SAndy Fiddaman#      define __LINKAGE__
12*b30d1939SAndy Fiddaman#    endif
13*b30d1939SAndy Fiddaman#    define __STDARG__
14*b30d1939SAndy Fiddaman#    define __PROTO__(x)	x
15*b30d1939SAndy Fiddaman#    define __OTORP__(x)
16*b30d1939SAndy Fiddaman#    define __PARAM__(n,o)	n
17*b30d1939SAndy Fiddaman#    if !defined(__STDC__) && !defined(__cplusplus)
18*b30d1939SAndy Fiddaman#      if !defined(c_plusplus)
19*b30d1939SAndy Fiddaman#      	define const
20*b30d1939SAndy Fiddaman#      endif
21*b30d1939SAndy Fiddaman#      define signed
22*b30d1939SAndy Fiddaman#      define void		int
23*b30d1939SAndy Fiddaman#      define volatile
24*b30d1939SAndy Fiddaman#      define __V_		char
25*b30d1939SAndy Fiddaman#    else
26*b30d1939SAndy Fiddaman#      define __V_		void
27*b30d1939SAndy Fiddaman#    endif
28*b30d1939SAndy Fiddaman#  else
29*b30d1939SAndy Fiddaman#    define __PROTO__(x)	()
30*b30d1939SAndy Fiddaman#    define __OTORP__(x)	x
31*b30d1939SAndy Fiddaman#    define __PARAM__(n,o)	o
32*b30d1939SAndy Fiddaman#    define __LINKAGE__
33*b30d1939SAndy Fiddaman#    define __V_		char
34*b30d1939SAndy Fiddaman#    define const
35*b30d1939SAndy Fiddaman#    define signed
36*b30d1939SAndy Fiddaman#    define void		int
37*b30d1939SAndy Fiddaman#    define volatile
38*b30d1939SAndy Fiddaman#  endif
39*b30d1939SAndy Fiddaman#  define __MANGLE__	__LINKAGE__
40*b30d1939SAndy Fiddaman#  if defined(__cplusplus) || defined(c_plusplus)
41*b30d1939SAndy Fiddaman#    define __VARARG__	...
42*b30d1939SAndy Fiddaman#  else
43*b30d1939SAndy Fiddaman#    define __VARARG__
44*b30d1939SAndy Fiddaman#  endif
45*b30d1939SAndy Fiddaman#  if defined(__STDARG__)
46*b30d1939SAndy Fiddaman#    define __VA_START__(p,a)	va_start(p,a)
47*b30d1939SAndy Fiddaman#  else
48*b30d1939SAndy Fiddaman#    define __VA_START__(p,a)	va_start(p)
49*b30d1939SAndy Fiddaman#  endif
50*b30d1939SAndy Fiddaman#  if !defined(__INLINE__)
51*b30d1939SAndy Fiddaman#    if defined(__cplusplus)
52*b30d1939SAndy Fiddaman#      define __INLINE__	extern __MANGLE__ inline
53*b30d1939SAndy Fiddaman#    else
54*b30d1939SAndy Fiddaman#      if defined(_WIN32) && !defined(__GNUC__)
55*b30d1939SAndy Fiddaman#      	define __INLINE__	__inline
56*b30d1939SAndy Fiddaman#      endif
57*b30d1939SAndy Fiddaman#    endif
58*b30d1939SAndy Fiddaman#  endif
59*b30d1939SAndy Fiddaman#endif
60*b30d1939SAndy Fiddaman#if !defined(__LINKAGE__)
61*b30d1939SAndy Fiddaman#define __LINKAGE__		/* 2004-08-11 transition */
62*b30d1939SAndy Fiddaman#endif
63*b30d1939SAndy Fiddaman
64*b30d1939SAndy Fiddaman#define _def_float_ast	1
65*b30d1939SAndy Fiddaman#define _sys_types	1	/* #include <sys/types.h> ok */
66*b30d1939SAndy Fiddaman#define _hdr_float	1	/* #include <float.h> ok */
67*b30d1939SAndy Fiddaman#define _hdr_limits	1	/* #include <limits.h> ok */
68*b30d1939SAndy Fiddaman#define _hdr_math	1	/* #include <math.h> ok */
69*b30d1939SAndy Fiddaman#define _hdr_values	1	/* #include <values.h> ok */
70*b30d1939SAndy Fiddaman#define _LIB_m	1	/* -lm is a library */
71*b30d1939SAndy Fiddaman#define _lib_frexp	1	/* frexp() in default lib(s) */
72*b30d1939SAndy Fiddaman#define _lib_frexpl	1	/* frexpl() in default lib(s) */
73*b30d1939SAndy Fiddaman#define _lib_ldexp	1	/* ldexp() in default lib(s) */
74*b30d1939SAndy Fiddaman#define _lib_ldexpl	1	/* ldexpl() in default lib(s) */
75*b30d1939SAndy Fiddaman#define _lib_finite	1	/* finite() in default lib(s) */
76*b30d1939SAndy Fiddaman#define _lib_isnanl	1	/* isnanl() in default lib(s) */
77*b30d1939SAndy Fiddaman#define _lib_copysign	1	/* copysign() in default lib(s) */
78*b30d1939SAndy Fiddaman#define _lib_copysignl	1	/* copysignl() in default lib(s) */
79*b30d1939SAndy Fiddaman#define _npt_finite	1	/* finite() needs a prototype */
80*b30d1939SAndy Fiddaman#define _npt_finitel	1	/* finitel() needs a prototype */
81*b30d1939SAndy Fiddaman#define _npt_isinfl	1	/* isinfl() needs a prototype */
82*b30d1939SAndy Fiddaman#define _lib_fpclassify	1	/* fpclassify present and works */
83*b30d1939SAndy Fiddaman#define _lib_isinf	1	/* isinf present and works */
84*b30d1939SAndy Fiddaman#define _lib_isnan	1	/* isnan present and works */
85*b30d1939SAndy Fiddaman#define _lib_signbit	1	/* signbit present and works */
86*b30d1939SAndy Fiddaman#include <ast_common.h>
87*b30d1939SAndy Fiddaman#include <float.h>
88*b30d1939SAndy Fiddaman#include <math.h>
89*b30d1939SAndy Fiddaman#ifndef FLT_DIG
90*b30d1939SAndy Fiddaman#define FLT_DIG 6
91*b30d1939SAndy Fiddaman#endif
92*b30d1939SAndy Fiddaman#ifndef FLT_MAX
93*b30d1939SAndy Fiddaman#define FLT_MAX 3.4028234663852885981170E+38F
94*b30d1939SAndy Fiddaman#endif
95*b30d1939SAndy Fiddaman#ifndef FLT_MAX_10_EXP
96*b30d1939SAndy Fiddaman#define FLT_MAX_10_EXP (+38)
97*b30d1939SAndy Fiddaman#endif
98*b30d1939SAndy Fiddaman#ifndef FLT_MAX_EXP
99*b30d1939SAndy Fiddaman#define FLT_MAX_EXP (+128)
100*b30d1939SAndy Fiddaman#endif
101*b30d1939SAndy Fiddaman#ifndef FLT_MIN
102*b30d1939SAndy Fiddaman#define FLT_MIN 1.1754943508222875079688E-38F
103*b30d1939SAndy Fiddaman#endif
104*b30d1939SAndy Fiddaman#ifndef FLT_MIN_10_EXP
105*b30d1939SAndy Fiddaman#define FLT_MIN_10_EXP (-37)
106*b30d1939SAndy Fiddaman#endif
107*b30d1939SAndy Fiddaman#ifndef FLT_MIN_EXP
108*b30d1939SAndy Fiddaman#define FLT_MIN_EXP (-125)
109*b30d1939SAndy Fiddaman#endif
110*b30d1939SAndy Fiddaman#ifndef DBL_DIG
111*b30d1939SAndy Fiddaman#define DBL_DIG 15
112*b30d1939SAndy Fiddaman#endif
113*b30d1939SAndy Fiddaman#ifndef DBL_MAX
114*b30d1939SAndy Fiddaman#define DBL_MAX 1.7976931348623157081452E+308
115*b30d1939SAndy Fiddaman#endif
116*b30d1939SAndy Fiddaman#ifndef DBL_MAX_10_EXP
117*b30d1939SAndy Fiddaman#define DBL_MAX_10_EXP (+308)
118*b30d1939SAndy Fiddaman#endif
119*b30d1939SAndy Fiddaman#ifndef DBL_MAX_EXP
120*b30d1939SAndy Fiddaman#define DBL_MAX_EXP (+1024)
121*b30d1939SAndy Fiddaman#endif
122*b30d1939SAndy Fiddaman#ifndef DBL_MIN
123*b30d1939SAndy Fiddaman#define DBL_MIN 2.2250738585072013830903E-308
124*b30d1939SAndy Fiddaman#endif
125*b30d1939SAndy Fiddaman#ifndef DBL_MIN_10_EXP
126*b30d1939SAndy Fiddaman#define DBL_MIN_10_EXP (-307)
127*b30d1939SAndy Fiddaman#endif
128*b30d1939SAndy Fiddaman#ifndef DBL_MIN_EXP
129*b30d1939SAndy Fiddaman#define DBL_MIN_EXP (-1021)
130*b30d1939SAndy Fiddaman#endif
131*b30d1939SAndy Fiddaman#ifndef LDBL_DIG
132*b30d1939SAndy Fiddaman#define LDBL_DIG 33
133*b30d1939SAndy Fiddaman#endif
134*b30d1939SAndy Fiddaman#ifndef LDBL_MAX
135*b30d1939SAndy Fiddaman#define LDBL_MAX 1.189731495357231765085759326628007016E+4932L
136*b30d1939SAndy Fiddaman#endif
137*b30d1939SAndy Fiddaman#ifndef LDBL_MAX_10_EXP
138*b30d1939SAndy Fiddaman#define LDBL_MAX_10_EXP (+4932)
139*b30d1939SAndy Fiddaman#endif
140*b30d1939SAndy Fiddaman#ifndef LDBL_MAX_EXP
141*b30d1939SAndy Fiddaman#define LDBL_MAX_EXP (+16384)
142*b30d1939SAndy Fiddaman#endif
143*b30d1939SAndy Fiddaman#ifndef LDBL_MIN
144*b30d1939SAndy Fiddaman#define LDBL_MIN 3.362103143112093506262677817321752603E-4932L
145*b30d1939SAndy Fiddaman#endif
146*b30d1939SAndy Fiddaman#ifndef LDBL_MIN_10_EXP
147*b30d1939SAndy Fiddaman#define LDBL_MIN_10_EXP (-4931)
148*b30d1939SAndy Fiddaman#endif
149*b30d1939SAndy Fiddaman#ifndef LDBL_MIN_EXP
150*b30d1939SAndy Fiddaman#define LDBL_MIN_EXP (-16381)
151*b30d1939SAndy Fiddaman#endif
152*b30d1939SAndy Fiddaman
153*b30d1939SAndy Fiddaman
154*b30d1939SAndy Fiddaman#define USHRT_DIG		4
155*b30d1939SAndy Fiddaman#define UINT_DIG		9
156*b30d1939SAndy Fiddaman#define ULONG_DIG		9
157*b30d1939SAndy Fiddaman#define ULLONG_DIG		19
158*b30d1939SAndy Fiddaman#define UINTMAX_DIG		ULLONG_DIG
159*b30d1939SAndy Fiddaman
160*b30d1939SAndy Fiddaman#define FLT_ULONG_MAX		4294967295.0F
161*b30d1939SAndy Fiddaman#define FLT_ULLONG_MAX		18446744073709551615.0F
162*b30d1939SAndy Fiddaman#define FLT_UINTMAX_MAX		FLT_ULLONG_MAX
163*b30d1939SAndy Fiddaman#define FLT_LONG_MAX		2147483647.0F
164*b30d1939SAndy Fiddaman#define FLT_LLONG_MAX		9223372036854775807.0F
165*b30d1939SAndy Fiddaman#define FLT_INTMAX_MAX		FLT_LLONG_MAX
166*b30d1939SAndy Fiddaman#define FLT_LONG_MIN		(-2147483648.0F)
167*b30d1939SAndy Fiddaman#define FLT_LLONG_MIN		(-9223372036854775808.0F)
168*b30d1939SAndy Fiddaman#define FLT_INTMAX_MIN		FLT_LLONG_MIN
169*b30d1939SAndy Fiddaman
170*b30d1939SAndy Fiddaman#define DBL_ULONG_MAX		4294967295.0
171*b30d1939SAndy Fiddaman#define DBL_ULLONG_MAX		18446744073709551615.0
172*b30d1939SAndy Fiddaman#define DBL_UINTMAX_MAX		DBL_ULLONG_MAX
173*b30d1939SAndy Fiddaman#define DBL_LONG_MAX		2147483647.0
174*b30d1939SAndy Fiddaman#define DBL_LLONG_MAX		9223372036854775807.0
175*b30d1939SAndy Fiddaman#define DBL_INTMAX_MAX		DBL_LLONG_MAX
176*b30d1939SAndy Fiddaman#define DBL_LONG_MIN		(-2147483648.0)
177*b30d1939SAndy Fiddaman#define DBL_LLONG_MIN		(-9223372036854775808.0)
178*b30d1939SAndy Fiddaman#define DBL_INTMAX_MIN		DBL_LLONG_MIN
179*b30d1939SAndy Fiddaman
180*b30d1939SAndy Fiddaman#define LDBL_ULONG_MAX		4294967295.0L
181*b30d1939SAndy Fiddaman#define LDBL_ULLONG_MAX		18446744073709551615.0L
182*b30d1939SAndy Fiddaman#define LDBL_UINTMAX_MAX	LDBL_ULLONG_MAX
183*b30d1939SAndy Fiddaman#define LDBL_LONG_MAX		2147483647.0L
184*b30d1939SAndy Fiddaman#define LDBL_LLONG_MAX		9223372036854775807.0L
185*b30d1939SAndy Fiddaman#define LDBL_INTMAX_MAX		LDBL_LLONG_MAX
186*b30d1939SAndy Fiddaman#define LDBL_LONG_MIN		(-2147483648.0L)
187*b30d1939SAndy Fiddaman#define LDBL_LLONG_MIN		(-9223372036854775808.0L)
188*b30d1939SAndy Fiddaman#define LDBL_INTMAX_MIN		LDBL_LLONG_MIN
189*b30d1939SAndy Fiddaman
190*b30d1939SAndy Fiddaman#define FLTMAX_UINTMAX_MAX	LDBL_UINTMAX_MAX
191*b30d1939SAndy Fiddaman#define FLTMAX_INTMAX_MAX	LDBL_INTMAX_MAX
192*b30d1939SAndy Fiddaman#define FLTMAX_INTMAX_MIN	LDBL_INTMAX_MIN
193*b30d1939SAndy Fiddaman
194*b30d1939SAndy Fiddamantypedef union _ast_dbl_exp_u
195*b30d1939SAndy Fiddaman{
196*b30d1939SAndy Fiddaman	uint32_t		e[sizeof(double)/4];
197*b30d1939SAndy Fiddaman	double			f;
198*b30d1939SAndy Fiddaman} _ast_dbl_exp_t;
199*b30d1939SAndy Fiddaman
200*b30d1939SAndy Fiddaman#define _ast_dbl_exp_index	0
201*b30d1939SAndy Fiddaman#define _ast_dbl_exp_shift	20
202*b30d1939SAndy Fiddaman
203*b30d1939SAndy Fiddamantypedef union _fltmax_exp_u
204*b30d1939SAndy Fiddaman{
205*b30d1939SAndy Fiddaman	uint32_t		e[sizeof(_ast_fltmax_t)/4];
206*b30d1939SAndy Fiddaman	_ast_fltmax_t		f;
207*b30d1939SAndy Fiddaman} _ast_fltmax_exp_t;
208*b30d1939SAndy Fiddaman
209*b30d1939SAndy Fiddaman#define _ast_fltmax_exp_index	0
210*b30d1939SAndy Fiddaman#define _ast_fltmax_exp_shift	16
211*b30d1939SAndy Fiddaman
212*b30d1939SAndy Fiddaman#define _ast_flt_unsigned_max_t	unsigned long long
213*b30d1939SAndy Fiddaman#define _ast_flt_nan_init	0x7f,0xff,0xff,0xff
214*b30d1939SAndy Fiddaman#define _ast_flt_inf_init	0x7f,0x80,0x00,0x00
215*b30d1939SAndy Fiddaman#define _ast_dbl_nan_init	0x7f,0xff,0xff,0xff,0xff,0xff,0xff,0xff
216*b30d1939SAndy Fiddaman#define _ast_dbl_inf_init	0x7f,0xf0,0x00,0x00,0x00,0x00,0x00,0x00
217*b30d1939SAndy Fiddaman#define _ast_ldbl_nan_init	0x7f,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff
218*b30d1939SAndy Fiddaman#define _ast_ldbl_inf_init	0x7f,0xff,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00
219*b30d1939SAndy Fiddaman#endif
220