Subversion Repositories planix.SVN

Rev

Rev 2 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 - 1
#ifndef __FLOAT
2
#define __FLOAT
3
/* IEEE, default rounding */
4
 
5
#define FLT_ROUNDS	1
6
#define FLT_RADIX	2
7
 
8
#define FLT_DIG		6
9
#define FLT_EPSILON	1.19209290e-07
10
#define FLT_MANT_DIG	24
11
#define FLT_MAX		3.40282347e+38
12
#define FLT_MAX_10_EXP	38
13
#define FLT_MAX_EXP	128
14
#define FLT_MIN		1.17549435e-38
15
#define FLT_MIN_10_EXP	-37
16
#define FLT_MIN_EXP	-125
17
 
18
#define DBL_DIG		15
19
#define DBL_EPSILON	2.2204460492503131e-16
20
#define DBL_MANT_DIG	53
21
#define DBL_MAX		1.797693134862315708145e+308
22
#define DBL_MAX_10_EXP	308
23
#define DBL_MAX_EXP	1024
24
#define DBL_MIN		2.225073858507201383090233e-308
25
#define DBL_MIN_10_EXP	-307
26
#define DBL_MIN_EXP	-1021
27
#define LDBL_MANT_DIG	DBL_MANT_DIG
28
#define LDBL_EPSILON	DBL_EPSILON
29
#define LDBL_DIG	DBL_DIG
30
#define LDBL_MIN_EXP	DBL_MIN_EXP
31
#define LDBL_MIN	DBL_MIN
32
#define LDBL_MIN_10_EXP	DBL_MIN_10_EXP
33
#define LDBL_MAX_EXP	DBL_MAX_EXP
34
#define LDBL_MAX	DBL_MAX
35
#define LDBL_MAX_10_EXP	DBL_MAX_10_EXP
36
 
37
typedef 	union FPdbleword FPdbleword;
38
union FPdbleword
39
{
40
	double	x;
41
	struct {	/* big endian */
42
		long hi;
43
		long lo;
44
	};
45
};
46
 
47
#ifdef _RESEARCH_SOURCE
48
/* define order of longs in IEEE double: little endian */
49
#define IEEE_MC68k	1
50
#define Sudden_Underflow 1
51
#endif
52
#ifdef _PLAN9_SOURCE
53
/* FCR */
54
#define	FPINEX	(1<<23)
55
#define	FPOVFL	(1<<26)
56
#define	FPUNFL	(1<<25)
57
#define	FPZDIV	(1<<24)
58
#define	FPRNR	(0<<30)
59
#define	FPRZ	(1<<30)
60
#define	FPRPINF	(2<<30)
61
#define	FPRNINF	(3<<30)
62
#define	FPRMASK	(3<<30)
63
#define	FPPEXT	0
64
#define	FPPSGL	0
65
#define	FPPDBL	0
66
#define	FPPMASK	0
67
/* FSR */
68
#define	FPAINEX	(1<<5)
69
#define	FPAOVFL	(1<<8)
70
#define	FPAUNFL	(1<<7)
71
#define	FPAZDIV	(1<<6)
72
#endif
73
#endif /* __FLOAT */