7 // FIXME: conveniance macros
12 #if LDBL_MANT_DIG == 53 && LDBL_MAX_EXP == 1024
14 #elif LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
25 #elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
37 #error Unsupported long double representation
41 // FIXME: hacks to make freebsd+openbsd long double code happy
43 // union and macros for freebsd
45 #if LDBL_MANT_DIG == 64 && LDBL_MAX_EXP == 16384
63 #define LDBL_MANL_SIZE 32
64 #define LDBL_MANH_SIZE 32
65 #define LDBL_NBIT (1ull << LDBL_MANH_SIZE-1)
66 #undef LDBL_IMPLICIT_NBIT
67 #define mask_nbit_l(u) ((u).bits.manh &= ~LDBL_NBIT)
69 #elif LDBL_MANT_DIG == 113 && LDBL_MAX_EXP == 16384
72 //#define LDBL_MAX 1.189731495357231765085759326628007016E+4932L
73 #define LDBL_MAX 0x1.ffffffffffffffffffffffffffffp+16383
74 #define LDBL_MAX_EXP 16384
75 #define LDBL_HAS_INFINITY 1
76 //#define LDBL_MIN 3.362103143112093506262677817321752603E-4932L
77 #define LDBL_MIN 0x1p-16382
78 #define LDBL_HAS_QUIET_NAN 1
79 #define LDBL_HAS_DENORM 1
80 //#define LDBL_EPSILON 1.925929944387235853055977942584927319E-34L
81 #define LDBL_EPSILON 0x1p-112
82 #define LDBL_MANT_DIG 113
83 #define LDBL_MIN_EXP (-16381)
84 #define LDBL_MAX_10_EXP 4932
85 #define LDBL_DENORM_MIN 0x0.0000000000000000000000000001p-16381
86 #define LDBL_MIN_10_EXP (-4931)
105 #define LDBL_MANL_SIZE 64
106 #define LDBL_MANH_SIZE 48
107 #define LDBL_NBIT (1ull << LDBL_MANH_SIZE)
108 #define LDBL_IMPLICIT_NBIT 1
109 #define mask_nbit_l(u)
114 // macros for openbsd
116 #define GET_LDOUBLE_WORDS(se,mh,ml, f) do{ \
117 union IEEEl2bits u; \
119 (se) = u.xbits.expsign; \
120 (mh) = u.bits.manh; \
121 (ml) = u.bits.manl; \
124 #define SET_LDOUBLE_WORDS(f, se,mh,ml) do{ \
125 union IEEEl2bits u; \
126 u.xbits.expsign = (se); \
127 u.bits.manh = (mh); \
128 u.bits.manl = (ml); \
132 #define GET_LDOUBLE_EXP(se, f) do{ \
133 union IEEEl2bits u; \
135 (se) = u.xbits.expsign; \
138 #define SET_LDOUBLE_EXP(f, se) do{ \
139 union IEEEl2bits u; \
141 u.xbits.expsign = (se); \