2002-06-13 18:20:48 +08:00
|
|
|
#include <fenv.h>
|
2006-07-03 18:32:58 +08:00
|
|
|
#include "cpu_features.h"
|
2002-06-13 18:20:48 +08:00
|
|
|
|
|
|
|
/* 7.6.2.4
|
|
|
|
The fesetexceptflag function sets the complete status for those
|
|
|
|
exception flags indicated by the argument excepts, according to the
|
|
|
|
representation in the object pointed to by flagp. The value of
|
|
|
|
*flagp shall have been set by a previous call to fegetexceptflag
|
|
|
|
whose second argument represented at least those exceptions
|
|
|
|
represented by the argument excepts. This function does not raise
|
|
|
|
exceptions, but only sets the state of the flags. */
|
|
|
|
|
2005-08-25 16:39:54 +08:00
|
|
|
int fesetexceptflag (const fexcept_t * flagp, int excepts)
|
2002-06-13 18:20:48 +08:00
|
|
|
{
|
|
|
|
fenv_t _env;
|
|
|
|
|
|
|
|
excepts &= FE_ALL_EXCEPT;
|
|
|
|
__asm__ volatile ("fnstenv %0;" : "=m" (_env));
|
|
|
|
_env.__status_word &= ~excepts;
|
|
|
|
_env.__status_word |= (*flagp & excepts);
|
|
|
|
__asm__ volatile ("fldenv %0;" : : "m" (_env));
|
2006-07-03 18:32:58 +08:00
|
|
|
|
|
|
|
if (__HAS_SSE)
|
|
|
|
{
|
|
|
|
unsigned int _csr;
|
|
|
|
__asm__ __volatile__("stmxcsr %0" : "=m" (_csr));
|
|
|
|
_csr &= ~excepts;
|
|
|
|
_csr |= *flagp & excepts;
|
|
|
|
__asm__ volatile ("ldmxcsr %0" : : "m" (_csr));
|
|
|
|
}
|
|
|
|
|
2005-08-25 16:39:54 +08:00
|
|
|
return 0;
|
2002-06-13 18:20:48 +08:00
|
|
|
}
|