mirror of
git://git.musl-libc.org/musl
synced 2025-01-24 07:33:15 +00:00
5a92dd95c7
Some PowerPC CPUs (e.g. Freescale MPC85xx) have a completely different instruction set for floating point operations (SPE). Executing regular PowerPC floating point instructions results in "Illegal instruction" errors. Make it possible to run these devices in soft-float mode.
37 lines
853 B
C
37 lines
853 B
C
#ifdef _SOFT_FLOAT
|
|
#define FE_ALL_EXCEPT 0
|
|
#define FE_TONEAREST 0
|
|
#else
|
|
#define FE_TONEAREST 0
|
|
#define FE_TOWARDZERO 1
|
|
#define FE_UPWARD 2
|
|
#define FE_DOWNWARD 3
|
|
|
|
#define FE_INEXACT 0x02000000
|
|
#define FE_DIVBYZERO 0x04000000
|
|
#define FE_UNDERFLOW 0x08000000
|
|
#define FE_OVERFLOW 0x10000000
|
|
#define FE_INVALID 0x20000000
|
|
|
|
#define FE_ALL_EXCEPT 0x3e000000
|
|
|
|
#ifdef _GNU_SOURCE
|
|
#define FE_INVALID_SNAN 0x01000000
|
|
#define FE_INVALID_ISI 0x00800000
|
|
#define FE_INVALID_IDI 0x00400000
|
|
#define FE_INVALID_ZDZ 0x00200000
|
|
#define FE_INVALID_IMZ 0x00100000
|
|
#define FE_INVALID_COMPARE 0x00080000
|
|
#define FE_INVALID_SOFTWARE 0x00000400
|
|
#define FE_INVALID_SQRT 0x00000200
|
|
#define FE_INVALID_INTEGER_CONVERSION 0x00000100
|
|
|
|
#define FE_ALL_INVALID 0x01f80700
|
|
#endif
|
|
#endif
|
|
|
|
typedef unsigned fexcept_t;
|
|
typedef double fenv_t;
|
|
|
|
#define FE_DFL_ENV ((const fenv_t *)-1)
|