VirtualBox

source: vbox/trunk/src/VBox/VMM/testcase/tstVMStructGC.cpp@ 1831

Last change on this file since 1831 was 1480, checked in by vboxsync, 18 years ago

No longer require contiguous memory for the VM structure.
Did long overdue IOCtl cleanup wrt R3/R0 pointers.

  • Property svn:keywords set to Id
File size: 32.0 KB
Line 
1/* $Id: tstVMStructGC.cpp 1480 2007-03-14 18:27:47Z vboxsync $ */
2/** @file
3 * tstVMMStructGC - Generate structure member and size checks from the GC perspective.
4 *
5 * This is built using the VBOXGC template but linked into a host
6 * ring-3 executable, rather hacky.
7 */
8
9/*
10 * Copyright (C) 2006 InnoTek Systemberatung GmbH
11 *
12 * This file is part of VirtualBox Open Source Edition (OSE), as
13 * available from http://www.virtualbox.org. This file is free software;
14 * you can redistribute it and/or modify it under the terms of the GNU
15 * General Public License as published by the Free Software Foundation,
16 * in version 2 as it comes in the "COPYING" file of the VirtualBox OSE
17 * distribution. VirtualBox OSE is distributed in the hope that it will
18 * be useful, but WITHOUT ANY WARRANTY of any kind.
19 *
20 * If you received this file as part of a commercial VirtualBox
21 * distribution, then only the terms of your commercial VirtualBox
22 * license agreement apply instead of the previous paragraph.
23 */
24
25
26/*
27 * Sanity checks.
28 */
29#ifndef IN_GC
30# error Incorrect template!
31#endif
32#if defined(IN_RING3) || defined(IN_RING0)
33# error Incorrect template!
34#endif
35
36
37/*******************************************************************************
38* Header Files *
39*******************************************************************************/
40#include <VBox/cfgm.h>
41#include <VBox/cpum.h>
42#include <VBox/mm.h>
43#include <VBox/pgm.h>
44#include <VBox/selm.h>
45#include <VBox/trpm.h>
46#include <VBox/vmm.h>
47#include <VBox/stam.h>
48#include "PDMInternal.h"
49#include <VBox/pdm.h>
50#include "CFGMInternal.h"
51#include "CPUMInternal.h"
52#include "MMInternal.h"
53#include "PGMInternal.h"
54#include "SELMInternal.h"
55#include "TRPMInternal.h"
56#include "TMInternal.h"
57#include "IOMInternal.h"
58#include "REMInternal.h"
59#include "HWACCMInternal.h"
60#include "PATMInternal.h"
61#include "VMMInternal.h"
62#include "DBGFInternal.h"
63#include "STAMInternal.h"
64#include "CSAMInternal.h"
65#include "EMInternal.h"
66#include "REMInternal.h"
67#include <VBox/vm.h>
68#include <VBox/param.h>
69#include <VBox/x86.h>
70
71/* we don't use iprt here because we're pretending to be in GC! */
72#include <stdio.h>
73
74#define GEN_CHECK_SIZE(s) printf(" CHECK_SIZE(%s, %u);\n", #s, (unsigned)sizeof(s))
75#define GEN_CHECK_OFF(s, m) printf(" CHECK_OFF(%s, %u, %s);\n", #s, (unsigned)RT_OFFSETOF(s, m), #m)
76
77int main()
78{
79 GEN_CHECK_SIZE(CFGM);
80
81 GEN_CHECK_SIZE(CPUM); // has .mac
82 GEN_CHECK_SIZE(CPUMHOSTCTX);
83 GEN_CHECK_SIZE(CPUMCTX);
84 GEN_CHECK_SIZE(CPUMCTXCORE);
85 GEN_CHECK_SIZE(STAMRATIOU32);
86 GEN_CHECK_SIZE(AVLOHCPHYSNODECORE);
87 GEN_CHECK_SIZE(AVLOGCPHYSNODECORE);
88 GEN_CHECK_SIZE(AVLROGCPHYSNODECORE);
89 GEN_CHECK_SIZE(AVLOGCPTRNODECORE);
90 GEN_CHECK_SIZE(AVLROGCPTRNODECORE);
91 GEN_CHECK_SIZE(AVLOIOPORTNODECORE);
92 GEN_CHECK_SIZE(AVLROIOPORTNODECORE);
93
94 GEN_CHECK_SIZE(DBGF);
95 GEN_CHECK_OFF(DBGF, offVM);
96 GEN_CHECK_OFF(DBGF, fAttached);
97 GEN_CHECK_OFF(DBGF, fStoppedInHyper);
98 GEN_CHECK_OFF(DBGF, PingPong);
99 GEN_CHECK_OFF(DBGF, DbgEvent);
100 GEN_CHECK_OFF(DBGF, enmVMMCmd);
101 GEN_CHECK_OFF(DBGF, VMMCmdData);
102 GEN_CHECK_OFF(DBGF, pInfoFirst);
103 GEN_CHECK_OFF(DBGF, InfoCritSect);
104 GEN_CHECK_OFF(DBGF, SymbolTree);
105 GEN_CHECK_OFF(DBGF, pSymbolSpace);
106 GEN_CHECK_OFF(DBGF, fSymInited);
107 GEN_CHECK_OFF(DBGF, cHwBreakpoints);
108 GEN_CHECK_OFF(DBGF, cBreakpoints);
109 GEN_CHECK_OFF(DBGF, aHwBreakpoints);
110 GEN_CHECK_OFF(DBGF, aBreakpoints);
111 GEN_CHECK_OFF(DBGF, iActiveBp);
112 GEN_CHECK_OFF(DBGF, fSingleSteppingRaw);
113 GEN_CHECK_SIZE(DBGFEVENT);
114
115 GEN_CHECK_SIZE(EM);
116 GEN_CHECK_OFF(EM, offVM);
117 GEN_CHECK_OFF(EM, pCtx);
118 GEN_CHECK_OFF(EM, enmState);
119 GEN_CHECK_OFF(EM, fForceRAW);
120 GEN_CHECK_OFF(EM, u.achPaddingFatalLongJump);
121 GEN_CHECK_OFF(EM, StatForcedActions);
122 GEN_CHECK_OFF(EM, StatTotalClis);
123 GEN_CHECK_OFF(EM, pStatsHC);
124 GEN_CHECK_OFF(EM, pStatsGC);
125 GEN_CHECK_OFF(EM, pCliStatTree);
126
127 GEN_CHECK_SIZE(IOM);
128
129 GEN_CHECK_SIZE(MM);
130 GEN_CHECK_OFF(MM, offVM);
131 GEN_CHECK_OFF(MM, offHyperNextStatic);
132 GEN_CHECK_OFF(MM, cbHyperArea);
133 GEN_CHECK_OFF(MM, fPGMInitialized);
134 GEN_CHECK_OFF(MM, offLookupHyper);
135 GEN_CHECK_OFF(MM, pHyperHeapHC);
136 GEN_CHECK_OFF(MM, pHyperHeapGC);
137 GEN_CHECK_OFF(MM, pLockedMem);
138 GEN_CHECK_OFF(MM, pPagePool);
139 GEN_CHECK_OFF(MM, pPagePoolLow);
140 GEN_CHECK_OFF(MM, pvDummyPage);
141 GEN_CHECK_OFF(MM, HCPhysDummyPage);
142 GEN_CHECK_OFF(MM, cbRAMSize);
143 GEN_CHECK_OFF(MM, pvRamBaseHC);
144 GEN_CHECK_OFF(MM, cbRamBase);
145 GEN_CHECK_OFF(MM, pHeap);
146 GEN_CHECK_SIZE(MMHYPERSTAT);
147 GEN_CHECK_SIZE(MMHYPERCHUNK);
148 GEN_CHECK_SIZE(MMHYPERCHUNKFREE);
149 GEN_CHECK_SIZE(MMHYPERHEAP);
150 GEN_CHECK_OFF(MMHYPERHEAP, u32Magic);
151 GEN_CHECK_OFF(MMHYPERHEAP, cbHeap);
152 GEN_CHECK_OFF(MMHYPERHEAP, pbHeapHC);
153 GEN_CHECK_OFF(MMHYPERHEAP, pbHeapGC);
154 GEN_CHECK_OFF(MMHYPERHEAP, pVMHC);
155 GEN_CHECK_OFF(MMHYPERHEAP, pVMGC);
156 GEN_CHECK_OFF(MMHYPERHEAP, cbFree);
157 GEN_CHECK_OFF(MMHYPERHEAP, offFreeHead);
158 GEN_CHECK_OFF(MMHYPERHEAP, offFreeTail);
159 GEN_CHECK_OFF(MMHYPERHEAP, offPageAligned);
160 GEN_CHECK_OFF(MMHYPERHEAP, HyperHeapStatTree);
161 GEN_CHECK_SIZE(MMLOOKUPHYPER);
162 GEN_CHECK_OFF(MMLOOKUPHYPER, offNext);
163 GEN_CHECK_OFF(MMLOOKUPHYPER, off);
164 GEN_CHECK_OFF(MMLOOKUPHYPER, cb);
165 GEN_CHECK_OFF(MMLOOKUPHYPER, enmType);
166 GEN_CHECK_OFF(MMLOOKUPHYPER, u.Locked.pvHC);
167 GEN_CHECK_OFF(MMLOOKUPHYPER, u.Locked.pvR0);
168 GEN_CHECK_OFF(MMLOOKUPHYPER, u.Locked.pLockedMem);
169 GEN_CHECK_OFF(MMLOOKUPHYPER, u.HCPhys.pvHC);
170 GEN_CHECK_OFF(MMLOOKUPHYPER, u.HCPhys.HCPhys);
171 GEN_CHECK_OFF(MMLOOKUPHYPER, u.GCPhys.GCPhys);
172 GEN_CHECK_OFF(MMLOOKUPHYPER, pszDesc);
173
174 GEN_CHECK_SIZE(PDM);
175 GEN_CHECK_OFF(PDM, offVM);
176 GEN_CHECK_OFF(PDM, pModules);
177 GEN_CHECK_OFF(PDM, pDevs);
178 GEN_CHECK_OFF(PDM, pDevInstances);
179 GEN_CHECK_OFF(PDM, pDrvs);
180 GEN_CHECK_OFF(PDM, pCritSects);
181 GEN_CHECK_OFF(PDM, aPciBuses);
182 GEN_CHECK_OFF(PDM, aPciBuses[0].iBus);
183 GEN_CHECK_OFF(PDM, aPciBuses[0].pDevInsR3);
184 GEN_CHECK_OFF(PDM, aPciBuses[0].pfnSetIrqR3);
185 GEN_CHECK_OFF(PDM, aPciBuses[0].pfnRegisterR3);
186 GEN_CHECK_OFF(PDM, aPciBuses[0].pfnIORegionRegisterR3);
187 GEN_CHECK_OFF(PDM, aPciBuses[0].pfnSaveExecR3);
188 GEN_CHECK_OFF(PDM, aPciBuses[0].pfnLoadExecR3);
189 GEN_CHECK_OFF(PDM, aPciBuses[0].pfnFakePCIBIOSR3);
190 GEN_CHECK_OFF(PDM, aPciBuses[0].pDevInsR0);
191 GEN_CHECK_OFF(PDM, aPciBuses[0].pfnSetIrqR0);
192 GEN_CHECK_OFF(PDM, aPciBuses[0].pDevInsGC);
193 GEN_CHECK_OFF(PDM, aPciBuses[0].pfnSetIrqGC);
194 GEN_CHECK_OFF(PDM, Pic);
195 GEN_CHECK_OFF(PDM, Pic.pDevInsR3);
196 GEN_CHECK_OFF(PDM, Pic.pfnSetIrqR3);
197 GEN_CHECK_OFF(PDM, Pic.pfnGetInterruptR3);
198 GEN_CHECK_OFF(PDM, Pic.pDevInsR0);
199 GEN_CHECK_OFF(PDM, Pic.pfnSetIrqR0);
200 GEN_CHECK_OFF(PDM, Pic.pfnGetInterruptR0);
201 GEN_CHECK_OFF(PDM, Pic.pDevInsGC);
202 GEN_CHECK_OFF(PDM, Pic.pfnSetIrqGC);
203 GEN_CHECK_OFF(PDM, Pic.pfnGetInterruptGC);
204 GEN_CHECK_OFF(PDM, Apic);
205 GEN_CHECK_OFF(PDM, Apic.pDevInsR3);
206 GEN_CHECK_OFF(PDM, Apic.pfnGetInterruptR3);
207 GEN_CHECK_OFF(PDM, Apic.pfnSetBaseR3);
208 GEN_CHECK_OFF(PDM, Apic.pfnGetBaseR3);
209 GEN_CHECK_OFF(PDM, Apic.pfnSetTPRR3);
210 GEN_CHECK_OFF(PDM, Apic.pfnGetTPRR3);
211 GEN_CHECK_OFF(PDM, Apic.pfnBusDeliverR3);
212 GEN_CHECK_OFF(PDM, Apic.pDevInsR0);
213 GEN_CHECK_OFF(PDM, Apic.pfnGetInterruptR0);
214 GEN_CHECK_OFF(PDM, Apic.pfnSetBaseR0);
215 GEN_CHECK_OFF(PDM, Apic.pfnGetBaseR0);
216 GEN_CHECK_OFF(PDM, Apic.pfnSetTPRR0);
217 GEN_CHECK_OFF(PDM, Apic.pfnGetTPRR0);
218 GEN_CHECK_OFF(PDM, Apic.pfnBusDeliverR0);
219 GEN_CHECK_OFF(PDM, Apic.pDevInsGC);
220 GEN_CHECK_OFF(PDM, Apic.pfnGetInterruptGC);
221 GEN_CHECK_OFF(PDM, Apic.pfnSetBaseGC);
222 GEN_CHECK_OFF(PDM, Apic.pfnGetBaseGC);
223 GEN_CHECK_OFF(PDM, Apic.pfnSetTPRGC);
224 GEN_CHECK_OFF(PDM, Apic.pfnGetTPRGC);
225 GEN_CHECK_OFF(PDM, Apic.pfnBusDeliverGC);
226 GEN_CHECK_OFF(PDM, IoApic);
227 GEN_CHECK_OFF(PDM, IoApic.pDevInsR3);
228 GEN_CHECK_OFF(PDM, IoApic.pfnSetIrqR3);
229 GEN_CHECK_OFF(PDM, IoApic.pDevInsR0);
230 GEN_CHECK_OFF(PDM, IoApic.pfnSetIrqR0);
231 GEN_CHECK_OFF(PDM, IoApic.pDevInsGC);
232 GEN_CHECK_OFF(PDM, IoApic.pfnSetIrqGC);
233 GEN_CHECK_OFF(PDM, pDmac);
234 GEN_CHECK_OFF(PDM, pRtc);
235 GEN_CHECK_OFF(PDM, pDevHlpQueueGC);
236 GEN_CHECK_OFF(PDM, pDevHlpQueueHC);
237 GEN_CHECK_OFF(PDM, cQueuedCritSectLeaves);
238 GEN_CHECK_OFF(PDM, apQueuedCritSectsLeaves);
239 GEN_CHECK_OFF(PDM, pQueuesTimer);
240 GEN_CHECK_OFF(PDM, pQueuesForced);
241 GEN_CHECK_OFF(PDM, pQueueFlushGC);
242 GEN_CHECK_OFF(PDM, pQueueFlushHC);
243 GEN_CHECK_OFF(PDM, cPollers);
244 GEN_CHECK_OFF(PDM, apfnPollers);
245 GEN_CHECK_OFF(PDM, aDrvInsPollers);
246 GEN_CHECK_OFF(PDM, pTimerPollers);
247#ifdef VBOX_WITH_PDM_LOCK
248 GEN_CHECK_OFF(PDM, CritSect);
249#endif
250 GEN_CHECK_OFF(PDM, StatQueuedCritSectLeaves);
251 GEN_CHECK_SIZE(PDMDEVINSINT);
252 GEN_CHECK_OFF(PDMDEVINSINT, pNextHC);
253 GEN_CHECK_OFF(PDMDEVINSINT, pPerDeviceNextHC);
254 GEN_CHECK_OFF(PDMDEVINSINT, pDevHC);
255 GEN_CHECK_OFF(PDMDEVINSINT, pVMHC);
256 GEN_CHECK_OFF(PDMDEVINSINT, pVMGC);
257 GEN_CHECK_OFF(PDMDEVINSINT, pLunsHC);
258 GEN_CHECK_OFF(PDMDEVINSINT, pCfgHandle);
259 GEN_CHECK_OFF(PDMDEVINSINT, pPciDeviceHC);
260 GEN_CHECK_OFF(PDMDEVINSINT, pPciDeviceGC);
261 GEN_CHECK_OFF(PDMDEVINSINT, pPciBusHC);
262 GEN_CHECK_OFF(PDMDEVINSINT, pPciBusGC);
263 GEN_CHECK_SIZE(PDMCRITSECTINT);
264 GEN_CHECK_OFF(PDMCRITSECTINT, Core);
265 GEN_CHECK_OFF(PDMCRITSECTINT, pNext);
266 GEN_CHECK_OFF(PDMCRITSECTINT, pvKey);
267 GEN_CHECK_OFF(PDMCRITSECTINT, pVMR3);
268 GEN_CHECK_OFF(PDMCRITSECTINT, pVMR0);
269 GEN_CHECK_OFF(PDMCRITSECTINT, pVMGC);
270 GEN_CHECK_OFF(PDMCRITSECTINT, StatContentionR0GCLock);
271 GEN_CHECK_OFF(PDMCRITSECTINT, StatContentionR0GCUnlock);
272 GEN_CHECK_OFF(PDMCRITSECTINT, StatContentionR3);
273 GEN_CHECK_OFF(PDMCRITSECTINT, StatLocked);
274 GEN_CHECK_SIZE(PDMQUEUE);
275 GEN_CHECK_OFF(PDMQUEUE, pNext);
276 GEN_CHECK_OFF(PDMQUEUE, enmType);
277 GEN_CHECK_OFF(PDMQUEUE, u);
278 GEN_CHECK_OFF(PDMQUEUE, u.Dev.pfnCallback);
279 GEN_CHECK_OFF(PDMQUEUE, u.Dev.pDevIns);
280 GEN_CHECK_OFF(PDMQUEUE, u.Drv.pfnCallback);
281 GEN_CHECK_OFF(PDMQUEUE, u.Drv.pDrvIns);
282 GEN_CHECK_OFF(PDMQUEUE, u.Int.pfnCallback);
283 GEN_CHECK_OFF(PDMQUEUE, u.Ext.pfnCallback);
284 GEN_CHECK_OFF(PDMQUEUE, u.Ext.pvUser);
285 GEN_CHECK_OFF(PDMQUEUE, pVMHC);
286 GEN_CHECK_OFF(PDMQUEUE, pVMGC);
287 GEN_CHECK_OFF(PDMQUEUE, cMilliesInterval);
288 GEN_CHECK_OFF(PDMQUEUE, pTimer);
289 GEN_CHECK_OFF(PDMQUEUE, cbItem);
290 GEN_CHECK_OFF(PDMQUEUE, cItems);
291 GEN_CHECK_OFF(PDMQUEUE, pPendingHC);
292 GEN_CHECK_OFF(PDMQUEUE, pPendingGC);
293 GEN_CHECK_OFF(PDMQUEUE, iFreeHead);
294 GEN_CHECK_OFF(PDMQUEUE, iFreeTail);
295 GEN_CHECK_OFF(PDMQUEUE, aFreeItems);
296 GEN_CHECK_OFF(PDMQUEUE, aFreeItems[1]);
297 GEN_CHECK_OFF(PDMQUEUE, aFreeItems[0].pItemGC);
298 GEN_CHECK_OFF(PDMQUEUE, aFreeItems[1].pItemHC);
299 GEN_CHECK_SIZE(PDMDEVHLPTASK);
300 GEN_CHECK_OFF(PDMDEVHLPTASK, Core);
301 GEN_CHECK_OFF(PDMDEVHLPTASK, pDevInsHC);
302 GEN_CHECK_OFF(PDMDEVHLPTASK, enmOp);
303 GEN_CHECK_OFF(PDMDEVHLPTASK, u);
304 GEN_CHECK_OFF(PDMDEVHLPTASK, u.SetIRQ.iIrq);
305 GEN_CHECK_OFF(PDMDEVHLPTASK, u.SetIRQ.iLevel);
306
307 GEN_CHECK_SIZE(PGM);
308 GEN_CHECK_OFF(PGM, offVM);
309 GEN_CHECK_OFF(PGM, paDynPageMap32BitPTEsGC);
310 GEN_CHECK_OFF(PGM, paDynPageMapPaePTEsGC);
311 GEN_CHECK_OFF(PGM, enmHostMode);
312 GEN_CHECK_OFF(PGM, enmShadowMode);
313 GEN_CHECK_OFF(PGM, enmGuestMode);
314 GEN_CHECK_OFF(PGM, GCPhysCR3);
315 GEN_CHECK_OFF(PGM, GCPtrCR3Mapping);
316 GEN_CHECK_OFF(PGM, GCPhysGstCR3Monitored);
317 GEN_CHECK_OFF(PGM, pGuestPDHC);
318 GEN_CHECK_OFF(PGM, pGuestPDGC);
319 GEN_CHECK_OFF(PGM, pGstPaePDPTRHC);
320 GEN_CHECK_OFF(PGM, pGstPaePDPTRGC);
321 GEN_CHECK_OFF(PGM, apGstPaePDsHC);
322 GEN_CHECK_OFF(PGM, apGstPaePDsGC);
323 GEN_CHECK_OFF(PGM, aGCPhysGstPaePDs);
324 GEN_CHECK_OFF(PGM, aGCPhysGstPaePDsMonitored);
325 GEN_CHECK_OFF(PGM, pHC32BitPD);
326 GEN_CHECK_OFF(PGM, pGC32BitPD);
327 GEN_CHECK_OFF(PGM, HCPhys32BitPD);
328 GEN_CHECK_OFF(PGM, apHCPaePDs);
329 GEN_CHECK_OFF(PGM, apGCPaePDs);
330 GEN_CHECK_OFF(PGM, aHCPhysPaePDs);
331 GEN_CHECK_OFF(PGM, pHCPaePDPTR);
332 GEN_CHECK_OFF(PGM, pGCPaePDPTR);
333 GEN_CHECK_OFF(PGM, HCPhysPaePDPTR);
334 GEN_CHECK_OFF(PGM, pHCPaePML4);
335 GEN_CHECK_OFF(PGM, pGCPaePML4);
336 GEN_CHECK_OFF(PGM, HCPhysPaePML4);
337 GEN_CHECK_OFF(PGM, pfnR3ShwRelocate);
338 GEN_CHECK_OFF(PGM, pfnR3ShwExit);
339 GEN_CHECK_OFF(PGM, pfnR3ShwGetPage);
340 GEN_CHECK_OFF(PGM, pfnR3ShwModifyPage);
341 GEN_CHECK_OFF(PGM, pfnR3ShwGetPDEByIndex);
342 GEN_CHECK_OFF(PGM, pfnR3ShwSetPDEByIndex);
343 GEN_CHECK_OFF(PGM, pfnR3ShwModifyPDEByIndex);
344 GEN_CHECK_OFF(PGM, pfnGCShwGetPage);
345 GEN_CHECK_OFF(PGM, pfnGCShwModifyPage);
346 GEN_CHECK_OFF(PGM, pfnGCShwGetPDEByIndex);
347 GEN_CHECK_OFF(PGM, pfnGCShwSetPDEByIndex);
348 GEN_CHECK_OFF(PGM, pfnGCShwModifyPDEByIndex);
349 GEN_CHECK_OFF(PGM, pfnR3GstRelocate);
350 GEN_CHECK_OFF(PGM, pfnR3GstExit);
351 GEN_CHECK_OFF(PGM, pfnR3GstMonitorCR3);
352 GEN_CHECK_OFF(PGM, pfnR3GstUnmonitorCR3);
353 GEN_CHECK_OFF(PGM, pfnR3GstMapCR3);
354 GEN_CHECK_OFF(PGM, pfnR3GstUnmapCR3);
355 GEN_CHECK_OFF(PGM, pfnR3GstGetPage);
356 GEN_CHECK_OFF(PGM, pfnR3GstModifyPage);
357 GEN_CHECK_OFF(PGM, pfnR3GstGetPDE);
358 GEN_CHECK_OFF(PGM, pfnGCGstGetPage);
359 GEN_CHECK_OFF(PGM, pfnGCGstModifyPage);
360 GEN_CHECK_OFF(PGM, pfnGCGstGetPDE);
361 GEN_CHECK_OFF(PGM, pfnR3BthRelocate);
362 GEN_CHECK_OFF(PGM, pfnR3BthSyncCR3);
363 GEN_CHECK_OFF(PGM, pfnR3BthTrap0eHandler);
364 GEN_CHECK_OFF(PGM, pfnR3BthInvalidatePage);
365 GEN_CHECK_OFF(PGM, pfnR3BthSyncPage);
366 GEN_CHECK_OFF(PGM, pfnR3BthPrefetchPage);
367 GEN_CHECK_OFF(PGM, pfnR3BthVerifyAccessSyncPage);
368 GEN_CHECK_OFF(PGM, pfnR3BthAssertCR3);
369 GEN_CHECK_OFF(PGM, pfnGCBthTrap0eHandler);
370 GEN_CHECK_OFF(PGM, pfnGCBthInvalidatePage);
371 GEN_CHECK_OFF(PGM, pfnGCBthSyncPage);
372 GEN_CHECK_OFF(PGM, pfnGCBthPrefetchPage);
373 GEN_CHECK_OFF(PGM, pfnGCBthVerifyAccessSyncPage);
374 GEN_CHECK_OFF(PGM, pfnGCBthAssertCR3);
375 GEN_CHECK_OFF(PGM, pRamRangesHC);
376 GEN_CHECK_OFF(PGM, pRamRangesGC);
377 GEN_CHECK_OFF(PGM, cbRamSize);
378 GEN_CHECK_OFF(PGM, pTreesHC);
379 GEN_CHECK_OFF(PGM, pTreesGC);
380 GEN_CHECK_OFF(PGM, pMappingsHC);
381 GEN_CHECK_OFF(PGM, pMappingsGC);
382 GEN_CHECK_OFF(PGM, fMappingsFixed);
383 GEN_CHECK_OFF(PGM, GCPtrMappingFixed);
384 GEN_CHECK_OFF(PGM, cbMappingFixed);
385 GEN_CHECK_OFF(PGM, pInterPD);
386 GEN_CHECK_OFF(PGM, apInterPTs);
387 GEN_CHECK_OFF(PGM, apInterPaePTs);
388 GEN_CHECK_OFF(PGM, apInterPaePDs);
389 GEN_CHECK_OFF(PGM, pInterPaePDPTR);
390 GEN_CHECK_OFF(PGM, pInterPaePDPTR64);
391 GEN_CHECK_OFF(PGM, pInterPaePML4);
392 GEN_CHECK_OFF(PGM, HCPhysInterPD);
393 GEN_CHECK_OFF(PGM, HCPhysInterPaePDPTR);
394 GEN_CHECK_OFF(PGM, HCPhysInterPaePML4);
395 GEN_CHECK_OFF(PGM, pbDynPageMapBaseGC);
396 GEN_CHECK_OFF(PGM, iDynPageMapLast);
397 GEN_CHECK_OFF(PGM, aHCPhysDynPageMapCache);
398 GEN_CHECK_OFF(PGM, GCPhysA20Mask);
399 GEN_CHECK_OFF(PGM, fA20Enabled);
400 GEN_CHECK_OFF(PGM, fSyncFlags);
401 GEN_CHECK_OFF(PGM, CritSect);
402#ifdef PGM_PD_CACHING_ENABLED
403 GEN_CHECK_OFF(PGM, pdcache);
404#endif
405 GEN_CHECK_OFF(PGM, pgmphysreadcache);
406 GEN_CHECK_OFF(PGM, pgmphyswritecache);
407 GEN_CHECK_SIZE(PGMMAPPING);
408 GEN_CHECK_OFF(PGMMAPPING, pNextHC);
409 GEN_CHECK_OFF(PGMMAPPING, pNextGC);
410 GEN_CHECK_OFF(PGMMAPPING, GCPtr);
411 GEN_CHECK_OFF(PGMMAPPING, GCPtrLast);
412 GEN_CHECK_OFF(PGMMAPPING, cb);
413 GEN_CHECK_OFF(PGMMAPPING, pfnRelocate);
414 GEN_CHECK_OFF(PGMMAPPING, pvUser);
415 GEN_CHECK_OFF(PGMMAPPING, pszDesc);
416 GEN_CHECK_OFF(PGMMAPPING, cPTs);
417 GEN_CHECK_OFF(PGMMAPPING, aPTs[1].HCPhysPT);
418 GEN_CHECK_OFF(PGMMAPPING, aPTs[1].pPTHC);
419 GEN_CHECK_OFF(PGMMAPPING, aPTs[1].pPTGC);
420 GEN_CHECK_OFF(PGMMAPPING, aPTs[1].HCPhysPaePT0);
421 GEN_CHECK_OFF(PGMMAPPING, aPTs[1].HCPhysPaePT1);
422 GEN_CHECK_OFF(PGMMAPPING, aPTs[1].paPaePTsHC);
423 GEN_CHECK_OFF(PGMMAPPING, aPTs[1].paPaePTsGC);
424 GEN_CHECK_SIZE(PGMPHYSHANDLER);
425 GEN_CHECK_OFF(PGMPHYSHANDLER, Core);
426 GEN_CHECK_OFF(PGMPHYSHANDLER, enmType);
427 GEN_CHECK_OFF(PGMPHYSHANDLER, cPages);
428 GEN_CHECK_OFF(PGMPHYSHANDLER, pfnHandlerR3);
429 GEN_CHECK_OFF(PGMPHYSHANDLER, pvUserR3);
430 GEN_CHECK_OFF(PGMPHYSHANDLER, pfnHandlerR0);
431 GEN_CHECK_OFF(PGMPHYSHANDLER, pvUserR0);
432 GEN_CHECK_OFF(PGMPHYSHANDLER, pfnHandlerGC);
433 GEN_CHECK_OFF(PGMPHYSHANDLER, pvUserGC);
434 GEN_CHECK_OFF(PGMPHYSHANDLER, pszDesc);
435 GEN_CHECK_SIZE(PGMPHYS2VIRTHANDLER);
436 GEN_CHECK_OFF(PGMPHYS2VIRTHANDLER, Core);
437 GEN_CHECK_OFF(PGMPHYS2VIRTHANDLER, offVirtHandler);
438 GEN_CHECK_SIZE(PGMVIRTHANDLER);
439 GEN_CHECK_OFF(PGMVIRTHANDLER, Core);
440 GEN_CHECK_OFF(PGMVIRTHANDLER, enmType);
441 GEN_CHECK_OFF(PGMVIRTHANDLER, GCPtr);
442 GEN_CHECK_OFF(PGMVIRTHANDLER, GCPtrLast);
443 GEN_CHECK_OFF(PGMVIRTHANDLER, cb);
444 GEN_CHECK_OFF(PGMVIRTHANDLER, pfnHandlerHC);
445 GEN_CHECK_OFF(PGMVIRTHANDLER, pfnHandlerGC);
446 GEN_CHECK_OFF(PGMVIRTHANDLER, pszDesc);
447 GEN_CHECK_OFF(PGMVIRTHANDLER, cPages);
448 GEN_CHECK_OFF(PGMVIRTHANDLER, aPhysToVirt);
449 GEN_CHECK_SIZE(PGMRAMRANGE);
450 GEN_CHECK_OFF(PGMRAMRANGE, pNextHC);
451 GEN_CHECK_OFF(PGMRAMRANGE, pNextGC);
452 GEN_CHECK_OFF(PGMRAMRANGE, GCPhys);
453 GEN_CHECK_OFF(PGMRAMRANGE, GCPhysLast);
454 GEN_CHECK_OFF(PGMRAMRANGE, cb);
455 GEN_CHECK_OFF(PGMRAMRANGE, pvHC);
456 GEN_CHECK_OFF(PGMRAMRANGE, aHCPhys);
457 GEN_CHECK_SIZE(PGMTREES);
458 GEN_CHECK_OFF(PGMTREES, PhysHandlers);
459 GEN_CHECK_OFF(PGMTREES, VirtHandlers);
460 GEN_CHECK_OFF(PGMTREES, PhysToVirtHandlers);
461 GEN_CHECK_OFF(PGMTREES, auPadding);
462 GEN_CHECK_SIZE(PGMPOOLPAGE);
463 GEN_CHECK_OFF(PGMPOOLPAGE, Core);
464 GEN_CHECK_OFF(PGMPOOLPAGE, GCPhys);
465 GEN_CHECK_OFF(PGMPOOLPAGE, pvPageHC);
466 GEN_CHECK_OFF(PGMPOOLPAGE, enmKind);
467 GEN_CHECK_OFF(PGMPOOLPAGE, bPadding);
468 GEN_CHECK_OFF(PGMPOOLPAGE, idx);
469 GEN_CHECK_OFF(PGMPOOLPAGE, iNext);
470#ifdef PGMPOOL_WITH_USER_TRACKING
471 GEN_CHECK_OFF(PGMPOOLPAGE, iUserHead);
472 GEN_CHECK_OFF(PGMPOOLPAGE, cPresent);
473 GEN_CHECK_OFF(PGMPOOLPAGE, iFirstPresent);
474#endif
475#ifdef PGMPOOL_WITH_MONITORING
476 GEN_CHECK_OFF(PGMPOOLPAGE, cModifications);
477 GEN_CHECK_OFF(PGMPOOLPAGE, iModifiedNext);
478 GEN_CHECK_OFF(PGMPOOLPAGE, iModifiedPrev);
479 GEN_CHECK_OFF(PGMPOOLPAGE, iMonitoredNext);
480 GEN_CHECK_OFF(PGMPOOLPAGE, iMonitoredPrev);
481#endif
482#ifdef PGMPOOL_WITH_CACHE
483 GEN_CHECK_OFF(PGMPOOLPAGE, iAgeNext);
484 GEN_CHECK_OFF(PGMPOOLPAGE, iAgePrev);
485#endif
486 GEN_CHECK_OFF(PGMPOOLPAGE, fZeroed);
487 GEN_CHECK_OFF(PGMPOOLPAGE, fSeenNonGlobal);
488 GEN_CHECK_OFF(PGMPOOLPAGE, fMonitored);
489 GEN_CHECK_OFF(PGMPOOLPAGE, fCached);
490 GEN_CHECK_OFF(PGMPOOLPAGE, fReusedFlushPending);
491 GEN_CHECK_OFF(PGMPOOLPAGE, fCR3Mix);
492 GEN_CHECK_SIZE(PGMPOOL);
493 GEN_CHECK_OFF(PGMPOOL, pVMHC);
494 GEN_CHECK_OFF(PGMPOOL, pVMGC);
495 GEN_CHECK_OFF(PGMPOOL, cMaxPages);
496 GEN_CHECK_OFF(PGMPOOL, cCurPages);
497 GEN_CHECK_OFF(PGMPOOL, iFreeHead);
498 GEN_CHECK_OFF(PGMPOOL, u16Padding);
499#ifdef PGMPOOL_WITH_USER_TRACKING
500 GEN_CHECK_OFF(PGMPOOL, iUserFreeHead);
501 GEN_CHECK_OFF(PGMPOOL, cMaxUsers);
502 GEN_CHECK_OFF(PGMPOOL, cPresent);
503 GEN_CHECK_OFF(PGMPOOL, paUsersHC);
504 GEN_CHECK_OFF(PGMPOOL, paUsersGC);
505#endif /* PGMPOOL_WITH_USER_TRACKING */
506#ifdef PGMPOOL_WITH_GCPHYS_TRACKING
507 GEN_CHECK_OFF(PGMPOOL, iPhysExtFreeHead);
508 GEN_CHECK_OFF(PGMPOOL, cMaxPhysExts);
509 GEN_CHECK_OFF(PGMPOOL, paPhysExtsHC);
510 GEN_CHECK_OFF(PGMPOOL, paPhysExtsGC);
511#endif
512#ifdef PGMPOOL_WITH_CACHE
513 GEN_CHECK_OFF(PGMPOOL, aiHash);
514 GEN_CHECK_OFF(PGMPOOL, iAgeHead);
515 GEN_CHECK_OFF(PGMPOOL, iAgeTail);
516 GEN_CHECK_OFF(PGMPOOL, fCacheEnabled);
517#endif
518#ifdef PGMPOOL_WITH_MONITORING
519 GEN_CHECK_OFF(PGMPOOL, pfnAccessHandlerGC);
520 GEN_CHECK_OFF(PGMPOOL, pfnAccessHandlerR0);
521 GEN_CHECK_OFF(PGMPOOL, pfnAccessHandlerR3);
522 GEN_CHECK_OFF(PGMPOOL, pszAccessHandler);
523 GEN_CHECK_OFF(PGMPOOL, iModifiedHead);
524 GEN_CHECK_OFF(PGMPOOL, cModifiedPages);
525#endif
526 GEN_CHECK_OFF(PGMPOOL, cUsedPages);
527#ifdef VBOX_WITH_STATISTICS
528 GEN_CHECK_OFF(PGMPOOL, cUsedPagesHigh);
529 GEN_CHECK_OFF(PGMPOOL, StatAlloc);
530 GEN_CHECK_OFF(PGMPOOL, StatClearAll);
531#endif
532 GEN_CHECK_OFF(PGMPOOL, HCPhysTree);
533 GEN_CHECK_OFF(PGMPOOL, aPages);
534 GEN_CHECK_OFF(PGMPOOL, aPages[1]);
535 GEN_CHECK_OFF(PGMPOOL, aPages[PGMPOOL_IDX_FIRST - 1]);
536
537 GEN_CHECK_SIZE(REM);
538 GEN_CHECK_OFF(REM, pCtx);
539 GEN_CHECK_OFF(REM, cCanExecuteRaw);
540 GEN_CHECK_OFF(REM, aGCPtrInvalidatedPages);
541 GEN_CHECK_OFF(REM, cHandlerNotifications);
542 GEN_CHECK_OFF(REM, aHandlerNotifications);
543 GEN_CHECK_OFF(REM, paHCVirtToGCPhys);
544 GEN_CHECK_OFF(REM, cPhysRegistrations);
545 GEN_CHECK_OFF(REM, aPhysReg);
546 GEN_CHECK_OFF(REM, rc);
547 GEN_CHECK_OFF(REM, StatsInQEMU);
548 GEN_CHECK_OFF(REM, Env);
549
550 GEN_CHECK_SIZE(SELM);
551 GEN_CHECK_OFF(SELM, offVM);
552 GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_CS]);
553 GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_DS]);
554 GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_CS64]);
555 GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_TSS]);
556 GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_TSS_TRAP08]);
557 GEN_CHECK_OFF(SELM, paGdtHC);
558 GEN_CHECK_OFF(SELM, paGdtGC);
559 GEN_CHECK_OFF(SELM, GuestGdtr);
560 GEN_CHECK_OFF(SELM, cbEffGuestGdtLimit);
561 GEN_CHECK_OFF(SELM, HCPtrLdt);
562 GEN_CHECK_OFF(SELM, GCPtrLdt);
563 GEN_CHECK_OFF(SELM, GCPtrGuestLdt);
564 GEN_CHECK_OFF(SELM, cbLdtLimit);
565 GEN_CHECK_OFF(SELM, offLdtHyper);
566 GEN_CHECK_OFF(SELM, Tss);
567 GEN_CHECK_OFF(SELM, TssTrap08);
568 GEN_CHECK_OFF(SELM, GCPtrTss);
569 GEN_CHECK_OFF(SELM, GCPtrGuestTss);
570 GEN_CHECK_OFF(SELM, cbGuestTss);
571 GEN_CHECK_OFF(SELM, fGuestTss32Bit);
572 GEN_CHECK_OFF(SELM, cbMonitoredGuestTss);
573 GEN_CHECK_OFF(SELM, GCSelTss);
574 GEN_CHECK_OFF(SELM, fGDTRangeRegistered);
575 GEN_CHECK_OFF(SELM, StatUpdateFromCPUM);
576
577 GEN_CHECK_SIZE(STAM);
578
579 GEN_CHECK_SIZE(TM);
580 GEN_CHECK_OFF(TM, offVM);
581 GEN_CHECK_OFF(TM, pvGIPR3);
582 //GEN_CHECK_OFF(TM, pvGIPR0);
583 GEN_CHECK_OFF(TM, pvGIPGC);
584 GEN_CHECK_OFF(TM, fTSCTicking);
585 GEN_CHECK_OFF(TM, u64TSCOffset);
586 GEN_CHECK_OFF(TM, u64TSC);
587 GEN_CHECK_OFF(TM, cTSCTicksPerSecond);
588 GEN_CHECK_OFF(TM, fVirtualTicking);
589 GEN_CHECK_OFF(TM, fVirtualWarpDrive);
590 GEN_CHECK_OFF(TM, u32VirtualWarpDrivePercentage);
591 GEN_CHECK_OFF(TM, u64VirtualOffset);
592 GEN_CHECK_OFF(TM, u64Virtual);
593 GEN_CHECK_OFF(TM, u64VirtualWarpDriveStart);
594 GEN_CHECK_OFF(TM, u64VirtualSync);
595 GEN_CHECK_OFF(TM, u32VirtualSyncCatchupPercentage);
596 GEN_CHECK_OFF(TM, u32VirtualSyncCatchupStopThreashold);
597 GEN_CHECK_OFF(TM, u64VirtualSyncCatchupStartTreashold);
598 GEN_CHECK_OFF(TM, u64VirtualSyncCatchupGiveUpTreashold);
599 GEN_CHECK_OFF(TM, pTimer);
600 GEN_CHECK_OFF(TM, u32TimerMillies);
601 GEN_CHECK_OFF(TM, pFree);
602 GEN_CHECK_OFF(TM, pCreated);
603 GEN_CHECK_OFF(TM, paTimerQueuesR3);
604 GEN_CHECK_OFF(TM, paTimerQueuesR0);
605 GEN_CHECK_OFF(TM, paTimerQueuesGC);
606 GEN_CHECK_OFF(TM, StatDoQueues);
607 GEN_CHECK_SIZE(TMTIMER);
608 GEN_CHECK_OFF(TMTIMER, u64Expire);
609 GEN_CHECK_OFF(TMTIMER, enmClock);
610 GEN_CHECK_OFF(TMTIMER, enmType);
611 GEN_CHECK_OFF(TMTIMER, u.Dev.pfnTimer);
612 GEN_CHECK_OFF(TMTIMER, u.Dev.pDevIns);
613 GEN_CHECK_OFF(TMTIMER, u.Drv.pfnTimer);
614 GEN_CHECK_OFF(TMTIMER, u.Drv.pDrvIns);
615 GEN_CHECK_OFF(TMTIMER, u.Internal.pfnTimer);
616 GEN_CHECK_OFF(TMTIMER, u.Internal.pvUser);
617 GEN_CHECK_OFF(TMTIMER, u.External.pfnTimer);
618 GEN_CHECK_OFF(TMTIMER, u.External.pvUser);
619 GEN_CHECK_OFF(TMTIMER, enmState);
620 GEN_CHECK_OFF(TMTIMER, offScheduleNext);
621 GEN_CHECK_OFF(TMTIMER, offNext);
622 GEN_CHECK_OFF(TMTIMER, offPrev);
623 GEN_CHECK_OFF(TMTIMER, pBigNext);
624 GEN_CHECK_OFF(TMTIMER, pBigPrev);
625 GEN_CHECK_OFF(TMTIMER, pszDesc);
626 GEN_CHECK_OFF(TMTIMER, pVMR0);
627 GEN_CHECK_OFF(TMTIMER, pVMR3);
628 GEN_CHECK_OFF(TMTIMER, pVMGC);
629 GEN_CHECK_SIZE(TMTIMERQUEUE);
630 GEN_CHECK_OFF(TMTIMERQUEUE, offActive);
631 GEN_CHECK_OFF(TMTIMERQUEUE, offSchedule);
632 GEN_CHECK_OFF(TMTIMERQUEUE, enmClock);
633
634 GEN_CHECK_SIZE(TRPM); // has .mac
635 GEN_CHECK_SIZE(VM); // has .mac
636 GEN_CHECK_SIZE(VMM);
637 GEN_CHECK_OFF(VMM, offVM);
638 GEN_CHECK_OFF(VMM, cbCoreCode);
639 GEN_CHECK_OFF(VMM, HCPhysCoreCode);
640 GEN_CHECK_OFF(VMM, pvHCCoreCodeR3);
641 GEN_CHECK_OFF(VMM, pvHCCoreCodeR0);
642 GEN_CHECK_OFF(VMM, pvGCCoreCode);
643 GEN_CHECK_OFF(VMM, enmSwitcher);
644 GEN_CHECK_OFF(VMM, aoffSwitchers);
645 GEN_CHECK_OFF(VMM, aoffSwitchers[1]);
646 GEN_CHECK_OFF(VMM, pfnR0HostToGuest);
647 GEN_CHECK_OFF(VMM, pfnGCGuestToHost);
648 GEN_CHECK_OFF(VMM, pfnGCCallTrampoline);
649 GEN_CHECK_OFF(VMM, pfnCPUMGCResumeGuest);
650 GEN_CHECK_OFF(VMM, pfnCPUMGCResumeGuestV86);
651 GEN_CHECK_OFF(VMM, iLastGCRc);
652 GEN_CHECK_OFF(VMM, pbHCStack);
653 GEN_CHECK_OFF(VMM, pbGCStack);
654 GEN_CHECK_OFF(VMM, pbGCStackBottom);
655 GEN_CHECK_OFF(VMM, pLoggerGC);
656 GEN_CHECK_OFF(VMM, pLoggerHC);
657 GEN_CHECK_OFF(VMM, cbLoggerGC);
658 GEN_CHECK_OFF(VMM, CritSectVMLock);
659 GEN_CHECK_OFF(VMM, pYieldTimer);
660 GEN_CHECK_OFF(VMM, cYieldResumeMillies);
661 GEN_CHECK_OFF(VMM, cYieldEveryMillies);
662 GEN_CHECK_OFF(VMM, enmCallHostOperation);
663 GEN_CHECK_OFF(VMM, rcCallHost);
664 GEN_CHECK_OFF(VMM, u64CallHostArg);
665 GEN_CHECK_OFF(VMM, CallHostR0JmpBuf);
666 GEN_CHECK_OFF(VMM, CallHostR0JmpBuf.SpCheck);
667 GEN_CHECK_OFF(VMM, CallHostR0JmpBuf.SpResume);
668 GEN_CHECK_OFF(VMM, StatRunGC);
669 GEN_CHECK_OFF(VMM, StatGCRetPGMLock);
670
671 GEN_CHECK_SIZE(RTPINGPONG);
672 GEN_CHECK_SIZE(RTCRITSECT);
673 GEN_CHECK_OFF(RTCRITSECT, u32Magic);
674 GEN_CHECK_OFF(RTCRITSECT, cLockers);
675 GEN_CHECK_OFF(RTCRITSECT, NativeThreadOwner);
676 GEN_CHECK_OFF(RTCRITSECT, cNestings);
677 GEN_CHECK_OFF(RTCRITSECT, fFlags);
678 GEN_CHECK_OFF(RTCRITSECT, EventSem);
679 GEN_CHECK_OFF(RTCRITSECT, Strict.ThreadOwner);
680 GEN_CHECK_OFF(RTCRITSECT, Strict.pszEnterFile);
681 GEN_CHECK_OFF(RTCRITSECT, Strict.u32EnterLine);
682 GEN_CHECK_OFF(RTCRITSECT, Strict.uEnterId);
683
684
685 GEN_CHECK_SIZE(CSAM);
686 GEN_CHECK_OFF(CSAM, offVM);
687 GEN_CHECK_OFF(CSAM, pPageTree);
688 GEN_CHECK_OFF(CSAM, aDangerousInstr);
689 GEN_CHECK_OFF(CSAM, aDangerousInstr[1]);
690 GEN_CHECK_OFF(CSAM, aDangerousInstr[CSAM_MAX_DANGR_INSTR - 1]);
691 GEN_CHECK_OFF(CSAM, cDangerousInstr);
692 GEN_CHECK_OFF(CSAM, iDangerousInstr);
693 GEN_CHECK_OFF(CSAM, pPDBitmapGC);
694 GEN_CHECK_OFF(CSAM, pPDHCBitmapGC);
695 GEN_CHECK_OFF(CSAM, pPDBitmapHC);
696 GEN_CHECK_OFF(CSAM, pPDGCBitmapHC);
697 GEN_CHECK_OFF(CSAM, savedstate);
698 GEN_CHECK_OFF(CSAM, savedstate.pSSM);
699 GEN_CHECK_OFF(CSAM, savedstate.cPageRecords);
700 GEN_CHECK_OFF(CSAM, savedstate.cPatchPageRecords);
701 GEN_CHECK_OFF(CSAM, cDirtyPages);
702 GEN_CHECK_OFF(CSAM, pvDirtyBasePage);
703 GEN_CHECK_OFF(CSAM, pvDirtyBasePage[1]);
704 GEN_CHECK_OFF(CSAM, pvDirtyBasePage[CSAM_MAX_DIRTY_PAGES - 1]);
705 GEN_CHECK_OFF(CSAM, pvDirtyFaultPage);
706 GEN_CHECK_OFF(CSAM, pvDirtyFaultPage[1]);
707 GEN_CHECK_OFF(CSAM, pvDirtyFaultPage[CSAM_MAX_DIRTY_PAGES - 1]);
708 GEN_CHECK_OFF(CSAM, fScanningStarted);
709 GEN_CHECK_OFF(CSAM, fGatesChecked);
710 GEN_CHECK_OFF(CSAM, StatNrTraps);
711 GEN_CHECK_OFF(CSAM, StatNrPages);
712
713 GEN_CHECK_SIZE(PATM);
714 GEN_CHECK_OFF(PATM, offVM);
715 GEN_CHECK_OFF(PATM, pPatchMemGC);
716 GEN_CHECK_OFF(PATM, pPatchMemHC);
717 GEN_CHECK_OFF(PATM, cbPatchMem);
718 GEN_CHECK_OFF(PATM, offPatchMem);
719 GEN_CHECK_OFF(PATM, fOutOfMemory);
720 GEN_CHECK_OFF(PATM, deltaReloc);
721 GEN_CHECK_OFF(PATM, pGCStateGC);
722 GEN_CHECK_OFF(PATM, pGCStateHC);
723 GEN_CHECK_OFF(PATM, pGCStackGC);
724 GEN_CHECK_OFF(PATM, pGCStackHC);
725 GEN_CHECK_OFF(PATM, pCPUMCtxGC);
726 GEN_CHECK_OFF(PATM, pStatsGC);
727 GEN_CHECK_OFF(PATM, pStatsHC);
728 GEN_CHECK_OFF(PATM, uCurrentPatchIdx);
729 GEN_CHECK_OFF(PATM, ulCallDepth);
730 GEN_CHECK_OFF(PATM, cPageRecords);
731 GEN_CHECK_OFF(PATM, pPatchedInstrGCLowest);
732 GEN_CHECK_OFF(PATM, pPatchedInstrGCHighest);
733 GEN_CHECK_OFF(PATM, PatchLookupTreeHC);
734 GEN_CHECK_OFF(PATM, PatchLookupTreeGC);
735 GEN_CHECK_OFF(PATM, pfnHelperCallGC);
736 GEN_CHECK_OFF(PATM, pfnHelperRetGC);
737 GEN_CHECK_OFF(PATM, pfnHelperJumpGC);
738 GEN_CHECK_OFF(PATM, pfnHelperIretGC);
739 GEN_CHECK_OFF(PATM, pGlobalPatchRec);
740 GEN_CHECK_OFF(PATM, pfnSysEnterGC);
741 GEN_CHECK_OFF(PATM, pfnSysEnterPatchGC);
742 GEN_CHECK_OFF(PATM, uSysEnterPatchIdx);
743 GEN_CHECK_OFF(PATM, pvFaultMonitor);
744 GEN_CHECK_OFF(PATM, mmio);
745 GEN_CHECK_OFF(PATM, mmio.GCPhys);
746 GEN_CHECK_OFF(PATM, mmio.pCachedData);
747 GEN_CHECK_OFF(PATM, savedstate);
748 GEN_CHECK_OFF(PATM, savedstate.pSSM);
749 GEN_CHECK_OFF(PATM, savedstate.cPatches);
750 GEN_CHECK_OFF(PATM, StatNrOpcodeRead);
751 GEN_CHECK_OFF(PATM, StatU32FunctionMaxSlotsUsed);
752
753 GEN_CHECK_SIZE(PATMGCSTATE);
754 GEN_CHECK_OFF(PATMGCSTATE, uVMFlags);
755 GEN_CHECK_OFF(PATMGCSTATE, uPendingAction);
756 GEN_CHECK_OFF(PATMGCSTATE, uPatchCalls);
757 GEN_CHECK_OFF(PATMGCSTATE, uScratch);
758 GEN_CHECK_OFF(PATMGCSTATE, uIretEFlags);
759 GEN_CHECK_OFF(PATMGCSTATE, uIretCS);
760 GEN_CHECK_OFF(PATMGCSTATE, uIretEIP);
761 GEN_CHECK_OFF(PATMGCSTATE, Psp);
762 GEN_CHECK_OFF(PATMGCSTATE, fPIF);
763 GEN_CHECK_OFF(PATMGCSTATE, GCPtrInhibitInterrupts);
764 GEN_CHECK_OFF(PATMGCSTATE, Restore);
765 GEN_CHECK_OFF(PATMGCSTATE, Restore.uEAX);
766 GEN_CHECK_OFF(PATMGCSTATE, Restore.uECX);
767 GEN_CHECK_OFF(PATMGCSTATE, Restore.uEDI);
768 GEN_CHECK_OFF(PATMGCSTATE, Restore.eFlags);
769 GEN_CHECK_OFF(PATMGCSTATE, Restore.uFlags);
770 GEN_CHECK_SIZE(PATMTREES);
771 GEN_CHECK_OFF(PATMTREES, PatchTree);
772 GEN_CHECK_OFF(PATMTREES, PatchTreeByPatchAddr);
773 GEN_CHECK_OFF(PATMTREES, PatchTreeByPage);
774 GEN_CHECK_SIZE(PATMPATCHREC);
775 GEN_CHECK_OFF(PATMPATCHREC, Core);
776 GEN_CHECK_OFF(PATMPATCHREC, CoreOffset);
777 GEN_CHECK_OFF(PATMPATCHREC, patch);
778 GEN_CHECK_SIZE(PATCHINFO);
779 GEN_CHECK_OFF(PATCHINFO, uState);
780 GEN_CHECK_OFF(PATCHINFO, uOldState);
781 GEN_CHECK_OFF(PATCHINFO, uOpMode);
782 GEN_CHECK_OFF(PATCHINFO, pPrivInstrHC);
783 GEN_CHECK_OFF(PATCHINFO, pPrivInstrGC);
784 GEN_CHECK_OFF(PATCHINFO, aPrivInstr);
785 GEN_CHECK_OFF(PATCHINFO, aPrivInstr[1]);
786 GEN_CHECK_OFF(PATCHINFO, aPrivInstr[MAX_INSTR_SIZE - 1]);
787 GEN_CHECK_OFF(PATCHINFO, cbPrivInstr);
788 GEN_CHECK_OFF(PATCHINFO, opcode);
789 GEN_CHECK_OFF(PATCHINFO, cbPatchJump);
790 GEN_CHECK_OFF(PATCHINFO, pPatchJumpDestGC);
791 GEN_CHECK_OFF(PATCHINFO, pPatchBlockOffset);
792 GEN_CHECK_OFF(PATCHINFO, cbPatchBlockSize);
793 GEN_CHECK_OFF(PATCHINFO, uCurPatchOffset);
794 GEN_CHECK_OFF(PATCHINFO, flags);
795 GEN_CHECK_OFF(PATCHINFO, pInstrGCLowest);
796 GEN_CHECK_OFF(PATCHINFO, pInstrGCHighest);
797 GEN_CHECK_OFF(PATCHINFO, FixupTree);
798 GEN_CHECK_OFF(PATCHINFO, nrFixups);
799 GEN_CHECK_OFF(PATCHINFO, JumpTree);
800 GEN_CHECK_OFF(PATCHINFO, nrJumpRecs);
801 GEN_CHECK_OFF(PATCHINFO, Patch2GuestAddrTree);
802 GEN_CHECK_OFF(PATCHINFO, Guest2PatchAddrTree);
803 GEN_CHECK_OFF(PATCHINFO, nrPatch2GuestRecs);
804 GEN_CHECK_OFF(PATCHINFO, cacheRec);
805 GEN_CHECK_OFF(PATCHINFO, cacheRec.pPatchLocStartHC);
806 GEN_CHECK_OFF(PATCHINFO, cacheRec.pPatchLocEndHC);
807 GEN_CHECK_OFF(PATCHINFO, cacheRec.pGuestLoc);
808 GEN_CHECK_OFF(PATCHINFO, cacheRec.opsize);
809 GEN_CHECK_OFF(PATCHINFO, pTempInfo);
810 GEN_CHECK_OFF(PATCHINFO, cCodeWrites);
811 GEN_CHECK_OFF(PATCHINFO, cTraps);
812 GEN_CHECK_OFF(PATCHINFO, cInvalidWrites);
813 GEN_CHECK_OFF(PATCHINFO, uPatchIdx);
814 GEN_CHECK_OFF(PATCHINFO, bDirtyOpcode);
815 GEN_CHECK_SIZE(PATMPATCHPAGE);
816 GEN_CHECK_OFF(PATMPATCHPAGE, Core);
817 GEN_CHECK_OFF(PATMPATCHPAGE, pLowestAddrGC);
818 GEN_CHECK_OFF(PATMPATCHPAGE, pHighestAddrGC);
819 GEN_CHECK_OFF(PATMPATCHPAGE, cCount);
820 GEN_CHECK_OFF(PATMPATCHPAGE, cMaxPatches);
821 GEN_CHECK_OFF(PATMPATCHPAGE, aPatch);
822
823 return (0);
824}
825
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