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
f20f4119
Commit
f20f4119
authored
Sep 30, 2009
by
Peter Dons Tychsen
Committed by
Alexandre Julliard
Sep 30, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
user32: Add exception handling for timer callbacks.
parent
9196e2ed
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
42 additions
and
3 deletions
+42
-3
message.c
dlls/user32/message.c
+29
-3
msg.c
dlls/user32/tests/msg.c
+13
-0
No files found.
dlls/user32/message.c
View file @
f20f4119
...
...
@@ -43,6 +43,7 @@
#include "win.h"
#include "controls.h"
#include "wine/debug.h"
#include "wine/exception.h"
WINE_DEFAULT_DEBUG_CHANNEL
(
msg
);
WINE_DECLARE_DEBUG_CHANNEL
(
relay
);
...
...
@@ -3065,9 +3066,21 @@ LRESULT WINAPI DispatchMessageA( const MSG* msg )
/* Process timer messages */
if
((
msg
->
message
==
WM_TIMER
)
||
(
msg
->
message
==
WM_SYSTIMER
))
{
if
(
msg
->
lParam
)
return
CallWindowProcA
(
(
WNDPROC
)
msg
->
lParam
,
msg
->
hwnd
,
if
(
msg
->
lParam
)
{
__TRY
{
retval
=
CallWindowProcA
(
(
WNDPROC
)
msg
->
lParam
,
msg
->
hwnd
,
msg
->
message
,
msg
->
wParam
,
GetTickCount
()
);
}
__EXCEPT_PAGE_FAULT
{
retval
=
0
;
}
__ENDTRY
return
retval
;
}
}
if
(
!
msg
->
hwnd
)
return
0
;
SPY_EnterMessage
(
SPY_DISPATCHMESSAGE
,
msg
->
hwnd
,
msg
->
message
,
...
...
@@ -3103,7 +3116,8 @@ LRESULT WINAPI DispatchMessageA( const MSG* msg )
* If the lpMsg parameter points to a WM_TIMER message and the
* parameter of the WM_TIMER message is not NULL, the lParam parameter
* points to the function that is called instead of the window
* procedure.
* procedure. The function stored in lParam (timer callback) is protected
* from causing page-faults.
*
* The message must be valid.
*
...
...
@@ -3123,9 +3137,21 @@ LRESULT WINAPI DispatchMessageW( const MSG* msg )
/* Process timer messages */
if
((
msg
->
message
==
WM_TIMER
)
||
(
msg
->
message
==
WM_SYSTIMER
))
{
if
(
msg
->
lParam
)
return
CallWindowProcW
(
(
WNDPROC
)
msg
->
lParam
,
msg
->
hwnd
,
if
(
msg
->
lParam
)
{
__TRY
{
retval
=
CallWindowProcW
(
(
WNDPROC
)
msg
->
lParam
,
msg
->
hwnd
,
msg
->
message
,
msg
->
wParam
,
GetTickCount
()
);
}
__EXCEPT_PAGE_FAULT
{
retval
=
0
;
}
__ENDTRY
return
retval
;
}
}
if
(
!
msg
->
hwnd
)
return
0
;
SPY_EnterMessage
(
SPY_DISPATCHMESSAGE
,
msg
->
hwnd
,
msg
->
message
,
...
...
dlls/user32/tests/msg.c
View file @
f20f4119
...
...
@@ -7813,6 +7813,12 @@ static VOID CALLBACK tfunc(HWND hwnd, UINT uMsg, UINT_PTR id, DWORD dwTime)
{
}
static
VOID
CALLBACK
tfunc_crash
(
HWND
hwnd
,
UINT
uMsg
,
UINT_PTR
id
,
DWORD
dwTime
)
{
/* Crash on purpose */
*
(
volatile
int
*
)
0
=
2
;
}
#define TIMER_ID 0x19
static
DWORD
WINAPI
timer_thread_proc
(
LPVOID
x
)
...
...
@@ -7834,6 +7840,7 @@ static void test_timers(void)
{
struct
timer_info
info
;
DWORD
id
;
MSG
msg
;
info
.
hWnd
=
CreateWindow
(
"TestWindowClass"
,
NULL
,
WS_OVERLAPPEDWINDOW
,
...
...
@@ -7855,6 +7862,12 @@ static void test_timers(void)
ok
(
KillTimer
(
info
.
hWnd
,
TIMER_ID
),
"KillTimer failed
\n
"
);
/* Test timer callback with crash */
info
.
id
=
SetTimer
(
info
.
hWnd
,
TIMER_ID
,
0
,
tfunc_crash
);
ok
(
info
.
id
,
"SetTimer failed
\n
"
);
Sleep
(
150
);
while
(
PeekMessage
(
&
msg
,
NULL
,
0
,
0
,
PM_REMOVE
))
DispatchMessage
(
&
msg
);
ok
(
DestroyWindow
(
info
.
hWnd
),
"failed to destroy window
\n
"
);
}
...
...
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