]> gitweb.factorcode.org Git - factor.git/blob - vm/os-freebsd-x86.32.hpp
Merge branch 'irc-fix' of git://tiodante.com/git/factor
[factor.git] / vm / os-freebsd-x86.32.hpp
1 #include <ucontext.h>
2 #include <machine/npx.h>
3
4 namespace factor
5 {
6
7 inline static void *ucontext_stack_pointer(void *uap)
8 {
9         ucontext_t *ucontext = (ucontext_t *)uap;
10         return (void *)ucontext->uc_mcontext.mc_esp;
11 }
12
13 inline static unsigned int uap_fpu_status(void *uap)
14 {
15         ucontext_t *ucontext = (ucontext_t *)uap;
16         if (ucontext->uc_mcontext.mc_fpformat == _MC_FPFMT_387)
17         {
18                 struct save87 *x87 = (struct save87 *)(&ucontext->uc_mcontext.mc_fpstate);
19                 return x87->sv_env.en_sw;
20         }
21         else if (ucontext->uc_mcontext.mc_fpformat == _MC_FPFMT_XMM)
22         {
23                 struct savexmm *xmm = (struct savexmm *)(&ucontext->uc_mcontext.mc_fpstate);
24                 return xmm->sv_env.en_sw | xmm->sv_env.en_mxcsr;
25         }
26         else
27                 return 0;
28 }
29
30 inline static void uap_clear_fpu_status(void *uap)
31 {
32         ucontext_t *ucontext = (ucontext_t *)uap;
33         if (ucontext->uc_mcontext.mc_fpformat == _MC_FPFMT_387)
34         {
35                 struct save87 *x87 = (struct save87 *)(&ucontext->uc_mcontext.mc_fpstate);
36                 x87->sv_env.en_sw = 0;
37         }
38         else if (ucontext->uc_mcontext.mc_fpformat == _MC_FPFMT_XMM)
39         {
40                 struct savexmm *xmm = (struct savexmm *)(&ucontext->uc_mcontext.mc_fpstate);
41                 xmm->sv_env.en_sw = 0;
42                 xmm->sv_env.en_mxcsr &= 0xffffffc0;
43         }
44 }
45
46 #define UAP_PROGRAM_COUNTER(ucontext) (((ucontext_t *)(ucontext))->uc_mcontext.mc_eip)
47
48 }