1
0
mirror of https://github.com/janet-lang/janet synced 2025-01-14 01:20:27 +00:00

Fix init race for environ lock.

This commit is contained in:
Andrew Chambers 2021-08-09 14:06:53 +12:00
parent c94d7574bc
commit f2e8691ad5

View File

@ -84,7 +84,6 @@ time_t timegm(struct tm *tm);
* setenv/getenv are not thread safe. */ * setenv/getenv are not thread safe. */
#ifdef JANET_THREADS #ifdef JANET_THREADS
# ifdef JANET_WINDOWS # ifdef JANET_WINDOWS
static int env_lock_initialized = 0;
static CRITICAL_SECTION env_lock; static CRITICAL_SECTION env_lock;
static void janet_lock_environ(void) { static void janet_lock_environ(void) {
EnterCriticalSection(&env_lock); EnterCriticalSection(&env_lock);
@ -2146,10 +2145,17 @@ void janet_lib_os(JanetTable *env) {
#if !defined(JANET_REDUCED_OS) && defined(JANET_WINDOWS) && defined(JANET_THREADS) #if !defined(JANET_REDUCED_OS) && defined(JANET_WINDOWS) && defined(JANET_THREADS)
/* During start up, the top-most abstract machine (thread) /* During start up, the top-most abstract machine (thread)
* in the thread tree sets up the critical section. */ * in the thread tree sets up the critical section. */
if (!env_lock_initialized) { static volatile long env_lock_initializing = 0;
InitializeCriticalSection(&env_lock); static volatile long env_lock_initialized = 0;
env_lock_initialized = 1; if(!InterlockedExchange(&env_lock_initializing, 1)){
InitializeCriticalSection(&env_lock);
InterlockedOr(&env_lock_initialized, 1);
} else {
while (!InterlockedOr(&env_lock_initialized, 0)) {
Sleep(0);
}
} }
#endif #endif
#ifndef JANET_NO_PROCESSES #ifndef JANET_NO_PROCESSES
#endif #endif