X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fbsd-os.h;h=474f6867eb39276fd042e6e9f5c22936db27d1c6;hb=f35f14479a64dd97f93d2d91dc154bdc141d6842;hp=18c29512f38ecc6e24d7bb9d4bbd8e1b6c92886f;hpb=01044af1b8d69fc3899dc0417064c1512223223d;p=sbcl.git diff --git a/src/runtime/bsd-os.h b/src/runtime/bsd-os.h index 18c2951..474f686 100644 --- a/src/runtime/bsd-os.h +++ b/src/runtime/bsd-os.h @@ -17,9 +17,15 @@ #include #include +#ifdef LISP_FEATURE_DARWIN +#include +#endif + typedef caddr_t os_vm_address_t; -#ifdef __NetBSD__ +#if defined __NetBSD__ typedef vsize_t os_vm_size_t; +#elif defined __OpenBSD__ +typedef size_t os_vm_size_t; #else typedef vm_size_t os_vm_size_t; #endif @@ -43,12 +49,16 @@ typedef struct sigaltstack stack_t; #include typedef ucontext_t os_context_t; -/* As the sbcl-devel message from Raymond Wiker 2000-12-01, FreeBSD - * (unlike Linux and OpenBSD) doesn't let us tweak the CPU's single - * step flag bit by messing with the flags stored in a signal context, - * so we need to implement single stepping in a more roundabout way. */ -#define CANNOT_GET_TO_SINGLE_STEP_FLAG -#define SIG_MEMORY_FAULT SIGBUS +#define SIG_MEMORY_FAULT SIGSEGV +/* Sometime in late 2005 FreeBSD was changed to signal SIGSEGV instead + * of SIGBUS for memory faults, as required by POSIX. In order to + * support both new and old FreeBSD at the same time, both signals are + * hooked to the GC write barrier machinery. If you're reading this + * message in the far future where FreeBSD 6 and earlier are just + * quaint memories, feel free to delete this hack (and any code that's + * #ifdef SIG_MEMORY_FAULT2'ed). -- JES, 2005-12-30 + */ +#define SIG_MEMORY_FAULT2 SIGBUS #elif defined __OpenBSD__ @@ -69,8 +79,15 @@ typedef ucontext_t os_context_t; If Apple is going to break ucontext_t out of spite, I'm going to be cross with them ;) -- PRM */ +#if defined(LISP_FEATURE_X86) +#include +#include +typedef struct ucontext os_context_t; +#else #include typedef ucontext_t os_context_t; +#endif + #define SIG_MEMORY_FAULT SIGBUS #else