Commit 69b65723 authored by Paul Gofman's avatar Paul Gofman Committed by Alexandre Julliard

ntdll: Don't reset rsp to context->Rsp until exception data is copied.

Context record may be stored on stack below context stack. This happens, e. g., with RtlRaiseException(). Signed-off-by: 's avatarPaul Gofman <pgofman@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 877540b5
...@@ -1979,17 +1979,18 @@ __ASM_GLOBAL_FUNC( user_exception_dispatcher_trampoline, ...@@ -1979,17 +1979,18 @@ __ASM_GLOBAL_FUNC( user_exception_dispatcher_trampoline,
void WINAPI do_call_user_exception_dispatcher(EXCEPTION_RECORD *rec, CONTEXT *context, struct stack_layout *stack) void WINAPI do_call_user_exception_dispatcher(EXCEPTION_RECORD *rec, CONTEXT *context, struct stack_layout *stack)
{ {
memcpy(&stack->context, context, sizeof(*context)); memmove(&stack->context, context, sizeof(*context));
memcpy(&stack->rec, rec, sizeof(*rec)); memcpy(&stack->rec, rec, sizeof(*rec));
user_exception_dispatcher_trampoline( stack, pKiUserExceptionDispatcher ); user_exception_dispatcher_trampoline( stack, pKiUserExceptionDispatcher );
} }
__ASM_GLOBAL_FUNC( call_user_exception_dispatcher, __ASM_GLOBAL_FUNC( call_user_exception_dispatcher,
"movq 0x98(%rdx),%rsp\n\t" /* context->Rsp */ "movq 0x98(%rdx),%r8\n\t" /* context->Rsp */
"and $~0xf,%rsp\n\t" "andq $~0xf,%r8\n\t"
"sub $0x630,%rsp\n\t" /* sizeof(struct stack_layout) */ "subq $0x630,%r8\n\t" /* sizeof(struct stack_layout) */
"movq %rsp,%r8\n\t" "cmpq %r8,%rsp\n\t"
"cmovbq %r8,%rsp\n\t"
"jmp " __ASM_NAME("do_call_user_exception_dispatcher") "\n\t") "jmp " __ASM_NAME("do_call_user_exception_dispatcher") "\n\t")
/*********************************************************************** /***********************************************************************
......
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