Commit b71cea76 authored by Rémi Bernon's avatar Rémi Bernon Committed by Alexandre Julliard

dinput: Wait for the hook thread to exit when stopping it.

FlatOut2 demo calls FreeLibrary on the dinput8 module more times than it has loaded it, and the module reference that the internal thread has is getting decremented before its exit. Having an internal window to destroy also makes it more likely to crash as it takes more time to exit calls the window procedure function. Waiting for the thread to complete when all the dinput instances are destroyed ensures that the thread isn't alive when the game frees the DLL, and prevents the thread from crashing. Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=50673Signed-off-by: 's avatarRémi Bernon <rbernon@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 4634fd4c
...@@ -1861,6 +1861,7 @@ static BOOL check_hook_thread(void) ...@@ -1861,6 +1861,7 @@ static BOOL check_hook_thread(void)
{ {
static HANDLE hook_thread; static HANDLE hook_thread;
HMODULE module; HMODULE module;
HANDLE wait_handle = NULL;
EnterCriticalSection(&dinput_hook_crit); EnterCriticalSection(&dinput_hook_crit);
...@@ -1884,11 +1885,17 @@ static BOOL check_hook_thread(void) ...@@ -1884,11 +1885,17 @@ static BOOL check_hook_thread(void)
hook_thread_id = 0; hook_thread_id = 0;
PostThreadMessageW(tid, WM_USER+0x10, 0, 0); PostThreadMessageW(tid, WM_USER+0x10, 0, 0);
CloseHandle(hook_thread); wait_handle = hook_thread;
hook_thread = NULL; hook_thread = NULL;
} }
LeaveCriticalSection(&dinput_hook_crit); LeaveCriticalSection(&dinput_hook_crit);
if (wait_handle)
{
WaitForSingleObject(wait_handle, INFINITE);
CloseHandle(wait_handle);
}
return hook_thread_id != 0; return hook_thread_id != 0;
} }
......
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