Home | History | Annotate | Line # | Download | only in i386
sfp-machine.h revision 1.1.1.6
      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.3  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.6  mrg   } while (0)
     62      1.1  mrg 
     63  1.1.1.2  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.3  mrg #define _FP_TININESS_AFTER_ROUNDING 1
     69  1.1.1.3  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