factor/vm/os-macosx-x86.32.hpp

73 lines
2.4 KiB
C++
Raw Normal View History

#include <sys/ucontext.h>
2009-05-04 02:46:13 -04:00
2013-05-11 22:24:31 -04:00
namespace factor {
2009-05-04 02:46:13 -04:00
// Fault handler information. MacOSX version.
// Copyright (C) 1993-1999, 2002-2003 Bruno Haible <clisp.org at bruno>
// Copyright (C) 2003 Paolo Bonzini <gnu.org at bonzini>
2009-05-02 05:04:19 -04:00
// Used under BSD license with permission from Paolo Bonzini and Bruno Haible,
// 2005-03-10:
2009-05-02 05:04:19 -04:00
// http://sourceforge.net/mailarchive/message.php?msg_name=200503102200.32002.bruno%40clisp.org
2009-05-02 05:04:19 -04:00
// Modified for Factor by Slava Pestov
2009-05-02 05:04:19 -04:00
#define MACH_EXC_STATE_TYPE i386_exception_state_t
#define MACH_EXC_STATE_FLAVOR i386_EXCEPTION_STATE
#define MACH_EXC_STATE_COUNT i386_EXCEPTION_STATE_COUNT
#define MACH_EXC_INTEGER_DIV EXC_I386_DIV
2009-05-02 05:04:19 -04:00
#define MACH_THREAD_STATE_TYPE i386_thread_state_t
#define MACH_THREAD_STATE_FLAVOR i386_THREAD_STATE
#define MACH_THREAD_STATE_COUNT i386_THREAD_STATE_COUNT
#define MACH_FLOAT_STATE_TYPE i386_float_state_t
#define MACH_FLOAT_STATE_FLAVOR i386_FLOAT_STATE
#define MACH_FLOAT_STATE_COUNT i386_FLOAT_STATE_COUNT
2009-05-02 05:04:19 -04:00
#if __DARWIN_UNIX03
2013-05-11 22:24:31 -04:00
#define MACH_EXC_STATE_FAULT(exc_state) (exc_state)->__faultvaddr
#define MACH_STACK_POINTER(thr_state) (thr_state)->__esp
#define MACH_PROGRAM_COUNTER(thr_state) (thr_state)->__eip
2013-05-11 22:24:31 -04:00
#define UAP_SS(ucontext) &(((ucontext_t*)(ucontext))->uc_mcontext->__ss)
#define UAP_FS(ucontext) &(((ucontext_t*)(ucontext))->uc_mcontext->__fs)
2013-05-11 22:24:31 -04:00
#define MXCSR(float_state) (float_state)->__fpu_mxcsr
#define X87SW(float_state) (float_state)->__fpu_fsw
2009-05-02 05:04:19 -04:00
#else
2013-05-11 22:24:31 -04:00
#define MACH_EXC_STATE_FAULT(exc_state) (exc_state)->faultvaddr
#define MACH_STACK_POINTER(thr_state) (thr_state)->esp
#define MACH_PROGRAM_COUNTER(thr_state) (thr_state)->eip
2013-05-11 22:24:31 -04:00
#define UAP_SS(ucontext) &(((ucontext_t*)(ucontext))->uc_mcontext->ss)
#define UAP_FS(ucontext) &(((ucontext_t*)(ucontext))->uc_mcontext->fs)
2013-05-11 22:24:31 -04:00
#define MXCSR(float_state) (float_state)->fpu_mxcsr
#define X87SW(float_state) (float_state)->fpu_fsw
2009-05-02 05:04:19 -04:00
#endif
2013-05-11 22:24:31 -04:00
#define UAP_PROGRAM_COUNTER(ucontext) MACH_PROGRAM_COUNTER(UAP_SS(ucontext))
2013-05-11 22:24:31 -04:00
inline static unsigned int mach_fpu_status(i386_float_state_t* float_state) {
unsigned short x87sw;
memcpy(&x87sw, &X87SW(float_state), sizeof(x87sw));
return MXCSR(float_state) | x87sw;
}
2013-05-11 22:24:31 -04:00
inline static unsigned int uap_fpu_status(void* uap) {
return mach_fpu_status(UAP_FS(uap));
}
2013-05-11 22:24:31 -04:00
inline static void mach_clear_fpu_status(i386_float_state_t* float_state) {
MXCSR(float_state) &= 0xffffffc0;
memset(&X87SW(float_state), 0, sizeof(X87SW(float_state)));
}
2013-05-11 22:24:31 -04:00
inline static void uap_clear_fpu_status(void* uap) {
mach_clear_fpu_status(UAP_FS(uap));
}
2009-05-04 02:46:13 -04:00
}