Commit 5be2a01c authored by Fabian Maurer's avatar Fabian Maurer Committed by Alexandre Julliard

imm32: Prevent deadlock on unload.

ole32 is delay loaded, which can cause race conditions against krnl386.exe when unloading. This is because imm32 tries to get the loader lock while holding the win16 mutex, and kernel386 does the opposite. Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=52511Signed-off-by: 's avatarFabian Maurer <dark.shadow4@web.de>
parent 131aa513
...@@ -80,6 +80,9 @@ typedef struct _tagImmHkl{ ...@@ -80,6 +80,9 @@ typedef struct _tagImmHkl{
DWORD (WINAPI *pImeGetImeMenuItems)(HIMC, DWORD, DWORD, IMEMENUITEMINFOW *, IMEMENUITEMINFOW *, DWORD); DWORD (WINAPI *pImeGetImeMenuItems)(HIMC, DWORD, DWORD, IMEMENUITEMINFOW *, IMEMENUITEMINFOW *, DWORD);
} ImmHkl; } ImmHkl;
static HRESULT (WINAPI *pCoRevokeInitializeSpy)(ULARGE_INTEGER cookie);
static void (WINAPI *pCoUninitialize)(void);
typedef struct tagInputContextData typedef struct tagInputContextData
{ {
HIMC handle; HIMC handle;
...@@ -249,7 +252,7 @@ static void imm_couninit_thread(BOOL cleanup) ...@@ -249,7 +252,7 @@ static void imm_couninit_thread(BOOL cleanup)
if (cleanup && spy->cookie.QuadPart) if (cleanup && spy->cookie.QuadPart)
{ {
CoRevokeInitializeSpy(spy->cookie); pCoRevokeInitializeSpy(spy->cookie);
spy->cookie.QuadPart = 0; spy->cookie.QuadPart = 0;
} }
...@@ -261,7 +264,7 @@ static void imm_couninit_thread(BOOL cleanup) ...@@ -261,7 +264,7 @@ static void imm_couninit_thread(BOOL cleanup)
{ {
spy->apt_flags &= ~IMM_APT_CREATED; spy->apt_flags &= ~IMM_APT_CREATED;
if (spy->apt_flags & IMM_APT_CAN_FREE) if (spy->apt_flags & IMM_APT_CAN_FREE)
CoUninitialize(); pCoUninitialize();
} }
if (cleanup) if (cleanup)
spy->apt_flags = 0; spy->apt_flags = 0;
...@@ -359,10 +362,19 @@ static const IInitializeSpyVtbl InitializeSpyVtbl = ...@@ -359,10 +362,19 @@ static const IInitializeSpyVtbl InitializeSpyVtbl =
InitializeSpy_PostUninitialize, InitializeSpy_PostUninitialize,
}; };
static BOOL WINAPI init_ole32_funcs( INIT_ONCE *once, void *param, void **context )
{
HMODULE module_ole32 = GetModuleHandleA("ole32");
pCoRevokeInitializeSpy = (void*)GetProcAddress(module_ole32, "CoRevokeInitializeSpy");
pCoUninitialize = (void*)GetProcAddress(module_ole32, "CoUninitialize");
return TRUE;
}
static void imm_coinit_thread(void) static void imm_coinit_thread(void)
{ {
struct coinit_spy *spy; struct coinit_spy *spy;
HRESULT hr; HRESULT hr;
static INIT_ONCE init_ole32_once = INIT_ONCE_STATIC_INIT;
TRACE("implicit COM initialization\n"); TRACE("implicit COM initialization\n");
...@@ -391,6 +403,8 @@ static void imm_coinit_thread(void) ...@@ -391,6 +403,8 @@ static void imm_coinit_thread(void)
hr = CoInitializeEx(NULL, COINIT_APARTMENTTHREADED); hr = CoInitializeEx(NULL, COINIT_APARTMENTTHREADED);
if (SUCCEEDED(hr)) if (SUCCEEDED(hr))
spy->apt_flags |= IMM_APT_CREATED; spy->apt_flags |= IMM_APT_CREATED;
InitOnceExecuteOnce(&init_ole32_once, init_ole32_funcs, NULL, NULL);
} }
static BOOL IMM_IsDefaultContext(HIMC imc) static BOOL IMM_IsDefaultContext(HIMC imc)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment