|  | /** | 
|  | * 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 <fenv.h> | 
|  |  | 
|  | 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; | 
|  | } |