From ee52502166165163b493f45e3b48992335702a2a Mon Sep 17 00:00:00 2001 From: Chris Davis Date: Wed, 4 Mar 2020 14:40:39 -0800 Subject: [PATCH] Modify global static to be returned from a local static in a helper function This change eliminates a globally initialized mutex we are seeing at launch of chrome. This is created on demand from a helper function with a static local. --- src/openvr_api_public.cpp | 22 +++++++++++++--------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/src/openvr_api_public.cpp b/src/openvr_api_public.cpp index 54aa5559..3d06ee2f 100644 --- a/src/openvr_api_public.cpp +++ b/src/openvr_api_public.cpp @@ -37,8 +37,12 @@ namespace vr static void *g_pVRModule = NULL; static IVRClientCore *g_pHmdSystem = NULL; -static std::recursive_mutex g_mutexSystem; +static std::recursive_mutex& GetMutexSystem() +{ + static std::recursive_mutex mutexSystem; + return mutexSystem; +} typedef void* (*VRClientCoreFactoryFn)(const char *pInterfaceName, int *pReturnCode); @@ -55,7 +59,7 @@ void CleanupInternalInterfaces(); uint32_t VR_InitInternal2( EVRInitError *peError, vr::EVRApplicationType eApplicationType, const char *pStartupInfo ) { - std::lock_guard lock( g_mutexSystem ); + std::lock_guard lock( GetMutexSystem() ); EVRInitError err = VR_LoadHmdSystemInternal(); if ( err == vr::VRInitError_None ) @@ -87,7 +91,7 @@ uint32_t VR_InitInternal( EVRInitError *peError, vr::EVRApplicationType eApplica void VR_ShutdownInternal() { - std::lock_guard lock( g_mutexSystem ); + std::lock_guard lock( GetMutexSystem() ); if ( g_pHmdSystem ) { @@ -172,7 +176,7 @@ EVRInitError VR_LoadHmdSystemInternal() void *VR_GetGenericInterface(const char *pchInterfaceVersion, EVRInitError *peError) { - std::lock_guard lock( g_mutexSystem ); + std::lock_guard lock( GetMutexSystem() ); if (!g_pHmdSystem) { @@ -186,7 +190,7 @@ void *VR_GetGenericInterface(const char *pchInterfaceVersion, EVRInitError *peEr bool VR_IsInterfaceVersionValid(const char *pchInterfaceVersion) { - std::lock_guard lock( g_mutexSystem ); + std::lock_guard lock( GetMutexSystem() ); if (!g_pHmdSystem) { @@ -198,7 +202,7 @@ bool VR_IsInterfaceVersionValid(const char *pchInterfaceVersion) bool VR_IsHmdPresent() { - std::lock_guard lock( g_mutexSystem ); + std::lock_guard lock( GetMutexSystem() ); if( g_pHmdSystem ) { @@ -225,7 +229,7 @@ bool VR_IsHmdPresent() /** Returns true if the OpenVR runtime is installed. */ bool VR_IsRuntimeInstalled() { - std::lock_guard lock( g_mutexSystem ); + std::lock_guard lock( GetMutexSystem() ); if( g_pHmdSystem ) { @@ -319,7 +323,7 @@ bool VR_GetRuntimePath( char *pchPathBuffer, uint32_t unBufferSize, uint32_t *pu /** Returns the symbol version of an HMD error. */ const char *VR_GetVRInitErrorAsSymbol( EVRInitError error ) { - std::lock_guard lock( g_mutexSystem ); + std::lock_guard lock( GetMutexSystem() ); if( g_pHmdSystem ) return g_pHmdSystem->GetIDForVRInitError( error ); @@ -331,7 +335,7 @@ const char *VR_GetVRInitErrorAsSymbol( EVRInitError error ) /** Returns the english string version of an HMD error. */ const char *VR_GetVRInitErrorAsEnglishDescription( EVRInitError error ) { - std::lock_guard lock( g_mutexSystem ); + std::lock_guard lock( GetMutexSystem() ); if ( g_pHmdSystem ) return g_pHmdSystem->GetEnglishStringForHmdError( error );