From d6fe9af0155b28cf23032bb173a1c9a054406b4e Mon Sep 17 00:00:00 2001 From: Michael Holman Date: Wed, 7 Feb 2018 03:08:19 -0800 Subject: [PATCH] deps: update ChakraCore to Microsoft/ChakraCore@e4493a2fe7 [1.8>1.9] [MERGE #4643 @MikeHolman] fix race condition where multiple threads simultaneously connect Merge pull request #4643 from MikeHolman:connectrace Reviewed-By: chakrabot --- deps/chakrashim/core/lib/JITClient/JITManager.cpp | 13 +++++-------- deps/chakrashim/core/lib/JITClient/JITManager.h | 1 + 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/deps/chakrashim/core/lib/JITClient/JITManager.cpp b/deps/chakrashim/core/lib/JITClient/JITManager.cpp index 81bc5c74291..b5923208d8c 100644 --- a/deps/chakrashim/core/lib/JITClient/JITManager.cpp +++ b/deps/chakrashim/core/lib/JITClient/JITManager.cpp @@ -226,20 +226,17 @@ JITManager::IsOOPJITEnabled() const HRESULT JITManager::ConnectRpcServer(__in HANDLE jitProcessHandle, __in_opt void* serverSecurityDescriptor, __in UUID connectionUuid) { + // We might be trying to connect from multiple threads simultaneously + AutoCriticalSection cs(&m_cs); + Assert(IsOOPJITEnabled()); - if(m_rpcBindingHandle != nullptr) + if (m_rpcBindingHandle != nullptr) { - // TODO: change this to allow connecting a new JIT process to new ThreadContexts - return E_FAIL; + return S_OK; } HRESULT hr = E_FAIL; - if (IsConnected()) - { - Assert(UNREACHED); - return E_FAIL; - } hr = CreateBinding(jitProcessHandle, serverSecurityDescriptor, &connectionUuid, &m_rpcBindingHandle); if (FAILED(hr)) diff --git a/deps/chakrashim/core/lib/JITClient/JITManager.h b/deps/chakrashim/core/lib/JITClient/JITManager.h index 9ab4eac396b..699424b2dfb 100644 --- a/deps/chakrashim/core/lib/JITClient/JITManager.h +++ b/deps/chakrashim/core/lib/JITClient/JITManager.h @@ -140,6 +140,7 @@ class JITManager bool m_oopJitEnabled; bool m_isJITServer; HRESULT m_failingHRESULT; + CriticalSection m_cs; static JITManager s_jitManager;