2009-05-02 05:04:19 -04:00
|
|
|
#include <ucontext.h>
|
2009-09-14 00:37:28 -04:00
|
|
|
#include <machine/fpu.h>
|
2009-05-02 05:04:19 -04:00
|
|
|
|
2009-05-04 02:46:13 -04:00
|
|
|
namespace factor
|
|
|
|
{
|
|
|
|
|
2009-05-04 02:00:30 -04:00
|
|
|
inline static void *ucontext_stack_pointer(void *uap)
|
2009-05-02 05:04:19 -04:00
|
|
|
{
|
|
|
|
ucontext_t *ucontext = (ucontext_t *)uap;
|
|
|
|
return (void *)ucontext->uc_mcontext.mc_rsp;
|
|
|
|
}
|
|
|
|
|
2009-09-14 00:37:28 -04:00
|
|
|
inline static unsigned int uap_fpu_status(void *uap)
|
|
|
|
{
|
|
|
|
ucontext_t *ucontext = (ucontext_t *)uap;
|
2009-09-14 04:09:03 -04:00
|
|
|
if (ucontext->uc_mcontext.mc_fpformat == _MC_FPFMT_XMM)
|
|
|
|
{
|
2009-09-14 10:56:38 -04:00
|
|
|
struct savefpu *xmm = (struct savefpu *)(&ucontext->uc_mcontext.mc_fpstate);
|
2009-09-14 04:09:03 -04:00
|
|
|
return xmm->sv_env.en_sw | xmm->sv_env.en_mxcsr;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
return 0;
|
2009-09-14 00:37:28 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
inline static void uap_clear_fpu_status(void *uap)
|
|
|
|
{
|
|
|
|
ucontext_t *ucontext = (ucontext_t *)uap;
|
2009-09-14 04:09:03 -04:00
|
|
|
if (ucontext->uc_mcontext.mc_fpformat == _MC_FPFMT_XMM)
|
|
|
|
{
|
2009-09-14 10:56:38 -04:00
|
|
|
struct savefpu *xmm = (struct savefpu *)(&ucontext->uc_mcontext.mc_fpstate);
|
2009-09-14 04:09:03 -04:00
|
|
|
xmm->sv_env.en_sw = 0;
|
|
|
|
xmm->sv_env.en_mxcsr &= 0xffffffc0;
|
2009-09-14 00:37:28 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-05-02 05:04:19 -04:00
|
|
|
#define UAP_PROGRAM_COUNTER(ucontext) (((ucontext_t *)(ucontext))->uc_mcontext.mc_rip)
|
2009-05-04 02:46:13 -04:00
|
|
|
|
|
|
|
}
|