Author: tkreuzer
Date: Fri Nov 14 19:21:50 2008
New Revision: 37370
URL:
http://svn.reactos.org/svn/reactos?rev=37370&view=rev
Log:
RtlCaptureContext can throw an exception. As we need to push the flags on the stack, we
need to create unwind info to make sure we can properly unwind. So instead of pushing the
flags and then popping them back, push them on the stack at the beginning of the function,
reference the location later, clean up the stack at the function end. Also add
.cif_adjust_cfa_offset unwind op.
Modified:
branches/ros-amd64-bringup/reactos/lib/rtl/amd64/except_asm.S
Modified: branches/ros-amd64-bringup/reactos/lib/rtl/amd64/except_asm.S
URL:
http://svn.reactos.org/svn/reactos/branches/ros-amd64-bringup/reactos/lib/r…
==============================================================================
--- branches/ros-amd64-bringup/reactos/lib/rtl/amd64/except_asm.S [iso-8859-1] (original)
+++ branches/ros-amd64-bringup/reactos/lib/rtl/amd64/except_asm.S [iso-8859-1] Fri Nov 14
19:21:50 2008
@@ -23,40 +23,45 @@
_RtlCaptureContext:
.cfi_startproc
- /* Push eflags */
+ /* Push rflags */
pushfq
+ .cfi_adjust_cfa_offset 8
/* Save the basic register context */
mov [rcx + CONTEXT_Rax], rax
mov [rcx + CONTEXT_Rcx], rcx
mov [rcx + CONTEXT_Rdx], rdx
+
+ /* Load rflags into rax */
+ mov rax, [rsp]
+
mov [rcx + CONTEXT_Rbx], rbx
-
- /* pop eflags */
- pop [rcx + CONTEXT_EFlags]
-
mov [rcx + CONTEXT_Rsi], rsi
mov [rcx + CONTEXT_Rdi], rdi
+
+ /* Store rflags */
+ mov [rcx + CONTEXT_EFlags], rax
+
mov [rcx + CONTEXT_Rbp], rbp
+ mov [rcx + CONTEXT_R8], r8
+ mov [rcx + CONTEXT_R9], r9
/* Load former stack pointer in rax */
- lea rax, [rsp + 8]
+ lea rax, [rsp + 0x10]
- mov [rcx + CONTEXT_R8], r8
- mov [rcx + CONTEXT_R9], r9
mov [rcx + CONTEXT_R10], r10
mov [rcx + CONTEXT_R11], r11
+ mov [rcx + CONTEXT_R12], r12
/* Store stack pointer */
mov [rcx + CONTEXT_Rsp], rax
- mov [rcx + CONTEXT_R12], r12
mov [rcx + CONTEXT_R13], r13
mov [rcx + CONTEXT_R14], r14
mov [rcx + CONTEXT_R15], r15
/* Load return address in rax */
- mov rax, [rsp]
+ mov rax, [rsp + 8]
/* Safe segment selectors */
mov [rcx + CONTEXT_SegCs], cs
@@ -87,6 +92,8 @@
movdqa [rcx + CONTEXT_Xmm14], xmm14
movdqa [rcx + CONTEXT_Xmm15], xmm15
*/
+ /* Cleanup stack and return */
+ add rsp, 8
ret
.cfi_endproc
.endfunc