X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/262d01a131c3ee7a69da93283a462b4399c9e9fd..5fc72d28104dca5e9f2fb0d2bb047c7277a7999f:/src/simix/smx_context.c diff --git a/src/simix/smx_context.c b/src/simix/smx_context.c index 5bcfdf9b5d..e447ed3e98 100644 --- a/src/simix/smx_context.c +++ b/src/simix/smx_context.c @@ -18,6 +18,7 @@ #ifdef _WIN32 #include +#include #else #include #endif @@ -27,10 +28,6 @@ #define _aligned_free __mingw_aligned_free #endif //MINGW -#if defined(_XBT_WIN32) -#include -#endif - #ifdef HAVE_VALGRIND_VALGRIND_H # include #endif @@ -45,7 +42,7 @@ int smx_context_stack_size_was_set = 0; int smx_context_guard_size; int smx_context_guard_size_was_set = 0; #ifdef HAVE_THREAD_LOCAL_STORAGE -static __thread smx_context_t smx_current_context_parallel; +static XBT_THREAD_LOCAL smx_context_t smx_current_context_parallel; #else static xbt_os_thread_key_t smx_current_context_key = 0; #endif @@ -163,8 +160,9 @@ void *SIMIX_context_stack_new(void) #ifndef _XBT_WIN32 if (mprotect(stack, smx_context_guard_size, PROT_NONE) == -1) { - XBT_WARN("Failed to protect stack: %s", strerror(errno)); - /* That's not fatal, pursue anyway. */ + xbt_die("Failed to protect stack: %s", strerror(errno)); + /* This is fatal. We are going to fail at some point when + we tryi reusing this. */ } #endif stack = (char *)stack + smx_context_guard_size; @@ -198,7 +196,7 @@ void SIMIX_context_stack_delete(void *stack) if (smx_context_guard_size > 0 && !MC_is_active()) { stack = (char *)stack - smx_context_guard_size; if (mprotect(stack, smx_context_guard_size, - PROT_READ | PROT_WRITE | PROT_EXEC) == -1) { + PROT_READ | PROT_WRITE) == -1) { XBT_WARN("Failed to remove page protection: %s", strerror(errno)); /* try to pursue anyway */ }