/** * This file has no copyright assigned and is placed in the Public Domain. * This file is part of the w64 mingw-runtime package. * No warranty is given; refer to the file DISCLAIMER.PD within this package. */ #include int __mingw_has_sse (void); /* 7.6.3.2 The fesetround function establishes the rounding direction represented by its argument round. If the argument is not equal to the value of a rounding direction macro, the rounding direction is not changed. */ int fesetround (int mode) { unsigned short _cw; if ((mode & ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO)) != 0) return -1; __asm__ volatile ("fnstcw %0;": "=m" (_cw)); _cw &= ~(FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO); _cw |= mode; __asm__ volatile ("fldcw %0;" : : "m" (_cw)); if (__mingw_has_sse ()) { int mxcsr; __asm__ volatile ("stmxcsr %0" : "=m" (*&mxcsr)); mxcsr &= ~ ((FE_TONEAREST | FE_DOWNWARD | FE_UPWARD | FE_TOWARDZERO) << 3); mxcsr |= mode << 3; __asm__ volatile ("ldmxcsr %0" : : "m" (*&mxcsr)); } return 0; }