/* Copyright (C) 2012 DJ Delorie, see COPYING.DJ for details */ /* Copyright (C) 2003 DJ Delorie, see COPYING.DJ for details */ /* Copyright (C) 1995 DJ Delorie, see COPYING.DJ for details */ #ifndef __dj_include_float_h_ #define __dj_include_float_h_ #include #include #ifdef __cplusplus extern "C" { #endif extern _float_union_t __dj_float_epsilon; extern _float_union_t __dj_float_max; extern _float_union_t __dj_float_min; #define FLT_DIG 6 #define FLT_EPSILON __dj_float_epsilon.f #define FLT_MANT_DIG 24 #define FLT_MAX __dj_float_max.f #define FLT_MAX_10_EXP 38 #define FLT_MAX_EXP 128 #define FLT_MIN __dj_float_min.f #define FLT_MIN_10_EXP (-37) #define FLT_MIN_EXP (-125) #define FLT_RADIX 2 #define FLT_ROUNDS 1 extern _double_union_t __dj_double_epsilon; extern _double_union_t __dj_double_max; extern _double_union_t __dj_double_min; #define DBL_DIG 15 #define DBL_EPSILON __dj_double_epsilon.d #define DBL_MANT_DIG 53 #define DBL_MAX __dj_double_max.d #define DBL_MAX_10_EXP 308 #define DBL_MAX_EXP 1024 #define DBL_MIN __dj_double_min.d #define DBL_MIN_10_EXP (-307) #define DBL_MIN_EXP (-1021) extern _longdouble_union_t __dj_long_double_epsilon; extern _longdouble_union_t __dj_long_double_max; extern _longdouble_union_t __dj_long_double_min; #define LDBL_DIG 18 #define LDBL_EPSILON __dj_long_double_epsilon.ld #define LDBL_MANT_DIG 64 #define LDBL_MAX __dj_long_double_max.ld #define LDBL_MAX_10_EXP 4932 #define LDBL_MAX_EXP 16384 #define LDBL_MIN __dj_long_double_min.ld #define LDBL_MIN_10_EXP (-4931) #define LDBL_MIN_EXP (-16381) #if (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) \ || !defined(__STRICT_ANSI__) || defined(__cplusplus) #endif /* (__STDC_VERSION__ >= 199901L) || !__STRICT_ANSI__ */ #ifndef __dj_ENFORCE_ANSI_FREESTANDING #if (defined(__STDC_VERSION__) && __STDC_VERSION__ >= 199901L) \ || !defined(__STRICT_ANSI__) || defined(__cplusplus) #endif /* (__STDC_VERSION__ >= 199901L) || !__STRICT_ANSI__ */ #ifndef __STRICT_ANSI__ #ifndef _POSIX_SOURCE /* These indicate the results of the last operation */ #define SW_INVALID 0x0001 /* Invalid operation */ #define SW_DENORMAL 0x0002 /* Denormalized operand */ #define SW_ZERODIVIDE 0x0004 /* Division by zero */ #define SW_OVERFLOW 0x0008 /* Overflow */ #define SW_UNDERFLOW 0x0010 /* Underflow (computational) */ #define SW_INEXACT 0x0020 /* Precision (computational) */ #define SW_STACKFAULT 0x0040 /* Stack Fault (over/under flow) */ #define SW_ERRORSUMMARY 0x0080 /* Error summary */ #define SW_COND 0x4700 /* Condition Code */ #define SW_C0 0x0100 /* Condition 0 bit */ #define SW_C1 0x0200 /* Condition 1 bit (also 0=stack underflow, 1=stack overflow) */ #define SW_C2 0x0400 /* Condition 2 bit */ #define SW_C3 0x4000 /* Condition 3 bit */ #define SW_TOP 0x3800 /* Top of stack */ #define SW_TOP_SHIFT 11 /* Shift to move TOS to LSB */ #define SW_BUSY 0x8000 /* FPU busy */ #define MCW_EM 0x003f /* Exception masks (0=fault, 1=handle) */ #define EM_INVALID 0x0001 /* Invalid operation */ #define EM_DENORMAL 0x0002 /* Denormalized operand */ #define EM_ZERODIVIDE 0x0004 /* Division by zero */ #define EM_OVERFLOW 0x0008 /* Overflow */ #define EM_UNDERFLOW 0x0010 /* Underflow */ #define EM_INEXACT 0x0020 /* Precision */ #define MCW_PC 0x0300 /* precision control */ #define PC_24 0x0000 /* 24 bits (single precision) */ #define PC_53 0x0200 /* 53 bits (double precision) */ #define PC_64 0x0300 /* 64 bits (extended precision) */ #define MCW_RC 0x0c00 /* Rounding control */ #define RC_NEAR 0x0000 /* Round to nearest or even */ #define RC_DOWN 0x0400 /* Round towards -Inf */ #define RC_UP 0x0800 /* Round towards +Inf */ #define RC_CHOP 0x0c00 /* Truncate towards zero */ #define MCW_IC 0x1000 /* obsolete; i486 is always affine */ #define IC_AFFINE 0x1000 /* -Inf < +Inf */ #define IC_PROJECTIVE 0x0000 /* -Inf == +Inf */ unsigned int _clear87(void); unsigned int _control87(unsigned int newcw, unsigned int mask); void _fpreset(void); unsigned int _status87(void); extern int __emu387_load_hook; #endif /* !_POSIX_SOURCE */ #endif /* !__STRICT_ANSI__ */ #endif /* !__dj_ENFORCE_ANSI_FREESTANDING */ #ifndef __dj_ENFORCE_FUNCTION_CALLS #endif /* !__dj_ENFORCE_FUNCTION_CALLS */ #ifdef __cplusplus } #endif #endif /* !__dj_include_float_h_ */