X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fthread.h;h=9d72005963b04650faed84f56eabf39e594381b2;hb=b9519773faa7b3c98915eccb9cb1fd8a8270ee56;hp=5d5eba9eae0130f58be68c418cecb5ea0581d8e5;hpb=584bfdc4e1093e43e4eb328a418b012745935a29;p=sbcl.git diff --git a/src/runtime/thread.h b/src/runtime/thread.h index 5d5eba9..9d72005 100644 --- a/src/runtime/thread.h +++ b/src/runtime/thread.h @@ -17,6 +17,7 @@ struct alloc_region { }; #include "genesis/symbol.h" #include "genesis/static-symbols.h" #include "genesis/thread.h" +#include "genesis/fdefn.h" #define STATE_RUNNING (make_fixnum(1)) #define STATE_SUSPENDED (make_fixnum(2)) @@ -33,6 +34,15 @@ union per_thread_data { extern struct thread * volatile all_threads; extern int dynamic_values_bytes; +#if defined(LISP_FEATURE_DARWIN) +#define CONTROL_STACK_ALIGNMENT_BYTES 8192 /* darwin wants page-aligned stacks */ +#define THREAD_ALIGNMENT_BYTES CONTROL_STACK_ALIGNMENT_BYTES +#else +#define THREAD_ALIGNMENT_BYTES BACKEND_PAGE_SIZE +#define CONTROL_STACK_ALIGNMENT_BYTES 16 +#endif + + #ifdef LISP_FEATURE_SB_THREAD #define for_each_thread(th) for(th=all_threads;th;th=th->next) #else @@ -102,6 +112,13 @@ SetTlSymbolValue(u64 tagged_symbol_pointer,lispobj val, void *thread) #endif } +/* This only works for static symbols. */ +static inline lispobj +StaticSymbolFunction(lispobj sym) +{ + return ((struct fdefn *)native_pointer(SymbolValue(sym, 0)))->fun; +} + static inline os_context_t *get_interrupt_context_for_thread(struct thread *th) { @@ -109,6 +126,10 @@ os_context_t *get_interrupt_context_for_thread(struct thread *th) [fixnum_value(SymbolValue(FREE_INTERRUPT_CONTEXT_INDEX,th)-1)]; } +#if defined(LISP_FEATURE_SB_THREAD) && defined(LISP_FEATURE_GCC_TLS) +extern __thread struct thread *current_thread; +#endif + /* This is clearly per-arch and possibly even per-OS code, but we can't * put it somewhere sensible like x86-linux-os.c because it needs too * much stuff like struct thread and all_threads to be defined, which @@ -127,8 +148,13 @@ static inline struct thread *arch_os_get_current_thread(void) sel.rpl = USER_PRIV; sel.ti = SEL_LDT; __asm__ __volatile__ ("movw %w0, %%fs" : : "r"(sel)); -#elif defined(LISP_FEATURE_FREEBSD) && defined(LISP_FEATURE_RESTORE_TLS_SEGMENT_REGISTER_FROM_TLS) +#elif defined(LISP_FEATURE_FREEBSD) +#ifdef LISP_FEATURE_GCC_TLS + struct thread *th = current_thread; +#else struct thread *th = pthread_getspecific(specials); +#endif +#ifdef LISP_FEATURE_RESTORE_TLS_SEGMENT_REGISTER_FROM_TLS unsigned int sel = LSEL(th->tls_cookie, SEL_UPL); unsigned int fs = rfs(); @@ -136,6 +162,7 @@ static inline struct thread *arch_os_get_current_thread(void) * causes privilege checking and it takes long time. */ if (fs != sel) load_fs(sel); +#endif return th; #endif __asm__ __volatile__ ("movl %%fs:%c1,%0" : "=r" (me) @@ -143,7 +170,11 @@ static inline struct thread *arch_os_get_current_thread(void) } return me; #else +#ifdef LISP_FEATURE_GCC_TLS + return current_thread; +#else return pthread_getspecific(specials); +#endif #endif /* x86 */ #else return all_threads;