VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-c64-Trap64Generic.asm@ 60674

Last change on this file since 60674 was 60657, checked in by vboxsync, 9 years ago

bs3kit: updates

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 12.6 KB
Line 
1; $Id: bs3-c64-Trap64Generic.asm 60657 2016-04-22 15:57:22Z vboxsync $
2;; @file
3; BS3Kit - Trap, 64-bit assembly handlers.
4;
5
6;
7; Copyright (C) 2007-2016 Oracle Corporation
8;
9; This file is part of VirtualBox Open Source Edition (OSE), as
10; available from http://www.virtualbox.org. This file is free software;
11; you can redistribute it and/or modify it under the terms of the GNU
12; General Public License (GPL) as published by the Free Software
13; Foundation, in version 2 as it comes in the "COPYING" file of the
14; VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15; hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16;
17; The contents of this file may alternatively be used under the terms
18; of the Common Development and Distribution License Version 1.0
19; (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20; VirtualBox OSE distribution, in which case the provisions of the
21; CDDL are applicable instead of those of the GPL.
22;
23; You may elect to license modified versions of this file under the
24; terms and conditions of either the GPL or the CDDL or both.
25;
26
27;*********************************************************************************************************************************
28;* Header Files *
29;*********************************************************************************************************************************
30%include "bs3kit-template-header.mac"
31
32%ifndef TMPL_64BIT
33 %error "64-bit only template"
34%endif
35
36
37;*********************************************************************************************************************************
38;* External Symbols *
39;*********************************************************************************************************************************
40BS3_EXTERN_DATA16 g_bBs3CurrentMode
41TMPL_BEGIN_TEXT
42BS3_EXTERN_CMN Bs3TrapDefaultHandler
43BS3_EXTERN_CMN Bs3RegCtxRestore
44TMPL_BEGIN_TEXT
45
46
47;*********************************************************************************************************************************
48;* Global Variables *
49;*********************************************************************************************************************************
50BS3_BEGIN_DATA16
51;; Easy to access flat address of Bs3Trap64GenericEntries.
52BS3_GLOBAL_DATA g_Bs3Trap64GenericEntriesFlatAddr, 4
53 dd Bs3Trap64GenericEntries wrt FLAT
54
55BS3_BEGIN_DATA64
56;; Pointer C trap handlers.
57BS3_GLOBAL_DATA g_apfnBs3TrapHandlers_c64, 2048
58 resq 256
59
60
61
62;;
63; Generic entry points for IDT handlers, 8 byte spacing.
64;
65BS3_PROC_BEGIN Bs3Trap64GenericEntries
66%macro Bs3Trap64GenericEntry 1
67 db 06ah, i ; push imm8 - note that this is a signextended value.
68 jmp %1
69 ALIGNCODE(8)
70%assign i i+1
71%endmacro
72
73%assign i 0 ; start counter.
74 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 0
75 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 1
76 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 2
77 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 3
78 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 4
79 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 5
80 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 6
81 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 7
82 Bs3Trap64GenericEntry Bs3Trap64GenericTrapErrCode ; 8
83 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 9
84 Bs3Trap64GenericEntry Bs3Trap64GenericTrapErrCode ; a
85 Bs3Trap64GenericEntry Bs3Trap64GenericTrapErrCode ; b
86 Bs3Trap64GenericEntry Bs3Trap64GenericTrapErrCode ; c
87 Bs3Trap64GenericEntry Bs3Trap64GenericTrapErrCode ; d
88 Bs3Trap64GenericEntry Bs3Trap64GenericTrapErrCode ; e
89 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; f (reserved)
90 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 10
91 Bs3Trap64GenericEntry Bs3Trap64GenericTrapErrCode ; 11
92 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 12
93 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 13
94 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 14
95 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 15 (reserved)
96 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 16 (reserved)
97 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 17 (reserved)
98 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 18 (reserved)
99 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 19 (reserved)
100 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 1a (reserved)
101 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 1b (reserved)
102 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 1c (reserved)
103 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 1d (reserved)
104 Bs3Trap64GenericEntry Bs3Trap64GenericTrapErrCode ; 1e
105 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt ; 1f (reserved)
106%rep 224
107 Bs3Trap64GenericEntry Bs3Trap64GenericTrapOrInt
108%endrep
109BS3_PROC_END Bs3Trap64GenericEntries
110
111
112
113
114;;
115; Trap or interrupt (no error code).
116;
117BS3_PROC_BEGIN Bs3Trap64GenericTrapOrInt
118 push rbp ; 0
119 mov rbp, rsp
120 pushfq ; -08h
121 cld
122 push rdi
123
124 ; Reserve space for the the register and trap frame.
125 mov edi, (BS3TRAPFRAME_size + 15) / 16
126.more_zeroed_space:
127 push qword 0
128 push qword 0
129 dec edi
130 jnz .more_zeroed_space
131 mov rdi, rsp ; rdi points to trapframe structure.
132
133 ; Free up rax.
134 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rax], rax
135
136 ; Copy stuff from the stack over.
137 mov al, [rbp + 08h]
138 mov [rdi + BS3TRAPFRAME.bXcpt], al
139 mov rax, [rbp]
140 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbp], rax
141 mov rax, [rbp - 08h]
142 mov [rdi + BS3TRAPFRAME.fHandlerRfl], rax
143 mov rax, [rbp - 10h]
144 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rdi], rax
145
146 lea rbp, [rbp + 08h] ; iret - 8 (i.e. rbp frame chain location)
147 jmp Bs3Trap64GenericCommon
148BS3_PROC_END Bs3Trap64GenericTrapOrInt
149
150
151;;
152; Trap with error code.
153;
154BS3_PROC_BEGIN Bs3Trap64GenericTrapErrCode
155 push rbp ; 0
156 mov rbp, rsp
157 pushfq ; -08h
158 cld
159 push rdi
160
161 ; Reserve space for the the register and trap frame.
162 mov edi, (BS3TRAPFRAME_size + 15) / 16
163.more_zeroed_space:
164 push qword 0
165 push qword 0
166 dec edi
167 jnz .more_zeroed_space
168 mov rdi, rsp ; rdi points to trapframe structure.
169
170 ; Free up rax.
171 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rax], rax
172
173 ; Copy stuff from the stack over.
174 mov rax, [rbp + 10h]
175 mov [rdi + BS3TRAPFRAME.uErrCd], rax
176 mov al, [rbp + 08h]
177 mov [rdi + BS3TRAPFRAME.bXcpt], al
178 mov rax, [rbp]
179 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbp], rax
180 mov rax, [rbp - 08h]
181 mov [rdi + BS3TRAPFRAME.fHandlerRfl], rax
182 mov rax, [rbp - 10h]
183 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rdi], rax
184
185 lea rbp, [rbp + 10h] ; iret - 8 (i.e. rbp frame chain location)
186 jmp Bs3Trap64GenericCommon
187BS3_PROC_END Bs3Trap64GenericTrapErrCode
188
189
190;;
191; Common context saving code and dispatching.
192;
193; @param rdi Pointer to the trap frame. The following members have been
194; filled in by the previous code:
195; - bXcpt
196; - uErrCd
197; - fHandlerRfl
198; - Ctx.rax
199; - Ctx.rbp
200; - Ctx.rdi
201;
202; @param rbp Pointer to the dword before the iret frame, i.e. where rbp
203; would be saved if this was a normal call.
204;
205BS3_PROC_BEGIN Bs3Trap64GenericCommon
206 ;
207 ; Fake RBP frame.
208 ;
209 mov rax, [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbp]
210 mov [rbp], rax
211
212 ;
213 ; Save the remaining GPRs and segment registers.
214 ;
215 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rcx], rcx
216 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rdx], rdx
217 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbx], rbx
218 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsi], rsi
219 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.r8 ], r8
220 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.r9 ], r9
221 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.r10], r10
222 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.r11], r11
223 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.r12], r12
224 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.r13], r13
225 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.r14], r14
226 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.r15], r15
227 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.ds], ds
228 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.es], es
229 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.fs], fs
230 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.gs], gs
231 lea rax, [rbp + 8h]
232 mov [rdi + BS3TRAPFRAME.uHandlerRsp], rax
233 mov [rdi + BS3TRAPFRAME.uHandlerSs], ss
234
235 ;
236 ; Load 32-bit data selector for the DPL we're executing at into DS, ES and SS.
237 ; Save the handler CS value first.
238 ;
239 mov ax, cs
240 mov [rdi + BS3TRAPFRAME.uHandlerCs], ax
241 AssertCompile(BS3_SEL_RING_SHIFT == 8)
242 and al, 3
243 mov ah, al
244 add ax, BS3_SEL_R0_DS64
245 mov ds, ax
246 mov es, ax
247 mov ss, ax
248
249 ;
250 ; Copy and update the mode.
251 ;
252 mov al, [BS3_DATA16_WRT(g_bBs3CurrentMode)]
253 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.bMode], al
254 and al, ~BS3_MODE_CODE_MASK
255 or al, BS3_MODE_CODE_64
256 mov [BS3_DATA16_WRT(g_bBs3CurrentMode)], al
257
258 ;
259 ; Copy iret info. Bless AMD for only doing one 64-bit iret frame layout.
260 ;
261 mov rcx, [rbp + 08]
262 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rip], rcx
263 mov cx, [rbp + 10h]
264 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.cs], cx
265 and cl, 3
266 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.bCpl], cl
267 mov rcx, [rbp + 18h]
268 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rflags], rcx
269 mov rcx, [rbp + 20h]
270 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsp], rcx
271 mov cx, [rbp + 28h]
272 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.ss], cx
273 mov byte [rdi + BS3TRAPFRAME.cbIretFrame], 5*8
274
275 ;
276 ; Control registers.
277 ;
278 str ax
279 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.tr], ax
280 sldt ax
281 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.ldtr], ax
282
283 mov ax, ss
284 test al, 3
285 jnz .skip_crX_because_cpl_not_0
286
287 mov rax, cr0
288 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr0], rax
289 mov rax, cr2
290 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr2], rax
291 mov rax, cr3
292 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr3], rax
293 mov rax, cr4
294 mov [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr4], rax
295 jmp .dispatch_to_handler
296
297.skip_crX_because_cpl_not_0:
298 or byte [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.fbFlags], \
299 BS3REG_CTX_F_NO_CR0_IS_MSW | BS3REG_CTX_F_NO_CR2_CR3 | BS3REG_CTX_F_NO_CR4
300 smsw [rdi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr0]
301
302 ;
303 ; Dispatch it to C code.
304 ;
305.dispatch_to_handler: ; The double fault code joins us here.
306 movzx ebx, byte [rdi + BS3TRAPFRAME.bXcpt]
307 lea rax, [BS3_DATA16_WRT(_g_apfnBs3TrapHandlers_c64)]
308 mov rax, [rax + rbx * 8]
309 or rax, rax
310 jnz .call_handler
311 lea rax, [BS3_WRT_RIP(Bs3TrapDefaultHandler)]
312.call_handler:
313 sub rsp, 20h
314 mov [rsp], rdi
315 mov rcx, rdi
316 call rax
317
318 ;
319 ; Resume execution using trap frame.
320 ;
321 xor edx, edx ; fFlags
322 mov [rsp + 8], rdx
323 lea rcx, [rdi + BS3TRAPFRAME.Ctx] ; pCtx
324 mov [rsp], rcx
325 call Bs3RegCtxRestore
326.panic:
327 hlt
328 jmp .panic
329BS3_PROC_END Bs3Trap64GenericCommon
330
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette