VirtualBox

source: vbox/trunk/src/VBox/ValidationKit/bootsectors/bs3kit/bs3-c32-Trap32Generic.asm@ 61239

Last change on this file since 61239 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: 21.2 KB
Line 
1; $Id: bs3-c32-Trap32Generic.asm 60657 2016-04-22 15:57:22Z vboxsync $
2;; @file
3; BS3Kit - Trap, 32-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_32BIT
33 %error "32-bit only template"
34%endif
35
36
37;*********************************************************************************************************************************
38;* External Symbols *
39;*********************************************************************************************************************************
40BS3_EXTERN_DATA16 g_bBs3CurrentMode
41BS3_EXTERN_DATA16 g_uBs3CpuDetected
42BS3_EXTERN_SYSTEM16 Bs3Gdt
43TMPL_BEGIN_TEXT
44BS3_EXTERN_CMN Bs3TrapDefaultHandler
45BS3_EXTERN_CMN Bs3RegCtxRestore
46TMPL_BEGIN_TEXT
47
48
49;*********************************************************************************************************************************
50;* Global Variables *
51;*********************************************************************************************************************************
52BS3_BEGIN_DATA16
53;; Easy to access flat address of Bs3Trap32GenericEntries.
54BS3_GLOBAL_DATA g_Bs3Trap32GenericEntriesFlatAddr, 4
55 dd Bs3Trap32GenericEntries wrt FLAT
56;; Easy to access flat address of Bs3Trap32DoubleFaultHandler.
57BS3_GLOBAL_DATA g_Bs3Trap32DoubleFaultHandlerFlatAddr, 4
58 dd Bs3Trap32DoubleFaultHandler wrt FLAT
59
60BS3_BEGIN_DATA32
61;; Pointer C trap handlers.
62BS3_GLOBAL_DATA g_apfnBs3TrapHandlers_c32, 1024
63 resd 256
64
65
66
67;;
68; Generic entry points for IDT handlers, 8 byte spacing.
69;
70BS3_PROC_BEGIN Bs3Trap32GenericEntries
71%macro Bs3Trap32GenericEntryNoErr 1
72 push byte 0 ; 2 byte: fake error code.
73 db 06ah, i ; 2 byte: push imm8 - note that this is a signextended value.
74 jmp near %1 ; 5 byte
75 ALIGNCODE(2)
76%assign i i+1
77%endmacro
78
79%macro Bs3Trap32GenericEntryErrCd 1
80 db 06ah, i ; 2 byte: push imm8 - note that this is a signextended value.
81 jmp near %1 ; 5 byte
82 db 0cch, 0cch ; 2 byte: padding.
83 ALIGNCODE(2)
84%assign i i+1
85%endmacro
86
87%assign i 0 ; start counter.
88 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 0
89 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 1
90 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 2
91 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 3
92 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 4
93 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 5
94 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 6
95 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 7
96 Bs3Trap32GenericEntryErrCd bs3Trap32GenericTrapOrInt ; 8
97 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 9
98 Bs3Trap32GenericEntryErrCd bs3Trap32GenericTrapOrInt ; a
99 Bs3Trap32GenericEntryErrCd bs3Trap32GenericTrapOrInt ; b
100 Bs3Trap32GenericEntryErrCd bs3Trap32GenericTrapOrInt ; c
101 Bs3Trap32GenericEntryErrCd bs3Trap32GenericTrapOrInt ; d
102 Bs3Trap32GenericEntryErrCd bs3Trap32GenericTrapOrInt ; e
103 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; f (reserved)
104 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 10
105 Bs3Trap32GenericEntryErrCd bs3Trap32GenericTrapOrInt ; 11
106 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 12
107 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 13
108 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 14
109 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 15 (reserved)
110 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 16 (reserved)
111 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 17 (reserved)
112 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 18 (reserved)
113 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 19 (reserved)
114 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 1a (reserved)
115 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 1b (reserved)
116 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 1c (reserved)
117 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 1d (reserved)
118 Bs3Trap32GenericEntryErrCd bs3Trap32GenericTrapOrInt ; 1e
119 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt ; 1f (reserved)
120%rep 224
121 Bs3Trap32GenericEntryNoErr bs3Trap32GenericTrapOrInt
122%endrep
123BS3_PROC_END Bs3Trap32GenericEntries
124AssertCompile(Bs3Trap32GenericEntries_EndProc - Bs3Trap32GenericEntries == 10*256)
125
126
127;;
128; Trap or interrupt with error code, faked if necessary.
129;
130BS3_PROC_BEGIN bs3Trap32GenericTrapOrInt
131 push ebp ; 0
132 mov ebp, esp
133 pushfd ; -04h
134 cld
135 push eax ; -08h
136 push edi ; -0ch
137 lea eax, [esp + (4+1+1)*4] ; 4 pushes above, 1 exception number push, 1 error code.
138 push eax ; -10h = handler ESP
139 add eax, 3*4 ; 3 dword iret frame
140 push eax ; -14h = caller ESP if same CPL
141 push ss ; -18h
142 push ds ; -1ch
143
144 ; Make sure we've got a flat DS. It makes everything so much simpler.
145 mov ax, ss
146 and al, 3
147 AssertCompile(BS3_SEL_RING_SHIFT == 8)
148 mov ah, al
149 add ax, BS3_SEL_R0_DS32
150 mov ds, ax
151
152 ;
153 ; We may be comming from 16-bit code with a 16-bit SS. Thunk it as
154 ; the C code may assume flat SS and we'll mess up by using EBP/ESP/EDI
155 ; instead of BP/SP/SS:DI. ASSUMES standard GDT selector.
156 ;
157 mov ax, ss
158 lar eax, ax
159 test eax, X86LAR_F_D
160 jz .stack_thunk
161 mov ax, ss
162 and al, 3
163 AssertCompile(BS3_SEL_RING_SHIFT == 8)
164 mov ah, al
165 add ax, BS3_SEL_R0_SS32
166 mov ss, ax
167 jmp .stack_flat
168.stack_thunk:
169 mov di, ss
170 and edi, X86_SEL_MASK_OFF_RPL
171 mov al, [X86DESCGENERIC_BIT_OFF_BASE_HIGH1 / 8 + edi + Bs3Gdt wrt FLAT]
172 mov ah, [X86DESCGENERIC_BIT_OFF_BASE_HIGH2 / 8 + edi + Bs3Gdt wrt FLAT]
173 shl eax, 16
174 mov ax, [X86DESCGENERIC_BIT_OFF_BASE_LOW / 8 + edi + Bs3Gdt wrt FLAT] ; eax = SS.base
175 movzx ebp, bp ; SS:BP -> flat EBP.
176 add ebp, eax
177 movzx edi, sp ; SS:SP -> flat ESP in EAX.
178 add edi, eax
179 mov ax, ss
180 and al, 3
181 AssertCompile(BS3_SEL_RING_SHIFT == 8)
182 mov ah, al
183 add ax, BS3_SEL_R0_SS32
184 mov ss, ax
185 mov esp, edi
186 sub dword [ebp - 10h], (4+1)*4 ; Recalc handler ESP in case of wraparound.
187 add word [ebp - 10h], (4+1)*4
188 sub dword [ebp - 10h], (4+1+3)*4 ; Recalc caller ESP in case of wraparound.
189 add word [ebp - 10h], (4+1+3)*4
190.stack_flat:
191
192 ; Reserve space for the the register and trap frame.
193 mov eax, (BS3TRAPFRAME_size + 7) / 8
194AssertCompileSizeAlignment(BS3TRAPFRAME, 8)
195.more_zeroed_space:
196 push dword 0
197 push dword 0
198 dec eax
199 jnz .more_zeroed_space
200 mov edi, esp ; edi points to trapframe structure.
201
202 ; Copy stuff from the stack over.
203 mov eax, [ebp + 8]
204;; @todo Do voodoo checks for 'int xx' or misguided hardware interrupts.
205 mov [edi + BS3TRAPFRAME.uErrCd], eax
206 mov al, [ebp + 4]
207 mov [edi + BS3TRAPFRAME.bXcpt], al
208 mov eax, [ebp]
209 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbp], eax
210 mov eax, [ebp - 04h]
211 mov [edi + BS3TRAPFRAME.fHandlerRfl], eax
212 mov eax, [ebp - 08h]
213 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rax], eax
214 mov eax, [ebp - 0ch]
215 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rdi], eax
216 mov eax, [ebp - 10h]
217 mov [edi + BS3TRAPFRAME.uHandlerRsp], eax
218 mov eax, [ebp - 14h]
219 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsp], eax
220 mov ax, [ebp - 18h]
221 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ss], ax
222 mov [edi + BS3TRAPFRAME.uHandlerSs], ax
223 mov ax, [ebp - 1ch]
224 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ds], ax
225
226 lea ebp, [ebp + 8] ; iret - 4 (i.e. ebp frame chain location)
227 jmp bs3Trap32GenericCommon
228BS3_PROC_END bs3Trap32GenericTrapErrCode
229
230
231;;
232; Common context saving code and dispatching.
233;
234; @param edi Pointer to the trap frame. The following members have been
235; filled in by the previous code:
236; - bXcpt
237; - uErrCd
238; - fHandlerRfl
239; - uHandlerRsp
240; - uHandlerSs
241; - Ctx.rax
242; - Ctx.rbp
243; - Ctx.rdi
244; - Ctx.rsp - assuming same CPL
245; - Ctx.ds
246; - Ctx.ss
247;
248; @param ebp Pointer to the dword before the iret frame, i.e. where ebp
249; would be saved if this was a normal call.
250;
251; @remarks This is a separate function for hysterical raisins.
252;
253BS3_PROC_BEGIN bs3Trap32GenericCommon
254 ;
255 ; Fake EBP frame.
256 ;
257 mov eax, [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbp]
258 mov [ebp], eax
259
260 ;
261 ; Save the remaining GPRs and segment registers.
262 ;
263 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rcx], ecx
264 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rdx], edx
265 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbx], ebx
266 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsi], esi
267 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.es], es
268 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.fs], fs
269 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.gs], gs
270
271 ;
272 ; Load 32-bit data selector for the DPL we're executing at into DS and ES.
273 ; Save the handler CS value first.
274 ;
275 mov ax, cs
276 mov [edi + BS3TRAPFRAME.uHandlerCs], ax
277 and al, 3
278 AssertCompile(BS3_SEL_RING_SHIFT == 8)
279 mov ah, al
280 add ax, BS3_SEL_R0_DS32
281 mov ds, ax
282 mov es, ax
283
284 ;
285 ; Copy and update the mode now that we've got a flat DS.
286 ;
287 mov al, [BS3_DATA16_WRT(g_bBs3CurrentMode)]
288 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.bMode], al
289 and al, ~BS3_MODE_CODE_MASK
290 or al, BS3_MODE_CODE_32
291 mov [BS3_DATA16_WRT(g_bBs3CurrentMode)], al
292
293 ;
294 ; Copy iret info.
295 ;
296 mov ecx, [ebp + 4]
297 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rip], ecx
298 mov ecx, [ebp + 12]
299 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rflags], ecx
300 mov cx, [ebp + 8]
301 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.cs], cx
302 test dword [ebp + 12], X86_EFL_VM
303 jnz .iret_frame_v8086
304 mov ax, ss
305 and al, 3
306 and cl, 3
307 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.bCpl], cl
308 cmp cl, al
309 je .iret_frame_same_cpl
310
311.iret_frame_different_cpl:
312 mov ecx, [ebp + 16]
313 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsp], ecx
314 mov cx, [ebp + 20]
315 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ss], cx
316 mov byte [edi + BS3TRAPFRAME.cbIretFrame], 5*4
317 jmp .iret_frame_done
318
319.iret_frame_v8086:
320 mov byte [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.bCpl], 3
321 or byte [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.bMode], BS3_MODE_CODE_V86 ; paranoia ^ 2
322 movzx ecx, word [ebp + 16]
323 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsp], ecx
324 mov cx, [ebp + 20]
325 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ss], cx
326 mov cx, [ebp + 24]
327 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.es], cx
328 mov cx, [ebp + 28]
329 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ds], cx
330 mov cx, [ebp + 32]
331 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.fs], cx
332 mov cx, [ebp + 36]
333 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.gs], cx
334 mov byte [edi + BS3TRAPFRAME.cbIretFrame], 9*4
335 jmp .iret_frame_done
336
337.iret_frame_same_cpl: ; (caller already set SS:RSP and uHandlerRsp for same CPL iret frames)
338 mov byte [edi + BS3TRAPFRAME.cbIretFrame], 3*4
339
340.iret_frame_done:
341 ;
342 ; Control registers.
343 ;
344 str ax
345 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.tr], ax
346 sldt ax
347 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ldtr], ax
348
349 mov ax, ss
350 test al, 3
351 jnz .skip_crX_because_cpl_not_0
352
353 mov eax, cr3
354 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr3], eax
355.save_cr0_cr2_cr4: ; The double fault code joins us here.
356 mov eax, cr0
357 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr0], eax
358 mov eax, cr2
359 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr2], eax
360
361 test byte [1 + BS3_DATA16_WRT(g_uBs3CpuDetected)], (BS3CPU_F_CPUID >> 8) ; CR4 first appeared in later 486es.
362 jz .skip_cr4_because_not_there
363 mov eax, cr4
364 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr4], eax
365 jmp .set_flags
366
367.skip_cr4_because_not_there:
368 mov byte [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.fbFlags], BS3REG_CTX_F_NO_CR4
369 jmp .set_flags
370
371.skip_crX_because_cpl_not_0:
372 or byte [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.fbFlags], \
373 BS3REG_CTX_F_NO_CR0_IS_MSW | BS3REG_CTX_F_NO_CR2_CR3 | BS3REG_CTX_F_NO_CR4
374 smsw [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr0]
375.set_flags:
376 or byte [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.fbFlags], BS3REG_CTX_F_NO_AMD64
377
378 ;
379 ; Dispatch it to C code.
380 ;
381.dispatch_to_handler:
382 movzx ebx, byte [edi + BS3TRAPFRAME.bXcpt]
383 mov eax, [ebx * 4 + BS3_DATA16_WRT(_g_apfnBs3TrapHandlers_c32)]
384 or eax, eax
385 jnz .call_handler
386 mov eax, Bs3TrapDefaultHandler
387.call_handler:
388 push edi
389 call eax
390
391 ;
392 ; Resume execution using trap frame.
393 ;
394 push 0
395 add edi, BS3TRAPFRAME.Ctx
396 push edi
397 call Bs3RegCtxRestore
398.panic:
399 hlt
400 jmp .panic
401BS3_PROC_END bs3Trap32GenericCommon
402
403
404;;
405; Helper.
406;
407; @retruns Flat address in eax.
408; @param ax
409; @uses eax
410;
411bs3Trap32TssInAxToFlatInEax:
412 ; Get the GDT base address and find the descriptor address (EAX)
413 sub esp, 8+2
414 sgdt [esp]
415 and eax, 0fff8h
416 add eax, [esp + 2] ; GDT base address.
417 add esp, 8+2
418
419 ; Get the flat TSS address from the descriptor.
420 mov al, [eax + (X86DESCGENERIC_BIT_OFF_BASE_HIGH1 / 8)]
421 mov ah, [eax + (X86DESCGENERIC_BIT_OFF_BASE_HIGH2 / 8)]
422 shl eax, 16
423 mov ax, [eax + (X86DESCGENERIC_BIT_OFF_BASE_LOW / 8)]
424 ret
425
426;;
427; Double fault handler.
428;
429; We don't have to load any selectors or clear anything in EFLAGS because the
430; TSS specified sane values which got loaded during the task switch.
431;
432BS3_PROC_BEGIN Bs3Trap32DoubleFaultHandler
433 push 0 ; We'll copy the rip from the other TSS here later to create a more sensible call chain.
434 push ebp
435 mov ebp, esp
436
437 pushfd ; Get handler flags.
438 pop ecx
439
440 xor edx, edx ; NULL register.
441
442 ;
443 ; Allocate a zero filled trap frame.
444 ;
445 mov eax, (BS3TRAPFRAME_size + 7) / 8
446AssertCompileSizeAlignment(BS3TRAPFRAME, 8)
447.more_zeroed_space:
448 push edx
449 push edx
450 dec eax
451 jz .more_zeroed_space
452 mov edi, esp
453
454 ;
455 ; Fill in the non-context trap frame bits.
456 ;
457 mov [edi + BS3TRAPFRAME.fHandlerRfl], ecx
458 mov word [edi + BS3TRAPFRAME.bXcpt], X86_XCPT_DF
459 mov [edi + BS3TRAPFRAME.uHandlerCs], cs
460 mov [edi + BS3TRAPFRAME.uHandlerSs], ss
461 lea ecx, [ebp + 3*4] ; two pushes, one error code.
462 mov [edi + BS3TRAPFRAME.uHandlerRsp], ecx
463 mov ecx, [ebp + 8]
464 mov [edi + BS3TRAPFRAME.uErrCd], ecx
465
466 ;
467 ; Copy the register state from the previous task segment.
468 ;
469
470 ; Find our TSS.
471 str ax
472 call bs3Trap32TssInAxToFlatInEax
473
474 ; Find the previous TSS.
475 mov ax, [eax + X86TSS32.selPrev]
476 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.tr], ax
477 call bs3Trap32TssInAxToFlatInEax
478
479 ; Do the copying.
480 mov ecx, [eax + X86TSS32.eax]
481 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rax], ecx
482 mov ecx, [eax + X86TSS32.ecx]
483 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rcx], ecx
484 mov ecx, [eax + X86TSS32.edx]
485 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rdx], ecx
486 mov ecx, [eax + X86TSS32.ebx]
487 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbx], ecx
488 mov ecx, [eax + X86TSS32.esp]
489 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsp], ecx
490 mov ecx, [eax + X86TSS32.ebp]
491 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rbp], ecx
492 mov [ebp], ecx ; For better call stacks.
493 mov ecx, [eax + X86TSS32.esi]
494 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsi], ecx
495 mov ecx, [eax + X86TSS32.edi]
496 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rdi], ecx
497 mov ecx, [eax + X86TSS32.esi]
498 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rsi], ecx
499 mov ecx, [eax + X86TSS32.eflags]
500 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rflags], ecx
501 mov ecx, [eax + X86TSS32.eip]
502 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.rip], ecx
503 mov [ebp + 4], ecx ; For better call stacks.
504 mov cx, [eax + X86TSS32.cs]
505 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.cs], cx
506 mov cx, [eax + X86TSS32.ds]
507 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ds], cx
508 mov cx, [eax + X86TSS32.es]
509 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.es], cx
510 mov cx, [eax + X86TSS32.fs]
511 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.fs], cx
512 mov cx, [eax + X86TSS32.gs]
513 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.gs], cx
514 mov cx, [eax + X86TSS32.ss]
515 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ss], cx
516 mov cx, [eax + X86TSS32.selLdt] ; Note! This isn't necessarily the ldtr at the time of the fault.
517 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ldtr], cx
518 mov cx, [eax + X86TSS32.cr3] ; Note! This isn't necessarily the cr3 at the time of the fault.
519 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.cr3], ecx
520
521 ;
522 ; Set CPL; copy and update mode.
523 ;
524 mov cl, [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.ss]
525 and cl, 3
526 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.bCpl], cl
527
528 mov cl, [BS3_DATA16_WRT(g_bBs3CurrentMode)]
529 mov [edi + BS3TRAPFRAME.Ctx + BS3REGCTX.bMode], cl
530 and cl, ~BS3_MODE_CODE_MASK
531 or cl, BS3_MODE_CODE_32
532 mov [BS3_DATA16_WRT(g_bBs3CurrentMode)], cl
533
534 ;
535 ; Join code paths with the generic handler code.
536 ;
537 jmp bs3Trap32GenericCommon.save_cr0_cr2_cr4
538BS3_PROC_END Bs3Trap32DoubleFaultHandler
539
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