X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fbsd-os.h;h=d95431df0fbc5c59c6e1fe57362369160bd8aa02;hb=a93dc34ed9e7f5c7162e9c18961e6cce23941b46;hp=86d8f6e1f272592e7a4e418bc954c884cbad4a7f;hpb=dc5e3163fe667e2629c7769aa8cf2e501eeeefa6;p=sbcl.git diff --git a/src/runtime/bsd-os.h b/src/runtime/bsd-os.h index 86d8f6e..d95431d 100644 --- a/src/runtime/bsd-os.h +++ b/src/runtime/bsd-os.h @@ -23,12 +23,21 @@ typedef off_t os_vm_offset_t; typedef int os_vm_prot_t; typedef int os_context_register_t; +#if defined __OpenBSD__ +/* name defined for compatibility between OpenBSD 3.1 sigaltstack(2) and + * Linux sigaltstack(2) */ +typedef struct sigaltstack stack_t; +#elif defined __FreeBSD__ +/* FreeBSD 4.6 already has stack_t defined. */ +#endif + #if defined __FreeBSD__ /* Note: The man page for sigaction(2) in FreeBSD 4.0 says that this * is an mcontext_t, but according to comments by Raymond Wiker in the * original FreeBSD port of SBCL, that's wrong, it's actually a * ucontext_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 @@ -39,6 +48,17 @@ typedef ucontext_t os_context_t; #elif defined __OpenBSD__ typedef struct sigcontext os_context_t; #define SIG_MEMORY_FAULT SIGSEGV +#elif defined DARWIN + /* man pages claim that the third argument is a sigcontext struct, + but ucontext_t is defined, matches sigcontext where sensible, + offers better access to mcontext, and is of course the SUSv2- + mandated type of the third argument, so we use that instead. + If Apple is going to break ucontext_t out of spite, I'm going + to be cross with them ;) -- PRM */ + +#include +typedef ucontext_t os_context_t; +#define SIG_MEMORY_FAULT SIGBUS #else #error unsupported BSD variant #endif