13 /* Make room for a KTRAP_FRAME */
14 sub rsp, SIZE_KTRAP_FRAME
15 // .allocstack SIZE_KTRAP_FRAME
18 mov [rsp + KTRAP_FRAME_Rbp], rbp
20 /* Save non-volatile registers */
21 mov [rsp + KTRAP_FRAME_Rbx], rbx
22 mov [rsp + KTRAP_FRAME_Rdi], rdi
23 mov [rsp + KTRAP_FRAME_Rsi], rsi
25 /* Save volatile registers */
26 mov [rsp + KTRAP_FRAME_Rax], rax
27 mov [rsp + KTRAP_FRAME_Rcx], rcx
28 mov [rsp + KTRAP_FRAME_Rdx], rdx
29 mov [rsp + KTRAP_FRAME_R8], r8
30 mov [rsp + KTRAP_FRAME_R9], r9
31 mov [rsp + KTRAP_FRAME_R10], r10
32 mov [rsp + KTRAP_FRAME_R11], r11
34 /* Save xmm registers */
35 movdqa [rsp + KTRAP_FRAME_Xmm0], xmm0
36 movdqa [rsp + KTRAP_FRAME_Xmm1], xmm1
37 movdqa [rsp + KTRAP_FRAME_Xmm2], xmm2
38 movdqa [rsp + KTRAP_FRAME_Xmm3], xmm3
39 movdqa [rsp + KTRAP_FRAME_Xmm4], xmm4
40 movdqa [rsp + KTRAP_FRAME_Xmm5], xmm5
42 /* Save cs and previous mode */
44 mov [rsp + KTRAP_FRAME_SegCs], ax
46 mov [rsp + KTRAP_FRAME_PreviousMode], al
48 /* Save segment selectors */
50 mov [rsp + KTRAP_FRAME_SegDs], ax
52 mov [rsp + KTRAP_FRAME_SegEs], ax
54 mov [rsp + KTRAP_FRAME_SegFs], ax
56 mov [rsp + KTRAP_FRAME_SegGs], ax
58 /* Save previous irql */
60 mov [rsp + KTRAP_FRAME_PreviousIrql], al
62 /* Save debug registers */
64 mov [rsp + KTRAP_FRAME_Dr0], rax
66 mov [rsp + KTRAP_FRAME_Dr1], rax
68 mov [rsp + KTRAP_FRAME_Dr2], rax
70 mov [rsp + KTRAP_FRAME_Dr3], rax
72 mov [rsp + KTRAP_FRAME_Dr6], rax
74 mov [rsp + KTRAP_FRAME_Dr7], rax
76 /* Point rbp, where rsp was before */
77 lea rbp, [rsp + SIZE_KTRAP_FRAME]
78 mov [rsp + KTRAP_FRAME_Rsp], rbp
80 /* Store the EFLAGS we previously pushed on the stack */
82 mov [rsp + KTRAP_FRAME_EFlags], rax
84 /* Get RIP from the stack */
86 mov [rsp + KTRAP_FRAME_Rip], rax
88 /* Make sure the direction flag is cleared */
91 /* Clear all breakpoint enables in dr7. */
97 mov byte ptr [rsp + KTRAP_FRAME_P5], 1 /* FirstChance */
98 mov r9, rsp /* Pointer to the trap frame */
99 mov r8, 0 /* Context */
100 mov dl, 0 /* PreviousMode (KernelMode) */
101 mov rcx, 0 /* ExceptionRecord */
102 call KdbEnterDebuggerException
104 /* Restore segment selectors */
105 mov ax, [rsp + KTRAP_FRAME_SegDs]
107 mov ax, [rsp + KTRAP_FRAME_SegEs]
109 mov ax, [rsp + KTRAP_FRAME_SegFs]
112 /* Restore non-volatile registers */
113 mov rbx, [rsp + KTRAP_FRAME_Rbx]
114 mov rdi, [rsp + KTRAP_FRAME_Rdi]
115 mov rsi, [rsp + KTRAP_FRAME_Rsi]
117 /* Restore volatile registers */
118 mov rax, [rsp + KTRAP_FRAME_Rax]
119 mov rcx, [rsp + KTRAP_FRAME_Rcx]
120 mov rdx, [rsp + KTRAP_FRAME_Rdx]
121 mov r8, [rsp + KTRAP_FRAME_R8]
122 mov r9, [rsp + KTRAP_FRAME_R9]
123 mov r10, [rsp + KTRAP_FRAME_R10]
124 mov r11, [rsp + KTRAP_FRAME_R11]
127 mov rsp, [rsp + KTRAP_FRAME_Rsp]
134 .globl KdbpStackSwitchAndCall
135 KdbpStackSwitchAndCall:
143 /* Save old stack on new stack */
149 /* Restire old stack */