VirtualBox

source: vbox/trunk/src/VBox/VMM/PATM/CSAMInternal.h@ 10024

Last change on this file since 10024 was 9344, checked in by vboxsync, 17 years ago

Types and string format specifiers.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 8.5 KB
Line 
1/* $Id: CSAMInternal.h 9344 2008-06-03 09:49:14Z vboxsync $ */
2/** @file
3 * CSAM - Internal header file.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22#ifndef ___CSAMInternal_h
23#define ___CSAMInternal_h
24
25#include <VBox/cdefs.h>
26#include <VBox/types.h>
27#include <VBox/csam.h>
28#include <VBox/dis.h>
29#include <VBox/log.h>
30
31#if !defined(IN_CSAM_R3) && !defined(IN_CSAM_R0) && !defined(IN_CSAM_GC)
32# error "Not in CSAM! This is an internal header!"
33#endif
34
35/** Page flags.
36 * These are placed in the three bits available for system programs in
37 * the page entries.
38 * @{ */
39#ifndef PGM_PTFLAGS_CSAM_VALIDATED
40/** Scanned and approved by CSAM (tm). */
41/** NOTE: Must be identical to the one defined in PGMInternal.h!! */
42#define PGM_PTFLAGS_CSAM_VALIDATED RT_BIT_64(11)
43#endif
44
45/** @} */
46
47#define CSAM_SSM_VERSION 14
48
49#define CSAM_PGDIRBMP_CHUNKS 1024
50
51#define CSAM_PAGE_BITMAP_SIZE (PAGE_SIZE/(sizeof(uint8_t)*8))
52
53/* Maximum nr of dirty page that are cached. */
54#define CSAM_MAX_DIRTY_PAGES 32
55
56/* Maximum number of cached addresses of dangerous instructions that have been scanned before. */
57#define CSAM_MAX_DANGR_INSTR 16 /* power of two! */
58#define CSAM_MAX_DANGR_INSTR_MASK (CSAM_MAX_DANGR_INSTR-1)
59
60/* Maximum number of possible dangerous code pages that we'll flush after a world switch */
61#define CSAM_MAX_CODE_PAGES_FLUSH 32
62
63#define CSAM_MAX_CALLEXIT_RET 16
64
65/* copy from PATMInternal.h */
66#define SIZEOF_NEARJUMP32 5 //opcode byte + 4 byte relative offset
67
68typedef struct
69{
70 RTRCPTR pInstrAfterRetGC[CSAM_MAX_CALLEXIT_RET];
71 uint32_t cInstrAfterRet;
72} CSAMCALLEXITREC, *PCSAMCALLEXITREC;
73
74typedef struct
75{
76 R3PTRTYPE(uint8_t *) pPageLocStartHC;
77 R3PTRTYPE(uint8_t *) pPageLocEndHC;
78 RCPTRTYPE(uint8_t *) pGuestLoc;
79 uint32_t depth; //call/jump depth
80
81 PCSAMCALLEXITREC pCallExitRec;
82} CSAMP2GLOOKUPREC, *PCSAMP2GLOOKUPREC;
83
84typedef struct
85{
86 RTRCPTR pPageGC;
87 RTGCPHYS GCPhys;
88 uint64_t fFlags;
89 uint32_t uSize;
90
91 uint8_t *pBitmap;
92
93 bool fCode32;
94 bool fMonitorActive;
95 bool fMonitorInvalidation;
96
97 CSAMTAG enmTag;
98
99 uint64_t u64Hash;
100} CSAMPAGE, *PCSAMPAGE;
101
102typedef struct
103{
104 // GC Patch pointer
105 RTRCPTR pInstrGC;
106
107 // Disassembly state for original instruction
108 DISCPUSTATE cpu;
109
110 uint32_t uState;
111
112 PCSAMPAGE pPage;
113} CSAMPATCH, *PCSAMPATCH;
114
115/**
116 * Lookup record for CSAM pages
117 */
118typedef struct CSAMPAGEREC
119{
120 /** The key is a GC virtual address. */
121 AVLPVNODECORE Core;
122 CSAMPAGE page;
123
124} CSAMPAGEREC, *PCSAMPAGEREC;
125
126/**
127 * Lookup record for patches
128 */
129typedef struct CSAMPATCHREC
130{
131 /** The key is a GC virtual address. */
132 AVLPVNODECORE Core;
133 CSAMPATCH patch;
134
135} CSAMPATCHREC, *PCSAMPATCHREC;
136
137
138/**
139 * CSAM VM Instance data.
140 * Changes to this must checked against the padding of the CSAM union in VM!
141 * @note change SSM version when changing it!!
142 */
143typedef struct CSAM
144{
145 /** Offset to the VM structure.
146 * See CSAM2VM(). */
147 RTINT offVM;
148#if HC_ARCH_BITS == 64
149 RTINT Alignment0; /**< Align pPageTree correctly. */
150#endif
151
152 R3PTRTYPE(PAVLPVNODECORE) pPageTree;
153
154 /* Array to store previously scanned dangerous instructions, so we don't need to
155 * switch back to ring 3 each time we encounter them in GC.
156 */
157 RTRCPTR aDangerousInstr[CSAM_MAX_DANGR_INSTR];
158 uint32_t cDangerousInstr;
159 uint32_t iDangerousInstr;
160
161 RCPTRTYPE(RTRCPTR *) pPDBitmapGC;
162 RCPTRTYPE(RTHCPTR *) pPDHCBitmapGC;
163 R3PTRTYPE(uint8_t **) pPDBitmapHC;
164 R3PTRTYPE(RTRCPTR *) pPDGCBitmapHC;
165
166 /* Temporary storage during load/save state */
167 struct
168 {
169 R3PTRTYPE(PSSMHANDLE) pSSM;
170 uint32_t cPageRecords;
171 uint32_t cPatchPageRecords;
172 } savedstate;
173
174 /* To keep track of dirty pages */
175 uint32_t cDirtyPages;
176 RTRCPTR pvDirtyBasePage[CSAM_MAX_DIRTY_PAGES];
177 RTRCPTR pvDirtyFaultPage[CSAM_MAX_DIRTY_PAGES];
178
179 /* To keep track of possible code pages */
180 uint32_t cPossibleCodePages;
181 RTRCPTR pvPossibleCodePage[CSAM_MAX_CODE_PAGES_FLUSH];
182
183 /* call addresses reported by the recompiler */
184 RTRCPTR pvCallInstruction[16];
185 RTUINT iCallInstruction;
186
187 /* Set when scanning has started. */
188 bool fScanningStarted;
189
190 /* Set when the IDT gates have been checked for the first time. */
191 bool fGatesChecked;
192 bool Alignment1[HC_ARCH_BITS == 32 ? 4 : 2]; /**< Align the stats on an 8-byte boundrary. */
193
194 STAMCOUNTER StatNrTraps;
195 STAMCOUNTER StatNrPages;
196 STAMCOUNTER StatNrPagesInv;
197 STAMCOUNTER StatNrRemovedPages;
198 STAMCOUNTER StatNrPatchPages;
199 STAMCOUNTER StatNrPageNPHC;
200 STAMCOUNTER StatNrPageNPGC;
201 STAMCOUNTER StatNrFlushes;
202 STAMCOUNTER StatNrFlushesSkipped;
203 STAMCOUNTER StatNrKnownPagesHC;
204 STAMCOUNTER StatNrKnownPagesGC;
205 STAMCOUNTER StatNrInstr;
206 STAMCOUNTER StatNrBytesRead;
207 STAMCOUNTER StatNrOpcodeRead;
208 STAMPROFILE StatTime;
209 STAMPROFILE StatTimeCheckAddr;
210 STAMPROFILE StatTimeAddrConv;
211 STAMPROFILE StatTimeFlushPage;
212 STAMPROFILE StatTimeDisasm;
213 STAMPROFILE StatFlushDirtyPages;
214 STAMPROFILE StatCheckGates;
215 STAMCOUNTER StatCodePageModified;
216 STAMCOUNTER StatDangerousWrite;
217
218 STAMCOUNTER StatInstrCacheHit;
219 STAMCOUNTER StatInstrCacheMiss;
220
221 STAMCOUNTER StatPagePATM;
222 STAMCOUNTER StatPageCSAM;
223 STAMCOUNTER StatPageREM;
224 STAMCOUNTER StatNrUserPages;
225 STAMCOUNTER StatPageMonitor;
226 STAMCOUNTER StatPageRemoveREMFlush;
227
228 STAMCOUNTER StatBitmapAlloc;
229
230 STAMCOUNTER StatScanNextFunction;
231 STAMCOUNTER StatScanNextFunctionFailed;
232} CSAM, *PCSAM;
233
234/**
235 * Call for analyzing the instructions following the privileged instr. for compliance with our heuristics
236 *
237 * @returns VBox status code.
238 * @param pVM The VM to operate on.
239 * @param pCpu CPU disassembly state
240 * @param pInstrHC Guest context pointer to privileged instruction
241 * @param pCurInstrGC Guest context pointer to current instruction
242 * @param pUserData User pointer
243 *
244 */
245typedef int (VBOXCALL *PFN_CSAMR3ANALYSE)(PVM pVM, DISCPUSTATE *pCpu, RCPTRTYPE(uint8_t *) pInstrGC, RCPTRTYPE(uint8_t *) pCurInstrGC, PCSAMP2GLOOKUPREC pCacheRec, void *pUserData);
246
247/**
248 * Calculate the branch destination
249 *
250 * @returns branch destination or 0 if failed
251 * @param pCpu Disassembly state of instruction.
252 * @param pBranchInstrGC GC pointer of branch instruction
253 */
254inline RTRCPTR CSAMResolveBranch(PDISCPUSTATE pCpu, RTRCPTR pBranchInstrGC)
255{
256 uint32_t disp;
257 if (pCpu->param1.flags & USE_IMMEDIATE8_REL)
258 {
259 disp = (int32_t)(char)pCpu->param1.parval;
260 }
261 else
262 if (pCpu->param1.flags & USE_IMMEDIATE16_REL)
263 {
264 disp = (int32_t)(uint16_t)pCpu->param1.parval;
265 }
266 else
267 if (pCpu->param1.flags & USE_IMMEDIATE32_REL)
268 {
269 disp = (int32_t)pCpu->param1.parval;
270 }
271 else
272 {
273 Log(("We don't support far jumps here!! (%08X)\n", pCpu->param1.flags));
274 return 0;
275 }
276#ifdef IN_GC
277 return (RTRCPTR)((uint8_t *)pBranchInstrGC + pCpu->opsize + disp);
278#else
279 return pBranchInstrGC + pCpu->opsize + disp;
280#endif
281}
282
283__BEGIN_DECLS
284CSAMGCDECL(int) CSAMGCCodePageWriteHandler(PVM pVM, RTGCUINT uErrorCode, PCPUMCTXCORE pRegFrame, RTGCPTR pvFault, RTGCPTR pvRange, uintptr_t offRange);
285__END_DECLS
286
287#endif
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