1 | ;$Id: HMInternal.mac 80078 2019-07-31 15:09:25Z vboxsync $
|
---|
2 | ;; @file
|
---|
3 | ; HM - Internal header file.
|
---|
4 | ;
|
---|
5 |
|
---|
6 | ;
|
---|
7 | ; Copyright (C) 2006-2019 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 |
|
---|
18 | ;Maximum number of cached entries.
|
---|
19 | %define VMX_VMCS_CACHE_MAX_ENTRY 128
|
---|
20 |
|
---|
21 | ; Structure for storing read and write VMCS actions.
|
---|
22 | struc VMXVMCSCACHE
|
---|
23 | %ifdef VBOX_WITH_CRASHDUMP_MAGIC
|
---|
24 | .aMagic resb 16
|
---|
25 | .uMagic resq 1
|
---|
26 | .u64TimeEntry resq 1
|
---|
27 | .u64TimeSwitch resq 1
|
---|
28 | .cResume resq 1
|
---|
29 | .interPD resq 1
|
---|
30 | .pSwitcher resq 1
|
---|
31 | .uPos resd 1
|
---|
32 | .idCpu resd 1
|
---|
33 | %endif
|
---|
34 | .cr2 resq 1
|
---|
35 | .Write.cValidEntries resd 1
|
---|
36 | .Write.uAlignment resd 1
|
---|
37 | .Write.aField resd VMX_VMCS_CACHE_MAX_ENTRY
|
---|
38 | .Write.aFieldVal resq VMX_VMCS_CACHE_MAX_ENTRY
|
---|
39 | .Read.cValidEntries resd 1
|
---|
40 | .Read.uAlignment resd 1
|
---|
41 | .Read.aField resd VMX_VMCS_CACHE_MAX_ENTRY
|
---|
42 | .Read.aFieldVal resq VMX_VMCS_CACHE_MAX_ENTRY
|
---|
43 | %ifdef VBOX_STRICT
|
---|
44 | .TestIn.HCPhysCpuPage resq 1
|
---|
45 | .TestIn.HCPhysVmcs resq 1
|
---|
46 | .TestIn.pCache resq 1
|
---|
47 | .TestIn.pCtx resq 1
|
---|
48 | .TestOut.HCPhysVmcs resq 1
|
---|
49 | .TestOut.pCache resq 1
|
---|
50 | .TestOut.pCtx resq 1
|
---|
51 | .TestOut.eflags resq 1
|
---|
52 | .TestOut.cr8 resq 1
|
---|
53 | .ScratchPad.param1 resq 1
|
---|
54 | .ScratchPad.param2 resq 1
|
---|
55 | .ScratchPad.param3 resq 1
|
---|
56 | .ScratchPad.param4 resq 1
|
---|
57 | %endif
|
---|
58 | endstruc
|
---|
59 |
|
---|
60 | struc HMCPU
|
---|
61 | .fCheckedTLBFlush resb 1
|
---|
62 | .fForceTLBFlush resb 1
|
---|
63 | .fActive resb 1
|
---|
64 | .fLeaveDone resb 1
|
---|
65 | .fUsingHyperDR7 resb 1
|
---|
66 | .fLoadSaveGuestXcr0 resb 1
|
---|
67 |
|
---|
68 | .fUseDebugLoop resb 1
|
---|
69 | .fUsingDebugLoop resb 1
|
---|
70 | .fDebugWantRdTscExit resb 1
|
---|
71 | .fSingleInstruction resb 1
|
---|
72 | .fClearTrapFlag resb 1
|
---|
73 |
|
---|
74 | .fGIMTrapXcptUD resb 1
|
---|
75 | .fTrapXcptGpForLovelyMesaDrv resb 1
|
---|
76 | alignb 8
|
---|
77 |
|
---|
78 | .cWorldSwitchExits resd 1
|
---|
79 | .idLastCpu resd 1
|
---|
80 | .cTlbFlushes resd 1
|
---|
81 | .uCurrentAsid resd 1
|
---|
82 | .u32HMError resd 1
|
---|
83 | alignb 8
|
---|
84 | .fCtxChanged resq 1
|
---|
85 |
|
---|
86 | ; incomplete to save unnecessary pain...
|
---|
87 | endstruc
|
---|
88 |
|
---|