Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
b0458516
Commit
b0458516
authored
Apr 10, 2014
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32: Cache the server queue mask on the client side and reset them when they have changed.
parent
202d91e5
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
51 additions
and
16 deletions
+51
-16
message.c
dlls/user32/message.c
+48
-15
user_private.h
dlls/user32/user_private.h
+3
-1
No files found.
dlls/user32/message.c
View file @
b0458516
...
...
@@ -2778,6 +2778,11 @@ static BOOL peek_message( MSG *msg, HWND hwnd, UINT first, UINT last, UINT flags
if
(
res
)
{
HeapFree
(
GetProcessHeap
(),
0
,
buffer
);
if
(
res
==
STATUS_PENDING
)
{
thread_info
->
wake_mask
=
changed_mask
&
(
QS_SENDMESSAGE
|
QS_SMRESULT
);
thread_info
->
changed_mask
=
changed_mask
;
}
if
(
res
!=
STATUS_BUFFER_OVERFLOW
)
return
FALSE
;
if
(
!
(
buffer
=
HeapAlloc
(
GetProcessHeap
(),
0
,
buffer_size
)))
return
FALSE
;
continue
;
...
...
@@ -3001,6 +3006,7 @@ static HANDLE get_server_queue_handle(void)
*/
static
void
wait_message_reply
(
UINT
flags
)
{
struct
user_thread_info
*
thread_info
=
get_user_thread_info
();
HANDLE
server_queue
=
get_server_queue_handle
();
for
(;;)
...
...
@@ -3017,6 +3023,8 @@ static void wait_message_reply( UINT flags )
}
SERVER_END_REQ
;
thread_info
->
wake_mask
=
thread_info
->
changed_mask
=
0
;
if
(
wake_bits
&
QS_SMRESULT
)
return
;
/* got a result */
if
(
wake_bits
&
QS_SENDMESSAGE
)
{
...
...
@@ -3029,6 +3037,43 @@ static void wait_message_reply( UINT flags )
}
}
/***********************************************************************
* wait_objects
*
* Wait for multiple objects including the server queue, with specific queue masks.
*/
static
DWORD
wait_objects
(
DWORD
count
,
const
HANDLE
*
handles
,
DWORD
timeout
,
DWORD
wake_mask
,
DWORD
changed_mask
,
DWORD
flags
)
{
struct
user_thread_info
*
thread_info
=
get_user_thread_info
();
DWORD
ret
;
assert
(
count
);
/* we must have at least the server queue */
flush_window_surfaces
(
TRUE
);
if
(
thread_info
->
wake_mask
!=
wake_mask
||
thread_info
->
changed_mask
!=
changed_mask
)
{
SERVER_START_REQ
(
set_queue_mask
)
{
req
->
wake_mask
=
wake_mask
;
req
->
changed_mask
=
changed_mask
;
req
->
skip_wait
=
0
;
wine_server_call
(
req
);
}
SERVER_END_REQ
;
thread_info
->
wake_mask
=
wake_mask
;
thread_info
->
changed_mask
=
changed_mask
;
}
ret
=
wow_handlers
.
wait_message
(
count
,
handles
,
timeout
,
changed_mask
,
flags
);
if
(
ret
!=
WAIT_TIMEOUT
)
thread_info
->
wake_mask
=
thread_info
->
changed_mask
=
0
;
return
ret
;
}
/***********************************************************************
* put_message_in_queue
*
...
...
@@ -3771,8 +3816,7 @@ BOOL WINAPI DECLSPEC_HOTPATCH GetMessageW( MSG *msg, HWND hwnd, UINT first, UINT
while
(
!
peek_message
(
msg
,
hwnd
,
first
,
last
,
PM_REMOVE
|
(
mask
<<
16
),
mask
))
{
flush_window_surfaces
(
TRUE
);
wow_handlers
.
wait_message
(
1
,
&
server_queue
,
INFINITE
,
mask
,
0
);
wait_objects
(
1
,
&
server_queue
,
INFINITE
,
mask
&
(
QS_SENDMESSAGE
|
QS_SMRESULT
),
mask
,
0
);
}
check_for_driver_events
(
msg
->
message
);
...
...
@@ -4093,23 +4137,12 @@ DWORD WINAPI MsgWaitForMultipleObjectsEx( DWORD count, const HANDLE *pHandles,
return
WAIT_FAILED
;
}
flush_window_surfaces
(
TRUE
);
/* set the queue mask */
SERVER_START_REQ
(
set_queue_mask
)
{
req
->
wake_mask
=
(
flags
&
MWMO_INPUTAVAILABLE
)
?
mask
:
0
;
req
->
changed_mask
=
mask
;
req
->
skip_wait
=
0
;
wine_server_call
(
req
);
}
SERVER_END_REQ
;
/* add the queue to the handle list */
for
(
i
=
0
;
i
<
count
;
i
++
)
handles
[
i
]
=
pHandles
[
i
];
handles
[
count
]
=
get_server_queue_handle
();
return
wow_handlers
.
wait_message
(
count
+
1
,
handles
,
timeout
,
mask
,
flags
);
return
wait_objects
(
count
+
1
,
handles
,
timeout
,
(
flags
&
MWMO_INPUTAVAILABLE
)
?
mask
:
0
,
mask
,
flags
);
}
...
...
dlls/user32/user_private.h
View file @
b0458516
...
...
@@ -172,6 +172,8 @@ struct wm_char_mapping_data
struct
user_thread_info
{
HANDLE
server_queue
;
/* Handle to server-side queue */
DWORD
wake_mask
;
/* Current queue wake mask */
DWORD
changed_mask
;
/* Current queue changed mask */
WORD
recursion_count
;
/* SendMessage recursion counter */
WORD
message_count
;
/* Get/PeekMessage loop counter */
BOOL
hook_unicode
;
/* Is current hook unicode? */
...
...
@@ -188,7 +190,7 @@ struct user_thread_info
HWND
msg_window
;
/* HWND_MESSAGE parent window */
RAWINPUT
*
rawinput
;
ULONG
pad
[
8
];
/* Available for more data */
ULONG
pad
[
6
];
/* Available for more data */
};
struct
hook_extra_info
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment