X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fruntime%2Fx86-linux-os.c;h=15eb762787fd401ee1dd461c478dd2783e51d076;hb=eb5265ab22a2b1cae18bbdf43c871dba9b5927ea;hp=b39df5ad0ea2e7389703d5da73fa14173c800178;hpb=1a6c2275ab21acc79d3a6866d4749dda8f02f7d7;p=sbcl.git diff --git a/src/runtime/x86-linux-os.c b/src/runtime/x86-linux-os.c index b39df5a..15eb762 100644 --- a/src/runtime/x86-linux-os.c +++ b/src/runtime/x86-linux-os.c @@ -22,6 +22,7 @@ #include #include +#include "sbcl.h" #include "./signal.h" #include "os.h" #include "arch.h" @@ -29,7 +30,6 @@ #include "interrupt.h" #include "interr.h" #include "lispregs.h" -#include "sbcl.h" #include #include @@ -40,13 +40,12 @@ #include #include #include -#include "modify-ldt-struct-name.h" #include #include +#include #include "thread.h" /* dynamic_values_bytes */ -#ifndef MODIFY_LDT_STRUCT_NAMED_USER_DESC -/* old glibc */ +#if LINUX_VERSION_CODE < KERNEL_VERSION(2,6,0) #define user_desc modify_ldt_ldt_s #endif @@ -66,13 +65,13 @@ void debug_get_ldt() printf("%d bytes in ldt: print/x local_ldt_copy\n", n); } -lispobj modify_ldt_lock; /* protect all calls to modify_ldt */ +volatile lispobj modify_ldt_lock; /* protect all calls to modify_ldt */ int arch_os_thread_init(struct thread *thread) { stack_t sigstack; #ifdef LISP_FEATURE_SB_THREAD - /* this must be called from a function that has an exclusive lock - * on all_threads + /* FIXME Lock ordering rules: all_threads_lock must usually be + * held when getting modify_ldt_lock */ struct user_desc ldt_entry = { 1, 0, 0, /* index, address, length filled in later */