Commit ce829bdc authored by James Abbatiello's avatar James Abbatiello Committed by Alexandre Julliard

Better thread safety for WarpPointer hack.

parent 60532568
...@@ -109,7 +109,6 @@ void MOUSE_SendEvent( DWORD mouseStatus, DWORD posX, DWORD posY, ...@@ -109,7 +109,6 @@ void MOUSE_SendEvent( DWORD mouseStatus, DWORD posX, DWORD posY,
int height = MONITOR_GetHeight(&MONITOR_PrimaryMonitor); int height = MONITOR_GetHeight(&MONITOR_PrimaryMonitor);
int iWndsLocks; int iWndsLocks;
WINE_MOUSEEVENT wme; WINE_MOUSEEVENT wme;
BOOL bOldWarpPointer;
if ( !DefMouseEventProc ) return; if ( !DefMouseEventProc ) return;
...@@ -128,11 +127,11 @@ void MOUSE_SendEvent( DWORD mouseStatus, DWORD posX, DWORD posY, ...@@ -128,11 +127,11 @@ void MOUSE_SendEvent( DWORD mouseStatus, DWORD posX, DWORD posY,
wme.hWnd = hWnd; wme.hWnd = hWnd;
wme.keyState = keyState; wme.keyState = keyState;
bOldWarpPointer = MOUSE_Driver->pEnableWarpPointer(FALSE); MOUSE_Driver->pEnableWarpPointer(FALSE);
/* To avoid deadlocks, we have to suspend all locks on windows structures /* To avoid deadlocks, we have to suspend all locks on windows structures
before the program control is passed to the mouse driver */ before the program control is passed to the mouse driver */
iWndsLocks = WIN_SuspendWndsLock(); iWndsLocks = WIN_SuspendWndsLock();
DefMouseEventProc( mouseStatus, posX, posY, 0, (DWORD)&wme ); DefMouseEventProc( mouseStatus, posX, posY, 0, (DWORD)&wme );
WIN_RestoreWndsLock(iWndsLocks); WIN_RestoreWndsLock(iWndsLocks);
MOUSE_Driver->pEnableWarpPointer(bOldWarpPointer); MOUSE_Driver->pEnableWarpPointer(TRUE);
} }
...@@ -38,7 +38,7 @@ typedef struct tagMOUSE_DRIVER { ...@@ -38,7 +38,7 @@ typedef struct tagMOUSE_DRIVER {
VOID (*pInit)(VOID); VOID (*pInit)(VOID);
VOID (*pSetCursor)(struct tagCURSORICONINFO *); VOID (*pSetCursor)(struct tagCURSORICONINFO *);
VOID (*pMoveCursor)(WORD, WORD); VOID (*pMoveCursor)(WORD, WORD);
BOOL (*pEnableWarpPointer)(BOOL); LONG (*pEnableWarpPointer)(BOOL);
} MOUSE_DRIVER; } MOUSE_DRIVER;
extern MOUSE_DRIVER *MOUSE_Driver; extern MOUSE_DRIVER *MOUSE_Driver;
......
...@@ -217,7 +217,7 @@ extern struct tagMOUSE_DRIVER TTYDRV_MOUSE_Driver; ...@@ -217,7 +217,7 @@ extern struct tagMOUSE_DRIVER TTYDRV_MOUSE_Driver;
extern void TTYDRV_MOUSE_Init(); extern void TTYDRV_MOUSE_Init();
extern void TTYDRV_MOUSE_SetCursor(struct tagCURSORICONINFO *lpCursor); extern void TTYDRV_MOUSE_SetCursor(struct tagCURSORICONINFO *lpCursor);
extern void TTYDRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY); extern void TTYDRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY);
extern BOOL TTYDRV_MOUSE_EnableWarpPointer(BOOL bEnable); extern LONG TTYDRV_MOUSE_EnableWarpPointer(BOOL bEnable);
/* TTY windows driver */ /* TTY windows driver */
......
...@@ -438,11 +438,10 @@ extern void X11DRV_MONITOR_SetScreenSaveTimeout(struct tagMONITOR *pMonitor, int ...@@ -438,11 +438,10 @@ extern void X11DRV_MONITOR_SetScreenSaveTimeout(struct tagMONITOR *pMonitor, int
extern struct tagMOUSE_DRIVER X11DRV_MOUSE_Driver; extern struct tagMOUSE_DRIVER X11DRV_MOUSE_Driver;
extern BOOL X11DRV_MOUSE_DisableWarpPointer;
extern void X11DRV_MOUSE_Init(); extern void X11DRV_MOUSE_Init();
extern void X11DRV_MOUSE_SetCursor(struct tagCURSORICONINFO *lpCursor); extern void X11DRV_MOUSE_SetCursor(struct tagCURSORICONINFO *lpCursor);
extern void X11DRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY); extern void X11DRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY);
extern BOOL X11DRV_MOUSE_EnableWarpPointer(BOOL bEnable); extern LONG X11DRV_MOUSE_EnableWarpPointer(BOOL bEnable);
/* X11 windows driver */ /* X11 windows driver */
......
...@@ -23,9 +23,9 @@ void TTYDRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY) ...@@ -23,9 +23,9 @@ void TTYDRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY)
/*********************************************************************** /***********************************************************************
* TTYDRV_MOUSE_EnableWarpPointer * TTYDRV_MOUSE_EnableWarpPointer
*/ */
BOOL TTYDRV_MOUSE_EnableWarpPointer(BOOL bEnable) LONG TTYDRV_MOUSE_EnableWarpPointer(BOOL bEnable)
{ {
return TRUE; return 0;
} }
/*********************************************************************** /***********************************************************************
......
...@@ -23,7 +23,7 @@ DEFAULT_DEBUG_CHANNEL(cursor) ...@@ -23,7 +23,7 @@ DEFAULT_DEBUG_CHANNEL(cursor)
Cursor X11DRV_MOUSE_XCursor = None; /* Current X cursor */ Cursor X11DRV_MOUSE_XCursor = None; /* Current X cursor */
static BOOL X11DRV_MOUSE_WarpPointer = TRUE; /* hack; see DISPLAY_MoveCursor */ static LONG X11DRV_MOUSE_WarpPointer = 0; /* hack; see DISPLAY_MoveCursor */
/*********************************************************************** /***********************************************************************
* X11DRV_MOUSE_DoSetCursor * X11DRV_MOUSE_DoSetCursor
...@@ -226,7 +226,7 @@ void X11DRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY) ...@@ -226,7 +226,7 @@ void X11DRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY)
int rootX, rootY, winX, winY; int rootX, rootY, winX, winY;
unsigned int xstate; unsigned int xstate;
if (!X11DRV_MOUSE_WarpPointer) return; if (X11DRV_MOUSE_WarpPointer < 0) return;
if (!TSXQueryPointer( display, X11DRV_GetXRootWindow(), &root, &child, if (!TSXQueryPointer( display, X11DRV_GetXRootWindow(), &root, &child,
&rootX, &rootY, &winX, &winY, &xstate )) &rootX, &rootY, &winX, &winY, &xstate ))
...@@ -244,13 +244,12 @@ void X11DRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY) ...@@ -244,13 +244,12 @@ void X11DRV_MOUSE_MoveCursor(WORD wAbsX, WORD wAbsY)
/*********************************************************************** /***********************************************************************
* X11DRV_MOUSE_EnableWarpPointer * X11DRV_MOUSE_EnableWarpPointer
*/ */
BOOL X11DRV_MOUSE_EnableWarpPointer(BOOL bEnable) LONG X11DRV_MOUSE_EnableWarpPointer(BOOL bEnable)
{ {
BOOL bOldEnable = X11DRV_MOUSE_WarpPointer; if (bEnable)
return InterlockedIncrement( &X11DRV_MOUSE_WarpPointer );
X11DRV_MOUSE_WarpPointer = bEnable; else
return InterlockedDecrement( &X11DRV_MOUSE_WarpPointer );
return bOldEnable;
} }
/*********************************************************************** /***********************************************************************
......
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