Module: wine Branch: master Commit: 685a3e6a6ed623718f640e8906bd44fbca3d8b2c URL: http://source.winehq.org/git/wine.git/?a=commit;h=685a3e6a6ed623718f640e8906...
Author: Vitaliy Margolen wine-patches@kievinfo.com Date: Thu Dec 28 12:04:10 2006 -0700
dinput: Release critical section before warping mouse.
---
dlls/dinput/mouse.c | 12 ++++-------- 1 files changed, 4 insertions(+), 8 deletions(-)
diff --git a/dlls/dinput/mouse.c b/dlls/dinput/mouse.c index 935c64b..81e520e 100644 --- a/dlls/dinput/mouse.c +++ b/dlls/dinput/mouse.c @@ -511,15 +511,15 @@ static HRESULT WINAPI SysMouseAImpl_GetD
if(This->base.acquired == 0) return DIERR_NOTACQUIRED;
- EnterCriticalSection(&This->base.crit); TRACE("(this=%p,0x%08x,%p):\n", This, len, ptr); TRACE("(X: %d - Y: %d - Z: %d L: %02x M: %02x R: %02x)\n", This->m_state.lX, This->m_state.lY, This->m_state.lZ, This->m_state.rgbButtons[0], This->m_state.rgbButtons[2], This->m_state.rgbButtons[1]); - + + EnterCriticalSection(&This->base.crit); /* Copy the current mouse state */ fill_DataFormat(ptr, &(This->m_state), &This->base.data_format); - + /* Initialize the buffer when in relative mode */ if (!(This->base.data_format.user_df->dwFlags & DIDF_ABSAXIS)) { @@ -527,23 +527,19 @@ static HRESULT WINAPI SysMouseAImpl_GetD This->m_state.lY = 0; This->m_state.lZ = 0; } + LeaveCriticalSection(&This->base.crit);
/* Check if we need to do a mouse warping */ if (This->need_warp && (GetCurrentTime() - This->last_warped > 10)) { if(!dinput_window_check(This)) - { - LeaveCriticalSection(&This->base.crit); return DIERR_GENERIC; - } TRACE("Warping mouse to %d - %d\n", This->mapped_center.x, This->mapped_center.y); SetCursorPos( This->mapped_center.x, This->mapped_center.y ); This->last_warped = GetCurrentTime();
This->need_warp = FALSE; } - - LeaveCriticalSection(&This->base.crit);
return DI_OK; }