sfp-machine.h revision 1.1.1.3 1 1.1 mrg #ifdef __MINGW32__
2 1.1 mrg /* Make sure we are using gnu-style bitfield handling. */
3 1.1 mrg #define _FP_STRUCT_LAYOUT __attribute__ ((gcc_struct))
4 1.1 mrg #endif
5 1.1 mrg
6 1.1 mrg /* The type of the result of a floating point comparison. This must
7 1.1 mrg match `__libgcc_cmp_return__' in GCC for the target. */
8 1.1 mrg typedef int __gcc_CMPtype __attribute__ ((mode (__libgcc_cmp_return__)));
9 1.1 mrg #define CMPtype __gcc_CMPtype
10 1.1 mrg
11 1.1 mrg #ifdef __x86_64__
12 1.1 mrg #include "config/i386/64/sfp-machine.h"
13 1.1 mrg #else
14 1.1 mrg #include "config/i386/32/sfp-machine.h"
15 1.1 mrg #endif
16 1.1 mrg
17 1.1 mrg #define _FP_KEEPNANFRACP 1
18 1.1.1.2 mrg #define _FP_QNANNEGATEDP 0
19 1.1 mrg
20 1.1 mrg #define _FP_NANSIGN_S 1
21 1.1 mrg #define _FP_NANSIGN_D 1
22 1.1 mrg #define _FP_NANSIGN_E 1
23 1.1 mrg #define _FP_NANSIGN_Q 1
24 1.1 mrg
25 1.1 mrg /* Here is something Intel misdesigned: the specs don't define
26 1.1 mrg the case where we have two NaNs with same mantissas, but
27 1.1 mrg different sign. Different operations pick up different NaNs. */
28 1.1 mrg #define _FP_CHOOSENAN(fs, wc, R, X, Y, OP) \
29 1.1 mrg do { \
30 1.1 mrg if (_FP_FRAC_GT_##wc(X, Y) \
31 1.1 mrg || (_FP_FRAC_EQ_##wc(X,Y) && (OP == '+' || OP == '*'))) \
32 1.1 mrg { \
33 1.1 mrg R##_s = X##_s; \
34 1.1 mrg _FP_FRAC_COPY_##wc(R,X); \
35 1.1 mrg } \
36 1.1 mrg else \
37 1.1 mrg { \
38 1.1 mrg R##_s = Y##_s; \
39 1.1 mrg _FP_FRAC_COPY_##wc(R,Y); \
40 1.1 mrg } \
41 1.1 mrg R##_c = FP_CLS_NAN; \
42 1.1 mrg } while (0)
43 1.1 mrg
44 1.1 mrg #ifndef _SOFT_FLOAT
45 1.1 mrg #define FP_EX_INVALID 0x01
46 1.1 mrg #define FP_EX_DENORM 0x02
47 1.1 mrg #define FP_EX_DIVZERO 0x04
48 1.1 mrg #define FP_EX_OVERFLOW 0x08
49 1.1 mrg #define FP_EX_UNDERFLOW 0x10
50 1.1 mrg #define FP_EX_INEXACT 0x20
51 1.1 mrg #define FP_EX_ALL \
52 1.1 mrg (FP_EX_INVALID | FP_EX_DENORM | FP_EX_DIVZERO | FP_EX_OVERFLOW \
53 1.1 mrg | FP_EX_UNDERFLOW | FP_EX_INEXACT)
54 1.1 mrg
55 1.1 mrg void __sfp_handle_exceptions (int);
56 1.1 mrg
57 1.1 mrg #define FP_HANDLE_EXCEPTIONS \
58 1.1 mrg do { \
59 1.1 mrg if (__builtin_expect (_fex, 0)) \
60 1.1 mrg __sfp_handle_exceptions (_fex); \
61 1.1.1.3 mrg } while (0)
62 1.1 mrg
63 1.1 mrg #define FP_TRAPPING_EXCEPTIONS ((~_fcw >> FP_EX_SHIFT) & FP_EX_ALL)
64 1.1 mrg
65 1.1 mrg #define FP_ROUNDMODE (_fcw & FP_RND_MASK)
66 1.1 mrg #endif
67 1.1 mrg
68 1.1.1.2 mrg #define _FP_TININESS_AFTER_ROUNDING 1
69 1.1.1.2 mrg
70 1.1 mrg #define __LITTLE_ENDIAN 1234
71 1.1 mrg #define __BIG_ENDIAN 4321
72 1.1 mrg
73 1.1 mrg #define __BYTE_ORDER __LITTLE_ENDIAN
74 1.1 mrg
75 1.1 mrg /* Define ALIASNAME as a strong alias for NAME. */
76 1.1 mrg #if defined __MACH__
77 1.1 mrg /* Mach-O doesn't support aliasing. If these functions ever return
78 1.1 mrg anything but CMPtype we need to revisit this... */
79 1.1 mrg #define strong_alias(name, aliasname) \
80 1.1 mrg CMPtype aliasname (TFtype a, TFtype b) { return name(a, b); }
81 1.1 mrg #else
82 1.1 mrg # define strong_alias(name, aliasname) _strong_alias(name, aliasname)
83 1.1 mrg # define _strong_alias(name, aliasname) \
84 1.1 mrg extern __typeof (name) aliasname __attribute__ ((alias (#name)));
85 1.1 mrg #endif
86