1 | /* $Id: tstVMStructGC.cpp 17371 2009-03-05 01:37:58Z 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-2007 Sun Microsystems, Inc.
|
---|
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 (GPL) as published by the Free Software
|
---|
16 | * Foundation, in version 2 as it comes in the "COPYING" file of the
|
---|
17 | * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
|
---|
18 | * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
|
---|
19 | *
|
---|
20 | * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
|
---|
21 | * Clara, CA 95054 USA or visit http://www.sun.com if you need
|
---|
22 | * additional information or have any questions.
|
---|
23 | */
|
---|
24 |
|
---|
25 |
|
---|
26 | /*
|
---|
27 | * Sanity checks.
|
---|
28 | */
|
---|
29 | #ifndef IN_RC
|
---|
30 | # error Incorrect template!
|
---|
31 | #endif
|
---|
32 | #if defined(IN_RING3) || defined(IN_RING0)
|
---|
33 | # error Incorrect template!
|
---|
34 | #endif
|
---|
35 |
|
---|
36 | #include <VBox/types.h>
|
---|
37 | #include <iprt/assert.h>
|
---|
38 | AssertCompileSize(uint8_t, 1);
|
---|
39 | AssertCompileSize(uint16_t, 2);
|
---|
40 | AssertCompileSize(uint32_t, 4);
|
---|
41 | AssertCompileSize(uint64_t, 8);
|
---|
42 | AssertCompileSize(RTRCPTR, 4);
|
---|
43 | #ifdef VBOX_WITH_64_BITS_GUESTS
|
---|
44 | AssertCompileSize(RTGCPTR, 8);
|
---|
45 | #else
|
---|
46 | AssertCompileSize(RTGCPTR, 4);
|
---|
47 | #endif
|
---|
48 | AssertCompileSize(RTGCPHYS, 8);
|
---|
49 | AssertCompileSize(RTHCPHYS, 8);
|
---|
50 |
|
---|
51 |
|
---|
52 | /*******************************************************************************
|
---|
53 | * Header Files *
|
---|
54 | *******************************************************************************/
|
---|
55 | #include <VBox/cfgm.h>
|
---|
56 | #include <VBox/cpum.h>
|
---|
57 | #include <VBox/mm.h>
|
---|
58 | #include <VBox/pgm.h>
|
---|
59 | #include <VBox/selm.h>
|
---|
60 | #include <VBox/trpm.h>
|
---|
61 | #include <VBox/vmm.h>
|
---|
62 | #include <VBox/stam.h>
|
---|
63 | #include "../PDMInternal.h"
|
---|
64 | #include <VBox/pdm.h>
|
---|
65 | #include "../CFGMInternal.h"
|
---|
66 | #include "../CPUMInternal.h"
|
---|
67 | #include "../MMInternal.h"
|
---|
68 | #include "../PGMInternal.h"
|
---|
69 | #include "../SELMInternal.h"
|
---|
70 | #include "../TRPMInternal.h"
|
---|
71 | #include "../TMInternal.h"
|
---|
72 | #include "../IOMInternal.h"
|
---|
73 | #include "../REMInternal.h"
|
---|
74 | #include "../HWACCMInternal.h"
|
---|
75 | #include "../PATM/PATMInternal.h"
|
---|
76 | #include "../VMMInternal.h"
|
---|
77 | #include "../DBGFInternal.h"
|
---|
78 | #include "../STAMInternal.h"
|
---|
79 | #include "../PATM/CSAMInternal.h"
|
---|
80 | #include "../EMInternal.h"
|
---|
81 | #include "../REMInternal.h"
|
---|
82 | #include <VBox/vm.h>
|
---|
83 | #include <VBox/param.h>
|
---|
84 | #include <VBox/x86.h>
|
---|
85 |
|
---|
86 | /* we don't use iprt here because we're pretending to be in GC! */
|
---|
87 | #include <stdio.h>
|
---|
88 |
|
---|
89 | #define GEN_CHECK_SIZE(s) printf(" CHECK_SIZE(%s, %u);\n", #s, (unsigned)sizeof(s))
|
---|
90 | #define GEN_CHECK_OFF(s, m) printf(" CHECK_OFF(%s, %u, %s);\n", #s, (unsigned)RT_OFFSETOF(s, m), #m)
|
---|
91 |
|
---|
92 | int main()
|
---|
93 | {
|
---|
94 | GEN_CHECK_SIZE(CFGM);
|
---|
95 |
|
---|
96 | GEN_CHECK_SIZE(CPUM); // has .mac
|
---|
97 | GEN_CHECK_SIZE(CPUMHOSTCTX);
|
---|
98 | GEN_CHECK_SIZE(CPUMCTX);
|
---|
99 | GEN_CHECK_SIZE(CPUMCTXMSR);
|
---|
100 | GEN_CHECK_SIZE(CPUMCTXCORE);
|
---|
101 | GEN_CHECK_SIZE(STAMRATIOU32);
|
---|
102 | GEN_CHECK_SIZE(AVLOHCPHYSNODECORE);
|
---|
103 | GEN_CHECK_SIZE(AVLOGCPHYSNODECORE);
|
---|
104 | GEN_CHECK_SIZE(AVLROGCPHYSNODECORE);
|
---|
105 | GEN_CHECK_SIZE(AVLOGCPTRNODECORE);
|
---|
106 | GEN_CHECK_SIZE(AVLROGCPTRNODECORE);
|
---|
107 | GEN_CHECK_SIZE(AVLOIOPORTNODECORE);
|
---|
108 | GEN_CHECK_SIZE(AVLROIOPORTNODECORE);
|
---|
109 |
|
---|
110 | GEN_CHECK_SIZE(DBGF);
|
---|
111 | GEN_CHECK_OFF(DBGF, offVM);
|
---|
112 | GEN_CHECK_OFF(DBGF, fAttached);
|
---|
113 | GEN_CHECK_OFF(DBGF, fStoppedInHyper);
|
---|
114 | GEN_CHECK_OFF(DBGF, PingPong);
|
---|
115 | GEN_CHECK_OFF(DBGF, DbgEvent);
|
---|
116 | GEN_CHECK_OFF(DBGF, enmVMMCmd);
|
---|
117 | GEN_CHECK_OFF(DBGF, VMMCmdData);
|
---|
118 | GEN_CHECK_OFF(DBGF, pInfoFirst);
|
---|
119 | GEN_CHECK_OFF(DBGF, InfoCritSect);
|
---|
120 | GEN_CHECK_OFF(DBGF, SymbolTree);
|
---|
121 | GEN_CHECK_OFF(DBGF, pSymbolSpace);
|
---|
122 | GEN_CHECK_OFF(DBGF, fSymInited);
|
---|
123 | GEN_CHECK_OFF(DBGF, cHwBreakpoints);
|
---|
124 | GEN_CHECK_OFF(DBGF, cBreakpoints);
|
---|
125 | GEN_CHECK_OFF(DBGF, aHwBreakpoints);
|
---|
126 | GEN_CHECK_OFF(DBGF, aBreakpoints);
|
---|
127 | GEN_CHECK_OFF(DBGF, iActiveBp);
|
---|
128 | GEN_CHECK_OFF(DBGF, fSingleSteppingRaw);
|
---|
129 | GEN_CHECK_SIZE(DBGFEVENT);
|
---|
130 |
|
---|
131 | GEN_CHECK_SIZE(EM);
|
---|
132 | GEN_CHECK_OFF(EM, offVM);
|
---|
133 | GEN_CHECK_OFF(EM, pCtx);
|
---|
134 | GEN_CHECK_OFF(EM, enmState);
|
---|
135 | GEN_CHECK_OFF(EM, fForceRAW);
|
---|
136 | GEN_CHECK_OFF(EM, u.achPaddingFatalLongJump);
|
---|
137 | GEN_CHECK_OFF(EM, StatForcedActions);
|
---|
138 | GEN_CHECK_OFF(EM, StatTotalClis);
|
---|
139 | GEN_CHECK_OFF(EM, pStatsR3);
|
---|
140 | GEN_CHECK_OFF(EM, pStatsR0);
|
---|
141 | GEN_CHECK_OFF(EM, pStatsRC);
|
---|
142 | GEN_CHECK_OFF(EM, pCliStatTree);
|
---|
143 |
|
---|
144 | GEN_CHECK_SIZE(IOM);
|
---|
145 | GEN_CHECK_OFF(IOM, pTreesRC);
|
---|
146 | GEN_CHECK_OFF(IOM, pTreesR3);
|
---|
147 | GEN_CHECK_OFF(IOM, pTreesR0);
|
---|
148 | GEN_CHECK_OFF(IOM, pMMIORangeLastR3);
|
---|
149 | GEN_CHECK_OFF(IOM, pMMIOStatsLastR3);
|
---|
150 | GEN_CHECK_OFF(IOM, pMMIORangeLastR0);
|
---|
151 | GEN_CHECK_OFF(IOM, pMMIOStatsLastR0);
|
---|
152 | GEN_CHECK_OFF(IOM, pMMIORangeLastRC);
|
---|
153 | GEN_CHECK_OFF(IOM, pMMIOStatsLastRC);
|
---|
154 | GEN_CHECK_OFF(IOM, pRangeLastReadR0);
|
---|
155 | GEN_CHECK_OFF(IOM, pRangeLastReadRC);
|
---|
156 |
|
---|
157 | GEN_CHECK_SIZE(IOMMMIORANGE);
|
---|
158 | GEN_CHECK_OFF(IOMMMIORANGE, GCPhys);
|
---|
159 | GEN_CHECK_OFF(IOMMMIORANGE, cb);
|
---|
160 | GEN_CHECK_OFF(IOMMMIORANGE, pszDesc);
|
---|
161 | GEN_CHECK_OFF(IOMMMIORANGE, pvUserR3);
|
---|
162 | GEN_CHECK_OFF(IOMMMIORANGE, pDevInsR3);
|
---|
163 | GEN_CHECK_OFF(IOMMMIORANGE, pfnWriteCallbackR3);
|
---|
164 | GEN_CHECK_OFF(IOMMMIORANGE, pfnReadCallbackR3);
|
---|
165 | GEN_CHECK_OFF(IOMMMIORANGE, pfnFillCallbackR3);
|
---|
166 | GEN_CHECK_OFF(IOMMMIORANGE, pvUserR0);
|
---|
167 | GEN_CHECK_OFF(IOMMMIORANGE, pDevInsR0);
|
---|
168 | GEN_CHECK_OFF(IOMMMIORANGE, pfnWriteCallbackR0);
|
---|
169 | GEN_CHECK_OFF(IOMMMIORANGE, pfnReadCallbackR0);
|
---|
170 | GEN_CHECK_OFF(IOMMMIORANGE, pfnFillCallbackR0);
|
---|
171 | GEN_CHECK_OFF(IOMMMIORANGE, pvUserRC);
|
---|
172 | GEN_CHECK_OFF(IOMMMIORANGE, pDevInsRC);
|
---|
173 | GEN_CHECK_OFF(IOMMMIORANGE, pfnWriteCallbackRC);
|
---|
174 | GEN_CHECK_OFF(IOMMMIORANGE, pfnReadCallbackRC);
|
---|
175 | GEN_CHECK_OFF(IOMMMIORANGE, pfnFillCallbackRC);
|
---|
176 |
|
---|
177 | GEN_CHECK_SIZE(IOMMMIOSTATS);
|
---|
178 | GEN_CHECK_OFF(IOMMMIOSTATS, ReadR3);
|
---|
179 |
|
---|
180 | GEN_CHECK_SIZE(IOMIOPORTRANGER0);
|
---|
181 | GEN_CHECK_OFF(IOMIOPORTRANGER0, Port);
|
---|
182 | GEN_CHECK_OFF(IOMIOPORTRANGER0, cPorts);
|
---|
183 | GEN_CHECK_OFF(IOMIOPORTRANGER0, pvUser);
|
---|
184 | GEN_CHECK_OFF(IOMIOPORTRANGER0, pDevIns);
|
---|
185 | GEN_CHECK_OFF(IOMIOPORTRANGER0, pszDesc);
|
---|
186 |
|
---|
187 | GEN_CHECK_SIZE(IOMIOPORTRANGERC);
|
---|
188 | GEN_CHECK_OFF(IOMIOPORTRANGERC, Port);
|
---|
189 | GEN_CHECK_OFF(IOMIOPORTRANGERC, cPorts);
|
---|
190 | GEN_CHECK_OFF(IOMIOPORTRANGERC, pvUser);
|
---|
191 | GEN_CHECK_OFF(IOMIOPORTRANGERC, pDevIns);
|
---|
192 | GEN_CHECK_OFF(IOMIOPORTRANGERC, pszDesc);
|
---|
193 |
|
---|
194 | GEN_CHECK_SIZE(IOMIOPORTSTATS);
|
---|
195 | GEN_CHECK_OFF(IOMIOPORTSTATS, InR3);
|
---|
196 |
|
---|
197 | GEN_CHECK_SIZE(IOMTREES);
|
---|
198 | GEN_CHECK_OFF(IOMTREES, IOPortTreeR3);
|
---|
199 | GEN_CHECK_OFF(IOMTREES, IOPortTreeR0);
|
---|
200 | GEN_CHECK_OFF(IOMTREES, IOPortTreeRC);
|
---|
201 | GEN_CHECK_OFF(IOMTREES, MMIOTree);
|
---|
202 | GEN_CHECK_OFF(IOMTREES, IOPortStatTree);
|
---|
203 | GEN_CHECK_OFF(IOMTREES, MMIOStatTree);
|
---|
204 |
|
---|
205 | GEN_CHECK_SIZE(MM);
|
---|
206 | GEN_CHECK_OFF(MM, offVM);
|
---|
207 | GEN_CHECK_OFF(MM, offHyperNextStatic);
|
---|
208 | GEN_CHECK_OFF(MM, cbHyperArea);
|
---|
209 | GEN_CHECK_OFF(MM, fDoneMMR3InitPaging);
|
---|
210 | GEN_CHECK_OFF(MM, fPGMInitialized);
|
---|
211 | GEN_CHECK_OFF(MM, offLookupHyper);
|
---|
212 | GEN_CHECK_OFF(MM, pHyperHeapRC);
|
---|
213 | GEN_CHECK_OFF(MM, pHyperHeapR3);
|
---|
214 | GEN_CHECK_OFF(MM, pHyperHeapR0);
|
---|
215 | GEN_CHECK_OFF(MM, pLockedMem);
|
---|
216 | GEN_CHECK_OFF(MM, pPagePoolR3);
|
---|
217 | GEN_CHECK_OFF(MM, pPagePoolLowR3);
|
---|
218 | #ifndef VBOX_WITH_2X_4GB_ADDR_SPACE
|
---|
219 | GEN_CHECK_OFF(MM, pPagePoolR0);
|
---|
220 | GEN_CHECK_OFF(MM, pPagePoolLowR0);
|
---|
221 | #endif
|
---|
222 | GEN_CHECK_OFF(MM, pvDummyPage);
|
---|
223 | GEN_CHECK_OFF(MM, HCPhysDummyPage);
|
---|
224 | GEN_CHECK_OFF(MM, cbRamBase);
|
---|
225 | GEN_CHECK_OFF(MM, cBasePages);
|
---|
226 | GEN_CHECK_OFF(MM, cShadowPages);
|
---|
227 | GEN_CHECK_OFF(MM, cFixedPages);
|
---|
228 | GEN_CHECK_SIZE(MMHYPERSTAT);
|
---|
229 | GEN_CHECK_SIZE(MMHYPERCHUNK);
|
---|
230 | GEN_CHECK_SIZE(MMHYPERCHUNKFREE);
|
---|
231 | GEN_CHECK_SIZE(MMHYPERHEAP);
|
---|
232 | GEN_CHECK_OFF(MMHYPERHEAP, u32Magic);
|
---|
233 | GEN_CHECK_OFF(MMHYPERHEAP, cbHeap);
|
---|
234 | GEN_CHECK_OFF(MMHYPERHEAP, pbHeapR3);
|
---|
235 | GEN_CHECK_OFF(MMHYPERHEAP, pVMR3);
|
---|
236 | GEN_CHECK_OFF(MMHYPERHEAP, pbHeapR0);
|
---|
237 | GEN_CHECK_OFF(MMHYPERHEAP, pVMR0);
|
---|
238 | GEN_CHECK_OFF(MMHYPERHEAP, pbHeapRC);
|
---|
239 | GEN_CHECK_OFF(MMHYPERHEAP, pVMRC);
|
---|
240 | GEN_CHECK_OFF(MMHYPERHEAP, cbFree);
|
---|
241 | GEN_CHECK_OFF(MMHYPERHEAP, offFreeHead);
|
---|
242 | GEN_CHECK_OFF(MMHYPERHEAP, offFreeTail);
|
---|
243 | GEN_CHECK_OFF(MMHYPERHEAP, offPageAligned);
|
---|
244 | GEN_CHECK_OFF(MMHYPERHEAP, HyperHeapStatTree);
|
---|
245 | GEN_CHECK_SIZE(MMLOOKUPHYPER);
|
---|
246 | GEN_CHECK_OFF(MMLOOKUPHYPER, offNext);
|
---|
247 | GEN_CHECK_OFF(MMLOOKUPHYPER, off);
|
---|
248 | GEN_CHECK_OFF(MMLOOKUPHYPER, cb);
|
---|
249 | GEN_CHECK_OFF(MMLOOKUPHYPER, enmType);
|
---|
250 | GEN_CHECK_OFF(MMLOOKUPHYPER, u.Locked.pvR3);
|
---|
251 | GEN_CHECK_OFF(MMLOOKUPHYPER, u.Locked.pvR0);
|
---|
252 | GEN_CHECK_OFF(MMLOOKUPHYPER, u.Locked.pLockedMem);
|
---|
253 | GEN_CHECK_OFF(MMLOOKUPHYPER, u.HCPhys.pvR3);
|
---|
254 | GEN_CHECK_OFF(MMLOOKUPHYPER, u.HCPhys.HCPhys);
|
---|
255 | GEN_CHECK_OFF(MMLOOKUPHYPER, u.GCPhys.GCPhys);
|
---|
256 | GEN_CHECK_OFF(MMLOOKUPHYPER, pszDesc);
|
---|
257 |
|
---|
258 | GEN_CHECK_SIZE(PDM);
|
---|
259 | GEN_CHECK_OFF(PDM, offVM);
|
---|
260 | GEN_CHECK_OFF(PDM, pDevs);
|
---|
261 | GEN_CHECK_OFF(PDM, pDevInstances);
|
---|
262 | GEN_CHECK_OFF(PDM, pUsbDevs);
|
---|
263 | GEN_CHECK_OFF(PDM, pUsbInstances);
|
---|
264 | GEN_CHECK_OFF(PDM, pDrvs);
|
---|
265 | GEN_CHECK_OFF(PDM, pCritSects);
|
---|
266 | GEN_CHECK_OFF(PDM, aPciBuses);
|
---|
267 | GEN_CHECK_OFF(PDM, aPciBuses[0].iBus);
|
---|
268 | GEN_CHECK_OFF(PDM, aPciBuses[0].pDevInsR3);
|
---|
269 | GEN_CHECK_OFF(PDM, aPciBuses[0].pfnSetIrqR3);
|
---|
270 | GEN_CHECK_OFF(PDM, aPciBuses[0].pfnRegisterR3);
|
---|
271 | GEN_CHECK_OFF(PDM, aPciBuses[0].pfnIORegionRegisterR3);
|
---|
272 | GEN_CHECK_OFF(PDM, aPciBuses[0].pfnSaveExecR3);
|
---|
273 | GEN_CHECK_OFF(PDM, aPciBuses[0].pfnLoadExecR3);
|
---|
274 | GEN_CHECK_OFF(PDM, aPciBuses[0].pfnFakePCIBIOSR3);
|
---|
275 | GEN_CHECK_OFF(PDM, aPciBuses[0].pDevInsR0);
|
---|
276 | GEN_CHECK_OFF(PDM, aPciBuses[0].pfnSetIrqR0);
|
---|
277 | GEN_CHECK_OFF(PDM, aPciBuses[0].pDevInsRC);
|
---|
278 | GEN_CHECK_OFF(PDM, aPciBuses[0].pfnSetIrqRC);
|
---|
279 | GEN_CHECK_OFF(PDM, Pic);
|
---|
280 | GEN_CHECK_OFF(PDM, Pic.pDevInsR3);
|
---|
281 | GEN_CHECK_OFF(PDM, Pic.pfnSetIrqR3);
|
---|
282 | GEN_CHECK_OFF(PDM, Pic.pfnGetInterruptR3);
|
---|
283 | GEN_CHECK_OFF(PDM, Pic.pDevInsR0);
|
---|
284 | GEN_CHECK_OFF(PDM, Pic.pfnSetIrqR0);
|
---|
285 | GEN_CHECK_OFF(PDM, Pic.pfnGetInterruptR0);
|
---|
286 | GEN_CHECK_OFF(PDM, Pic.pDevInsRC);
|
---|
287 | GEN_CHECK_OFF(PDM, Pic.pfnSetIrqRC);
|
---|
288 | GEN_CHECK_OFF(PDM, Pic.pfnGetInterruptRC);
|
---|
289 | GEN_CHECK_OFF(PDM, Apic);
|
---|
290 | GEN_CHECK_OFF(PDM, Apic.pDevInsR3);
|
---|
291 | GEN_CHECK_OFF(PDM, Apic.pfnGetInterruptR3);
|
---|
292 | GEN_CHECK_OFF(PDM, Apic.pfnSetBaseR3);
|
---|
293 | GEN_CHECK_OFF(PDM, Apic.pfnGetBaseR3);
|
---|
294 | GEN_CHECK_OFF(PDM, Apic.pfnSetTPRR3);
|
---|
295 | GEN_CHECK_OFF(PDM, Apic.pfnWriteMSRR3);
|
---|
296 | GEN_CHECK_OFF(PDM, Apic.pfnReadMSRR3);
|
---|
297 | GEN_CHECK_OFF(PDM, Apic.pfnGetTPRR3);
|
---|
298 | GEN_CHECK_OFF(PDM, Apic.pfnBusDeliverR3);
|
---|
299 | GEN_CHECK_OFF(PDM, Apic.pDevInsR0);
|
---|
300 | GEN_CHECK_OFF(PDM, Apic.pfnGetInterruptR0);
|
---|
301 | GEN_CHECK_OFF(PDM, Apic.pfnSetBaseR0);
|
---|
302 | GEN_CHECK_OFF(PDM, Apic.pfnGetBaseR0);
|
---|
303 | GEN_CHECK_OFF(PDM, Apic.pfnSetTPRR0);
|
---|
304 | GEN_CHECK_OFF(PDM, Apic.pfnGetTPRR0);
|
---|
305 | GEN_CHECK_OFF(PDM, Apic.pfnWriteMSRR0);
|
---|
306 | GEN_CHECK_OFF(PDM, Apic.pfnReadMSRR0);
|
---|
307 | GEN_CHECK_OFF(PDM, Apic.pfnBusDeliverR0);
|
---|
308 | GEN_CHECK_OFF(PDM, Apic.pDevInsRC);
|
---|
309 | GEN_CHECK_OFF(PDM, Apic.pfnGetInterruptRC);
|
---|
310 | GEN_CHECK_OFF(PDM, Apic.pfnSetBaseRC);
|
---|
311 | GEN_CHECK_OFF(PDM, Apic.pfnGetBaseRC);
|
---|
312 | GEN_CHECK_OFF(PDM, Apic.pfnSetTPRRC);
|
---|
313 | GEN_CHECK_OFF(PDM, Apic.pfnGetTPRRC);
|
---|
314 | GEN_CHECK_OFF(PDM, Apic.pfnWriteMSRRC);
|
---|
315 | GEN_CHECK_OFF(PDM, Apic.pfnReadMSRRC);
|
---|
316 | GEN_CHECK_OFF(PDM, Apic.pfnBusDeliverRC);
|
---|
317 | GEN_CHECK_OFF(PDM, IoApic);
|
---|
318 | GEN_CHECK_OFF(PDM, IoApic.pDevInsR3);
|
---|
319 | GEN_CHECK_OFF(PDM, IoApic.pfnSetIrqR3);
|
---|
320 | GEN_CHECK_OFF(PDM, IoApic.pDevInsR0);
|
---|
321 | GEN_CHECK_OFF(PDM, IoApic.pfnSetIrqR0);
|
---|
322 | GEN_CHECK_OFF(PDM, IoApic.pDevInsRC);
|
---|
323 | GEN_CHECK_OFF(PDM, IoApic.pfnSetIrqRC);
|
---|
324 | GEN_CHECK_OFF(PDM, pDmac);
|
---|
325 | GEN_CHECK_OFF(PDM, pRtc);
|
---|
326 | GEN_CHECK_OFF(PDM, pUsbHubs);
|
---|
327 | GEN_CHECK_OFF(PDM, pDevHlpQueueR3);
|
---|
328 | GEN_CHECK_OFF(PDM, pDevHlpQueueR0);
|
---|
329 | GEN_CHECK_OFF(PDM, pDevHlpQueueRC);
|
---|
330 | GEN_CHECK_OFF(PDM, cQueuedCritSectLeaves);
|
---|
331 | GEN_CHECK_OFF(PDM, apQueuedCritSectsLeaves);
|
---|
332 | GEN_CHECK_OFF(PDM, pQueuesTimer);
|
---|
333 | GEN_CHECK_OFF(PDM, pQueuesForced);
|
---|
334 | GEN_CHECK_OFF(PDM, pQueueFlushR0);
|
---|
335 | GEN_CHECK_OFF(PDM, pQueueFlushRC);
|
---|
336 | GEN_CHECK_OFF(PDM, pThreads);
|
---|
337 | GEN_CHECK_OFF(PDM, pThreadsTail);
|
---|
338 | GEN_CHECK_OFF(PDM, cPollers);
|
---|
339 | GEN_CHECK_OFF(PDM, apfnPollers);
|
---|
340 | GEN_CHECK_OFF(PDM, aDrvInsPollers);
|
---|
341 | GEN_CHECK_OFF(PDM, pTimerPollers);
|
---|
342 | GEN_CHECK_OFF(PDM, CritSect);
|
---|
343 | GEN_CHECK_OFF(PDM, StatQueuedCritSectLeaves);
|
---|
344 | GEN_CHECK_SIZE(PDMDEVINSINT);
|
---|
345 | GEN_CHECK_OFF(PDMDEVINSINT, pNextR3);
|
---|
346 | GEN_CHECK_OFF(PDMDEVINSINT, pPerDeviceNextR3);
|
---|
347 | GEN_CHECK_OFF(PDMDEVINSINT, pDevR3);
|
---|
348 | GEN_CHECK_OFF(PDMDEVINSINT, pVMR3);
|
---|
349 | GEN_CHECK_OFF(PDMDEVINSINT, pVMR0);
|
---|
350 | GEN_CHECK_OFF(PDMDEVINSINT, pVMRC);
|
---|
351 | GEN_CHECK_OFF(PDMDEVINSINT, pLunsR3);
|
---|
352 | GEN_CHECK_OFF(PDMDEVINSINT, pCfgHandle);
|
---|
353 | GEN_CHECK_OFF(PDMDEVINSINT, pPciDeviceR3);
|
---|
354 | GEN_CHECK_OFF(PDMDEVINSINT, pPciDeviceR0);
|
---|
355 | GEN_CHECK_OFF(PDMDEVINSINT, pPciDeviceRC);
|
---|
356 | GEN_CHECK_OFF(PDMDEVINSINT, pPciBusR3);
|
---|
357 | GEN_CHECK_OFF(PDMDEVINSINT, pPciBusR0);
|
---|
358 | GEN_CHECK_OFF(PDMDEVINSINT, pPciBusRC);
|
---|
359 | GEN_CHECK_SIZE(PDMCRITSECTINT);
|
---|
360 | GEN_CHECK_OFF(PDMCRITSECTINT, Core);
|
---|
361 | GEN_CHECK_OFF(PDMCRITSECTINT, pNext);
|
---|
362 | GEN_CHECK_OFF(PDMCRITSECTINT, pvKey);
|
---|
363 | GEN_CHECK_OFF(PDMCRITSECTINT, pVMR3);
|
---|
364 | GEN_CHECK_OFF(PDMCRITSECTINT, pVMR0);
|
---|
365 | GEN_CHECK_OFF(PDMCRITSECTINT, pVMRC);
|
---|
366 | GEN_CHECK_OFF(PDMCRITSECTINT, StatContentionRZLock);
|
---|
367 | GEN_CHECK_OFF(PDMCRITSECTINT, StatContentionRZUnlock);
|
---|
368 | GEN_CHECK_OFF(PDMCRITSECTINT, StatContentionR3);
|
---|
369 | GEN_CHECK_OFF(PDMCRITSECTINT, StatLocked);
|
---|
370 | GEN_CHECK_SIZE(PDMQUEUE);
|
---|
371 | GEN_CHECK_OFF(PDMQUEUE, pNext);
|
---|
372 | GEN_CHECK_OFF(PDMQUEUE, enmType);
|
---|
373 | GEN_CHECK_OFF(PDMQUEUE, u);
|
---|
374 | GEN_CHECK_OFF(PDMQUEUE, u.Dev.pfnCallback);
|
---|
375 | GEN_CHECK_OFF(PDMQUEUE, u.Dev.pDevIns);
|
---|
376 | GEN_CHECK_OFF(PDMQUEUE, u.Drv.pfnCallback);
|
---|
377 | GEN_CHECK_OFF(PDMQUEUE, u.Drv.pDrvIns);
|
---|
378 | GEN_CHECK_OFF(PDMQUEUE, u.Int.pfnCallback);
|
---|
379 | GEN_CHECK_OFF(PDMQUEUE, u.Ext.pfnCallback);
|
---|
380 | GEN_CHECK_OFF(PDMQUEUE, u.Ext.pvUser);
|
---|
381 | GEN_CHECK_OFF(PDMQUEUE, pVMR3);
|
---|
382 | GEN_CHECK_OFF(PDMQUEUE, pVMR0);
|
---|
383 | GEN_CHECK_OFF(PDMQUEUE, pVMRC);
|
---|
384 | GEN_CHECK_OFF(PDMQUEUE, cMilliesInterval);
|
---|
385 | GEN_CHECK_OFF(PDMQUEUE, pTimer);
|
---|
386 | GEN_CHECK_OFF(PDMQUEUE, cbItem);
|
---|
387 | GEN_CHECK_OFF(PDMQUEUE, cItems);
|
---|
388 | GEN_CHECK_OFF(PDMQUEUE, pPendingR3);
|
---|
389 | GEN_CHECK_OFF(PDMQUEUE, pPendingR0);
|
---|
390 | GEN_CHECK_OFF(PDMQUEUE, pPendingRC);
|
---|
391 | GEN_CHECK_OFF(PDMQUEUE, iFreeHead);
|
---|
392 | GEN_CHECK_OFF(PDMQUEUE, iFreeTail);
|
---|
393 | GEN_CHECK_OFF(PDMQUEUE, aFreeItems);
|
---|
394 | GEN_CHECK_OFF(PDMQUEUE, aFreeItems[1]);
|
---|
395 | GEN_CHECK_OFF(PDMQUEUE, aFreeItems[0].pItemR3);
|
---|
396 | GEN_CHECK_OFF(PDMQUEUE, aFreeItems[0].pItemR0);
|
---|
397 | GEN_CHECK_OFF(PDMQUEUE, aFreeItems[1].pItemRC);
|
---|
398 | GEN_CHECK_SIZE(PDMDEVHLPTASK);
|
---|
399 | GEN_CHECK_OFF(PDMDEVHLPTASK, Core);
|
---|
400 | GEN_CHECK_OFF(PDMDEVHLPTASK, pDevInsR3);
|
---|
401 | GEN_CHECK_OFF(PDMDEVHLPTASK, enmOp);
|
---|
402 | GEN_CHECK_OFF(PDMDEVHLPTASK, u);
|
---|
403 | GEN_CHECK_OFF(PDMDEVHLPTASK, u.SetIRQ.iIrq);
|
---|
404 | GEN_CHECK_OFF(PDMDEVHLPTASK, u.SetIRQ.iLevel);
|
---|
405 |
|
---|
406 | GEN_CHECK_SIZE(PGM);
|
---|
407 | GEN_CHECK_OFF(PGM, offVM);
|
---|
408 | GEN_CHECK_OFF(PGM, fRamPreAlloc);
|
---|
409 | GEN_CHECK_OFF(PGM, paDynPageMap32BitPTEsGC);
|
---|
410 | GEN_CHECK_OFF(PGM, paDynPageMapPaePTEsGC);
|
---|
411 | GEN_CHECK_OFF(PGM, enmHostMode);
|
---|
412 | GEN_CHECK_OFF(PGM, enmShadowMode);
|
---|
413 | GEN_CHECK_OFF(PGM, enmGuestMode);
|
---|
414 | GEN_CHECK_OFF(PGM, GCPhysCR3);
|
---|
415 | GEN_CHECK_OFF(PGM, GCPtrCR3Mapping);
|
---|
416 | #ifndef VBOX_WITH_PGMPOOL_PAGING_ONLY
|
---|
417 | GEN_CHECK_OFF(PGM, GCPhysGstCR3Monitored);
|
---|
418 | #endif
|
---|
419 | GEN_CHECK_OFF(PGM, pGst32BitPdR3);
|
---|
420 | #ifndef VBOX_WITH_2X_4GB_ADDR_SPACE
|
---|
421 | GEN_CHECK_OFF(PGM, pGst32BitPdR0);
|
---|
422 | #endif
|
---|
423 | GEN_CHECK_OFF(PGM, pGst32BitPdRC);
|
---|
424 | GEN_CHECK_OFF(PGM, pGstPaePdptR3);
|
---|
425 | #ifndef VBOX_WITH_2X_4GB_ADDR_SPACE
|
---|
426 | GEN_CHECK_OFF(PGM, pGstPaePdptR0);
|
---|
427 | #endif
|
---|
428 | GEN_CHECK_OFF(PGM, pGstPaePdptRC);
|
---|
429 | GEN_CHECK_OFF(PGM, apGstPaePDsR3);
|
---|
430 | #ifndef VBOX_WITH_2X_4GB_ADDR_SPACE
|
---|
431 | GEN_CHECK_OFF(PGM, apGstPaePDsR0);
|
---|
432 | #endif
|
---|
433 | GEN_CHECK_OFF(PGM, apGstPaePDsRC);
|
---|
434 | GEN_CHECK_OFF(PGM, aGCPhysGstPaePDs);
|
---|
435 | GEN_CHECK_OFF(PGM, aGCPhysGstPaePDsMonitored);
|
---|
436 | #ifndef VBOX_WITH_PGMPOOL_PAGING_ONLY
|
---|
437 | GEN_CHECK_OFF(PGM, pShw32BitPdR3);
|
---|
438 | # ifndef VBOX_WITH_2X_4GB_ADDR_SPACE
|
---|
439 | GEN_CHECK_OFF(PGM, pShw32BitPdR0);
|
---|
440 | # endif
|
---|
441 | GEN_CHECK_OFF(PGM, pShw32BitPdRC);
|
---|
442 | GEN_CHECK_OFF(PGM, HCPhysShw32BitPD);
|
---|
443 | GEN_CHECK_OFF(PGM, apShwPaePDsR3);
|
---|
444 | # ifndef VBOX_WITH_2X_4GB_ADDR_SPACE
|
---|
445 | GEN_CHECK_OFF(PGM, apShwPaePDsR0);
|
---|
446 | # endif
|
---|
447 | GEN_CHECK_OFF(PGM, apShwPaePDsRC);
|
---|
448 | GEN_CHECK_OFF(PGM, aHCPhysPaePDs);
|
---|
449 | GEN_CHECK_OFF(PGM, pShwPaePdptR3);
|
---|
450 | GEN_CHECK_OFF(PGM, pShwPaePdptR0);
|
---|
451 | GEN_CHECK_OFF(PGM, pShwPaePdptRC);
|
---|
452 | GEN_CHECK_OFF(PGM, HCPhysShwPaePdpt);
|
---|
453 | #endif
|
---|
454 | GEN_CHECK_OFF(PGM, pShwRootR3);
|
---|
455 | #ifndef VBOX_WITH_2X_4GB_ADDR_SPACE
|
---|
456 | GEN_CHECK_OFF(PGM, pShwRootR0);
|
---|
457 | #endif
|
---|
458 | GEN_CHECK_OFF(PGM, HCPhysShwCR3);
|
---|
459 | GEN_CHECK_OFF(PGM, pShwPageCR3R3);
|
---|
460 | GEN_CHECK_OFF(PGM, pShwPageCR3R0);
|
---|
461 | GEN_CHECK_OFF(PGM, pShwPageCR3RC);
|
---|
462 | GEN_CHECK_OFF(PGM, pfnR3ShwRelocate);
|
---|
463 | GEN_CHECK_OFF(PGM, pfnR3ShwExit);
|
---|
464 | GEN_CHECK_OFF(PGM, pfnR3ShwGetPage);
|
---|
465 | GEN_CHECK_OFF(PGM, pfnR3ShwModifyPage);
|
---|
466 | GEN_CHECK_OFF(PGM, pfnRCShwGetPage);
|
---|
467 | GEN_CHECK_OFF(PGM, pfnRCShwModifyPage);
|
---|
468 | GEN_CHECK_OFF(PGM, pfnR3GstRelocate);
|
---|
469 | GEN_CHECK_OFF(PGM, pfnR3GstExit);
|
---|
470 | #ifndef VBOX_WITH_PGMPOOL_PAGING_ONLY
|
---|
471 | GEN_CHECK_OFF(PGM, pfnR3GstMonitorCR3);
|
---|
472 | GEN_CHECK_OFF(PGM, pfnR3GstUnmonitorCR3);
|
---|
473 | #endif
|
---|
474 | GEN_CHECK_OFF(PGM, pfnR3BthMapCR3);
|
---|
475 | GEN_CHECK_OFF(PGM, pfnR3BthUnmapCR3);
|
---|
476 | GEN_CHECK_OFF(PGM, pfnR3GstGetPage);
|
---|
477 | GEN_CHECK_OFF(PGM, pfnR3GstModifyPage);
|
---|
478 | GEN_CHECK_OFF(PGM, pfnR3GstGetPDE);
|
---|
479 | GEN_CHECK_OFF(PGM, pfnRCGstGetPage);
|
---|
480 | GEN_CHECK_OFF(PGM, pfnRCGstModifyPage);
|
---|
481 | GEN_CHECK_OFF(PGM, pfnRCGstGetPDE);
|
---|
482 | GEN_CHECK_OFF(PGM, pfnR3BthRelocate);
|
---|
483 | GEN_CHECK_OFF(PGM, pfnR3BthSyncCR3);
|
---|
484 | GEN_CHECK_OFF(PGM, pfnR3BthInvalidatePage);
|
---|
485 | GEN_CHECK_OFF(PGM, pfnR3BthSyncPage);
|
---|
486 | GEN_CHECK_OFF(PGM, pfnR3BthPrefetchPage);
|
---|
487 | GEN_CHECK_OFF(PGM, pfnR3BthVerifyAccessSyncPage);
|
---|
488 | GEN_CHECK_OFF(PGM, pfnR3BthAssertCR3);
|
---|
489 | GEN_CHECK_OFF(PGM, pfnRCBthTrap0eHandler);
|
---|
490 | GEN_CHECK_OFF(PGM, pfnRCBthInvalidatePage);
|
---|
491 | GEN_CHECK_OFF(PGM, pfnRCBthSyncPage);
|
---|
492 | GEN_CHECK_OFF(PGM, pfnRCBthPrefetchPage);
|
---|
493 | GEN_CHECK_OFF(PGM, pfnRCBthVerifyAccessSyncPage);
|
---|
494 | GEN_CHECK_OFF(PGM, pfnRCBthAssertCR3);
|
---|
495 | GEN_CHECK_OFF(PGM, pRamRangesR3);
|
---|
496 | GEN_CHECK_OFF(PGM, pRamRangesR0);
|
---|
497 | GEN_CHECK_OFF(PGM, pRamRangesRC);
|
---|
498 | GEN_CHECK_OFF(PGM, pRomRangesR3);
|
---|
499 | GEN_CHECK_OFF(PGM, pRomRangesR0);
|
---|
500 | GEN_CHECK_OFF(PGM, pRomRangesRC);
|
---|
501 | GEN_CHECK_OFF(PGM, cbRamSize);
|
---|
502 | GEN_CHECK_OFF(PGM, pTreesR3);
|
---|
503 | GEN_CHECK_OFF(PGM, pTreesR0);
|
---|
504 | GEN_CHECK_OFF(PGM, pTreesRC);
|
---|
505 | GEN_CHECK_OFF(PGM, pMappingsR3);
|
---|
506 | GEN_CHECK_OFF(PGM, pMappingsRC);
|
---|
507 | GEN_CHECK_OFF(PGM, pMappingsR0);
|
---|
508 | GEN_CHECK_OFF(PGM, fFinalizedMappings);
|
---|
509 | GEN_CHECK_OFF(PGM, fMappingsFixed);
|
---|
510 | GEN_CHECK_OFF(PGM, GCPtrMappingFixed);
|
---|
511 | GEN_CHECK_OFF(PGM, cbMappingFixed);
|
---|
512 | GEN_CHECK_OFF(PGM, pInterPD);
|
---|
513 | GEN_CHECK_OFF(PGM, apInterPTs);
|
---|
514 | GEN_CHECK_OFF(PGM, apInterPaePTs);
|
---|
515 | GEN_CHECK_OFF(PGM, apInterPaePDs);
|
---|
516 | GEN_CHECK_OFF(PGM, pInterPaePDPT);
|
---|
517 | GEN_CHECK_OFF(PGM, pInterPaePDPT64);
|
---|
518 | GEN_CHECK_OFF(PGM, pInterPaePML4);
|
---|
519 | GEN_CHECK_OFF(PGM, HCPhysInterPD);
|
---|
520 | GEN_CHECK_OFF(PGM, HCPhysInterPaePDPT);
|
---|
521 | GEN_CHECK_OFF(PGM, HCPhysInterPaePML4);
|
---|
522 | GEN_CHECK_OFF(PGM, pbDynPageMapBaseGC);
|
---|
523 | GEN_CHECK_OFF(PGM, iDynPageMapLast);
|
---|
524 | GEN_CHECK_OFF(PGM, aHCPhysDynPageMapCache);
|
---|
525 | GEN_CHECK_OFF(PGM, pvR0DynMapUsed);
|
---|
526 | GEN_CHECK_OFF(PGM, GCPhys4MBPSEMask);
|
---|
527 | GEN_CHECK_OFF(PGM, GCPhysA20Mask);
|
---|
528 | GEN_CHECK_OFF(PGM, fA20Enabled);
|
---|
529 | GEN_CHECK_OFF(PGM, fSyncFlags);
|
---|
530 | GEN_CHECK_OFF(PGM, CritSect);
|
---|
531 | GEN_CHECK_OFF(PGM, pPoolR3);
|
---|
532 | GEN_CHECK_OFF(PGM, pPoolR0);
|
---|
533 | GEN_CHECK_OFF(PGM, pPoolRC);
|
---|
534 | GEN_CHECK_OFF(PGM, fNoMorePhysWrites);
|
---|
535 | GEN_CHECK_OFF(PGM, fPhysCacheFlushPending);
|
---|
536 | GEN_CHECK_OFF(PGM, pgmphysreadcache);
|
---|
537 | GEN_CHECK_OFF(PGM, pgmphyswritecache);
|
---|
538 | GEN_CHECK_OFF(PGM, ChunkR3Map);
|
---|
539 | GEN_CHECK_OFF(PGM, ChunkR3Map.pTree);
|
---|
540 | GEN_CHECK_OFF(PGM, ChunkR3Map.Tlb);
|
---|
541 | GEN_CHECK_OFF(PGM, ChunkR3Map.c);
|
---|
542 | GEN_CHECK_OFF(PGM, ChunkR3Map.cMax);
|
---|
543 | GEN_CHECK_OFF(PGM, ChunkR3Map.iNow);
|
---|
544 | GEN_CHECK_OFF(PGM, ChunkR3Map.AgeingCountdown);
|
---|
545 | GEN_CHECK_OFF(PGM, PhysTlbHC);
|
---|
546 | GEN_CHECK_OFF(PGM, PhysTlbHC.aEntries[0]);
|
---|
547 | GEN_CHECK_OFF(PGM, PhysTlbHC.aEntries[1]);
|
---|
548 | GEN_CHECK_OFF(PGM, PhysTlbHC.aEntries[1].GCPhys);
|
---|
549 | GEN_CHECK_OFF(PGM, PhysTlbHC.aEntries[1].pMap);
|
---|
550 | GEN_CHECK_OFF(PGM, PhysTlbHC.aEntries[1].pPage);
|
---|
551 | GEN_CHECK_OFF(PGM, PhysTlbHC.aEntries[1].pv);
|
---|
552 | GEN_CHECK_OFF(PGM, HCPhysZeroPg);
|
---|
553 | GEN_CHECK_OFF(PGM, pvZeroPgR3);
|
---|
554 | GEN_CHECK_OFF(PGM, pvZeroPgR0);
|
---|
555 | GEN_CHECK_OFF(PGM, pvZeroPgGC);
|
---|
556 | GEN_CHECK_OFF(PGM, cHandyPages);
|
---|
557 | GEN_CHECK_OFF(PGM, aHandyPages);
|
---|
558 | GEN_CHECK_OFF(PGM, aHandyPages[1]);
|
---|
559 | GEN_CHECK_OFF(PGM, aHandyPages[1].HCPhysGCPhys);
|
---|
560 | GEN_CHECK_OFF(PGM, aHandyPages[1].idPage);
|
---|
561 | GEN_CHECK_OFF(PGM, aHandyPages[1].idSharedPage);
|
---|
562 | GEN_CHECK_OFF(PGM, cAllPages);
|
---|
563 | GEN_CHECK_OFF(PGM, cPrivatePages);
|
---|
564 | GEN_CHECK_OFF(PGM, cSharedPages);
|
---|
565 | GEN_CHECK_OFF(PGM, cZeroPages);
|
---|
566 | GEN_CHECK_OFF(PGM, cGuestModeChanges);
|
---|
567 | #ifdef VBOX_WITH_STATISTICS
|
---|
568 | GEN_CHECK_OFF(PGM, pStatTrap0eAttributionR0);
|
---|
569 | GEN_CHECK_OFF(PGM, pStatTrap0eAttributionRC);
|
---|
570 | #endif
|
---|
571 |
|
---|
572 | GEN_CHECK_SIZE(PGMMAPPING);
|
---|
573 | GEN_CHECK_OFF(PGMMAPPING, pNextR3);
|
---|
574 | GEN_CHECK_OFF(PGMMAPPING, pNextRC);
|
---|
575 | GEN_CHECK_OFF(PGMMAPPING, pNextR0);
|
---|
576 | GEN_CHECK_OFF(PGMMAPPING, GCPtr);
|
---|
577 | GEN_CHECK_OFF(PGMMAPPING, GCPtrLast);
|
---|
578 | GEN_CHECK_OFF(PGMMAPPING, cb);
|
---|
579 | GEN_CHECK_OFF(PGMMAPPING, pfnRelocate);
|
---|
580 | GEN_CHECK_OFF(PGMMAPPING, pvUser);
|
---|
581 | GEN_CHECK_OFF(PGMMAPPING, pszDesc);
|
---|
582 | GEN_CHECK_OFF(PGMMAPPING, cPTs);
|
---|
583 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].HCPhysPT);
|
---|
584 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].pPTR3);
|
---|
585 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].pPTR0);
|
---|
586 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].pPTRC);
|
---|
587 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].HCPhysPaePT0);
|
---|
588 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].HCPhysPaePT1);
|
---|
589 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].paPaePTsR3);
|
---|
590 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].paPaePTsRC);
|
---|
591 | GEN_CHECK_OFF(PGMMAPPING, aPTs[1].paPaePTsR0);
|
---|
592 | GEN_CHECK_SIZE(PGMPHYSHANDLER);
|
---|
593 | GEN_CHECK_OFF(PGMPHYSHANDLER, Core);
|
---|
594 | GEN_CHECK_SIZE(((PPGMPHYSHANDLER)0)->Core);
|
---|
595 | GEN_CHECK_OFF(PGMPHYSHANDLER, enmType);
|
---|
596 | GEN_CHECK_OFF(PGMPHYSHANDLER, cPages);
|
---|
597 | GEN_CHECK_OFF(PGMPHYSHANDLER, pfnHandlerR3);
|
---|
598 | GEN_CHECK_OFF(PGMPHYSHANDLER, pvUserR3);
|
---|
599 | GEN_CHECK_OFF(PGMPHYSHANDLER, pfnHandlerR0);
|
---|
600 | GEN_CHECK_OFF(PGMPHYSHANDLER, pvUserR0);
|
---|
601 | GEN_CHECK_OFF(PGMPHYSHANDLER, pfnHandlerRC);
|
---|
602 | GEN_CHECK_OFF(PGMPHYSHANDLER, pvUserRC);
|
---|
603 | GEN_CHECK_OFF(PGMPHYSHANDLER, pszDesc);
|
---|
604 | GEN_CHECK_SIZE(PGMPHYS2VIRTHANDLER);
|
---|
605 | GEN_CHECK_OFF(PGMPHYS2VIRTHANDLER, Core);
|
---|
606 | GEN_CHECK_OFF(PGMPHYS2VIRTHANDLER, offVirtHandler);
|
---|
607 | GEN_CHECK_SIZE(PGMVIRTHANDLER);
|
---|
608 | GEN_CHECK_OFF(PGMVIRTHANDLER, Core);
|
---|
609 | GEN_CHECK_OFF(PGMVIRTHANDLER, enmType);
|
---|
610 | GEN_CHECK_OFF(PGMVIRTHANDLER, cb);
|
---|
611 | GEN_CHECK_OFF(PGMVIRTHANDLER, pfnHandlerR3);
|
---|
612 | GEN_CHECK_OFF(PGMVIRTHANDLER, pfnHandlerRC);
|
---|
613 | GEN_CHECK_OFF(PGMVIRTHANDLER, pszDesc);
|
---|
614 | GEN_CHECK_OFF(PGMVIRTHANDLER, cPages);
|
---|
615 | GEN_CHECK_OFF(PGMVIRTHANDLER, aPhysToVirt);
|
---|
616 | GEN_CHECK_SIZE(PGMPAGE);
|
---|
617 | GEN_CHECK_OFF(PGMPAGE, HCPhysX);
|
---|
618 | GEN_CHECK_SIZE(PGMRAMRANGE);
|
---|
619 | GEN_CHECK_OFF(PGMRAMRANGE, pNextR3);
|
---|
620 | GEN_CHECK_OFF(PGMRAMRANGE, pNextR0);
|
---|
621 | GEN_CHECK_OFF(PGMRAMRANGE, pNextRC);
|
---|
622 | GEN_CHECK_OFF(PGMRAMRANGE, GCPhys);
|
---|
623 | GEN_CHECK_OFF(PGMRAMRANGE, GCPhysLast);
|
---|
624 | GEN_CHECK_OFF(PGMRAMRANGE, cb);
|
---|
625 | GEN_CHECK_OFF(PGMRAMRANGE, fFlags);
|
---|
626 | GEN_CHECK_OFF(PGMRAMRANGE, pvR3);
|
---|
627 | GEN_CHECK_OFF(PGMRAMRANGE, pszDesc);
|
---|
628 | GEN_CHECK_OFF(PGMRAMRANGE, aPages);
|
---|
629 | GEN_CHECK_OFF(PGMRAMRANGE, aPages[1]);
|
---|
630 | GEN_CHECK_SIZE(PGMROMPAGE);
|
---|
631 | GEN_CHECK_OFF(PGMROMPAGE, Virgin);
|
---|
632 | GEN_CHECK_OFF(PGMROMPAGE, Shadow);
|
---|
633 | GEN_CHECK_OFF(PGMROMPAGE, enmProt);
|
---|
634 | GEN_CHECK_SIZE(PGMROMRANGE);
|
---|
635 | GEN_CHECK_OFF(PGMROMRANGE, pNextR3);
|
---|
636 | GEN_CHECK_OFF(PGMROMRANGE, pNextR0);
|
---|
637 | GEN_CHECK_OFF(PGMROMRANGE, pNextRC);
|
---|
638 | GEN_CHECK_OFF(PGMROMRANGE, GCPhys);
|
---|
639 | GEN_CHECK_OFF(PGMROMRANGE, GCPhysLast);
|
---|
640 | GEN_CHECK_OFF(PGMROMRANGE, cb);
|
---|
641 | GEN_CHECK_OFF(PGMROMRANGE, fFlags);
|
---|
642 | GEN_CHECK_OFF(PGMROMRANGE, pvOriginal);
|
---|
643 | GEN_CHECK_OFF(PGMROMRANGE, pszDesc);
|
---|
644 | GEN_CHECK_OFF(PGMROMRANGE, aPages);
|
---|
645 | GEN_CHECK_OFF(PGMROMRANGE, aPages[1]);
|
---|
646 | GEN_CHECK_SIZE(PGMMMIO2RANGE);
|
---|
647 | GEN_CHECK_OFF(PGMMMIO2RANGE, pDevInsR3);
|
---|
648 | GEN_CHECK_OFF(PGMMMIO2RANGE, pNextR3);
|
---|
649 | GEN_CHECK_OFF(PGMMMIO2RANGE, fMapped);
|
---|
650 | GEN_CHECK_OFF(PGMMMIO2RANGE, fOverlapping);
|
---|
651 | GEN_CHECK_OFF(PGMMMIO2RANGE, iRegion);
|
---|
652 | GEN_CHECK_OFF(PGMMMIO2RANGE, RamRange);
|
---|
653 | GEN_CHECK_SIZE(PGMTREES);
|
---|
654 | GEN_CHECK_OFF(PGMTREES, PhysHandlers);
|
---|
655 | GEN_CHECK_OFF(PGMTREES, VirtHandlers);
|
---|
656 | GEN_CHECK_OFF(PGMTREES, PhysToVirtHandlers);
|
---|
657 | GEN_CHECK_OFF(PGMTREES, HyperVirtHandlers);
|
---|
658 | GEN_CHECK_SIZE(PGMPOOLPAGE);
|
---|
659 | GEN_CHECK_OFF(PGMPOOLPAGE, Core);
|
---|
660 | GEN_CHECK_OFF(PGMPOOLPAGE, GCPhys);
|
---|
661 | GEN_CHECK_OFF(PGMPOOLPAGE, pvPageR3);
|
---|
662 | GEN_CHECK_OFF(PGMPOOLPAGE, enmKind);
|
---|
663 | GEN_CHECK_OFF(PGMPOOLPAGE, bPadding);
|
---|
664 | GEN_CHECK_OFF(PGMPOOLPAGE, idx);
|
---|
665 | GEN_CHECK_OFF(PGMPOOLPAGE, iNext);
|
---|
666 | #ifdef PGMPOOL_WITH_USER_TRACKING
|
---|
667 | GEN_CHECK_OFF(PGMPOOLPAGE, iUserHead);
|
---|
668 | GEN_CHECK_OFF(PGMPOOLPAGE, cPresent);
|
---|
669 | GEN_CHECK_OFF(PGMPOOLPAGE, iFirstPresent);
|
---|
670 | #endif
|
---|
671 | #ifdef PGMPOOL_WITH_MONITORING
|
---|
672 | GEN_CHECK_OFF(PGMPOOLPAGE, cModifications);
|
---|
673 | GEN_CHECK_OFF(PGMPOOLPAGE, iModifiedNext);
|
---|
674 | GEN_CHECK_OFF(PGMPOOLPAGE, iModifiedPrev);
|
---|
675 | GEN_CHECK_OFF(PGMPOOLPAGE, iMonitoredNext);
|
---|
676 | GEN_CHECK_OFF(PGMPOOLPAGE, iMonitoredPrev);
|
---|
677 | #endif
|
---|
678 | #ifdef PGMPOOL_WITH_CACHE
|
---|
679 | GEN_CHECK_OFF(PGMPOOLPAGE, iAgeNext);
|
---|
680 | GEN_CHECK_OFF(PGMPOOLPAGE, iAgePrev);
|
---|
681 | #endif
|
---|
682 | GEN_CHECK_OFF(PGMPOOLPAGE, fZeroed);
|
---|
683 | GEN_CHECK_OFF(PGMPOOLPAGE, fSeenNonGlobal);
|
---|
684 | GEN_CHECK_OFF(PGMPOOLPAGE, fMonitored);
|
---|
685 | GEN_CHECK_OFF(PGMPOOLPAGE, fCached);
|
---|
686 | GEN_CHECK_OFF(PGMPOOLPAGE, fReusedFlushPending);
|
---|
687 | #ifndef VBOX_WITH_PGMPOOL_PAGING_ONLY
|
---|
688 | GEN_CHECK_OFF(PGMPOOLPAGE, fCR3Mix);
|
---|
689 | #endif
|
---|
690 | GEN_CHECK_SIZE(PGMPOOL);
|
---|
691 | GEN_CHECK_OFF(PGMPOOL, pVMR3);
|
---|
692 | GEN_CHECK_OFF(PGMPOOL, pVMR0);
|
---|
693 | GEN_CHECK_OFF(PGMPOOL, pVMRC);
|
---|
694 | GEN_CHECK_OFF(PGMPOOL, cMaxPages);
|
---|
695 | GEN_CHECK_OFF(PGMPOOL, cCurPages);
|
---|
696 | GEN_CHECK_OFF(PGMPOOL, iFreeHead);
|
---|
697 | GEN_CHECK_OFF(PGMPOOL, u16Padding);
|
---|
698 | #ifdef PGMPOOL_WITH_USER_TRACKING
|
---|
699 | GEN_CHECK_OFF(PGMPOOL, iUserFreeHead);
|
---|
700 | GEN_CHECK_OFF(PGMPOOL, cMaxUsers);
|
---|
701 | GEN_CHECK_OFF(PGMPOOL, cPresent);
|
---|
702 | GEN_CHECK_OFF(PGMPOOL, paUsersR3);
|
---|
703 | GEN_CHECK_OFF(PGMPOOL, paUsersR0);
|
---|
704 | GEN_CHECK_OFF(PGMPOOL, paUsersRC);
|
---|
705 | #endif /* PGMPOOL_WITH_USER_TRACKING */
|
---|
706 | #ifdef PGMPOOL_WITH_GCPHYS_TRACKING
|
---|
707 | GEN_CHECK_OFF(PGMPOOL, iPhysExtFreeHead);
|
---|
708 | GEN_CHECK_OFF(PGMPOOL, cMaxPhysExts);
|
---|
709 | GEN_CHECK_OFF(PGMPOOL, paPhysExtsR3);
|
---|
710 | GEN_CHECK_OFF(PGMPOOL, paPhysExtsR0);
|
---|
711 | GEN_CHECK_OFF(PGMPOOL, paPhysExtsRC);
|
---|
712 | #endif
|
---|
713 | #ifdef PGMPOOL_WITH_CACHE
|
---|
714 | GEN_CHECK_OFF(PGMPOOL, aiHash);
|
---|
715 | GEN_CHECK_OFF(PGMPOOL, iAgeHead);
|
---|
716 | GEN_CHECK_OFF(PGMPOOL, iAgeTail);
|
---|
717 | GEN_CHECK_OFF(PGMPOOL, fCacheEnabled);
|
---|
718 | #endif
|
---|
719 | #ifdef PGMPOOL_WITH_MONITORING
|
---|
720 | GEN_CHECK_OFF(PGMPOOL, pfnAccessHandlerRC);
|
---|
721 | GEN_CHECK_OFF(PGMPOOL, pfnAccessHandlerR0);
|
---|
722 | GEN_CHECK_OFF(PGMPOOL, pfnAccessHandlerR3);
|
---|
723 | GEN_CHECK_OFF(PGMPOOL, pszAccessHandler);
|
---|
724 | GEN_CHECK_OFF(PGMPOOL, iModifiedHead);
|
---|
725 | GEN_CHECK_OFF(PGMPOOL, cModifiedPages);
|
---|
726 | #endif
|
---|
727 | GEN_CHECK_OFF(PGMPOOL, cUsedPages);
|
---|
728 | #ifdef VBOX_WITH_STATISTICS
|
---|
729 | GEN_CHECK_OFF(PGMPOOL, cUsedPagesHigh);
|
---|
730 | GEN_CHECK_OFF(PGMPOOL, StatAlloc);
|
---|
731 | GEN_CHECK_OFF(PGMPOOL, StatClearAll);
|
---|
732 | #endif
|
---|
733 | GEN_CHECK_OFF(PGMPOOL, HCPhysTree);
|
---|
734 | GEN_CHECK_OFF(PGMPOOL, aPages);
|
---|
735 | GEN_CHECK_OFF(PGMPOOL, aPages[1]);
|
---|
736 | GEN_CHECK_OFF(PGMPOOL, aPages[PGMPOOL_IDX_FIRST - 1]);
|
---|
737 |
|
---|
738 | GEN_CHECK_SIZE(REM);
|
---|
739 | GEN_CHECK_OFF(REM, pCtx);
|
---|
740 | GEN_CHECK_OFF(REM, cCanExecuteRaw);
|
---|
741 | GEN_CHECK_OFF(REM, aGCPtrInvalidatedPages);
|
---|
742 | GEN_CHECK_OFF(REM, cHandlerNotifications);
|
---|
743 | GEN_CHECK_OFF(REM, aHandlerNotifications);
|
---|
744 | GEN_CHECK_OFF(REM, paHCVirtToGCPhys);
|
---|
745 | GEN_CHECK_OFF(REM, cPhysRegistrations);
|
---|
746 | GEN_CHECK_OFF(REM, aPhysReg);
|
---|
747 | GEN_CHECK_OFF(REM, rc);
|
---|
748 | GEN_CHECK_OFF(REM, StatsInQEMU);
|
---|
749 | GEN_CHECK_OFF(REM, Env);
|
---|
750 |
|
---|
751 | GEN_CHECK_SIZE(SELM);
|
---|
752 | GEN_CHECK_OFF(SELM, offVM);
|
---|
753 | GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_CS]);
|
---|
754 | GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_DS]);
|
---|
755 | GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_CS64]);
|
---|
756 | GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_TSS]);
|
---|
757 | GEN_CHECK_OFF(SELM, aHyperSel[SELM_HYPER_SEL_TSS_TRAP08]);
|
---|
758 | GEN_CHECK_OFF(SELM, paGdtR3);
|
---|
759 | GEN_CHECK_OFF(SELM, paGdtRC);
|
---|
760 | GEN_CHECK_OFF(SELM, GuestGdtr);
|
---|
761 | GEN_CHECK_OFF(SELM, cbEffGuestGdtLimit);
|
---|
762 | GEN_CHECK_OFF(SELM, pvLdtR3);
|
---|
763 | GEN_CHECK_OFF(SELM, pvLdtRC);
|
---|
764 | GEN_CHECK_OFF(SELM, GCPtrGuestLdt);
|
---|
765 | GEN_CHECK_OFF(SELM, cbLdtLimit);
|
---|
766 | GEN_CHECK_OFF(SELM, offLdtHyper);
|
---|
767 | GEN_CHECK_OFF(SELM, Tss);
|
---|
768 | GEN_CHECK_OFF(SELM, TssTrap08);
|
---|
769 | GEN_CHECK_OFF(SELM, pvMonShwTssRC);
|
---|
770 | GEN_CHECK_OFF(SELM, GCPtrGuestTss);
|
---|
771 | GEN_CHECK_OFF(SELM, cbGuestTss);
|
---|
772 | GEN_CHECK_OFF(SELM, fGuestTss32Bit);
|
---|
773 | GEN_CHECK_OFF(SELM, cbMonitoredGuestTss);
|
---|
774 | GEN_CHECK_OFF(SELM, GCSelTss);
|
---|
775 | GEN_CHECK_OFF(SELM, fGDTRangeRegistered);
|
---|
776 | GEN_CHECK_OFF(SELM, StatUpdateFromCPUM);
|
---|
777 |
|
---|
778 | GEN_CHECK_SIZE(TM);
|
---|
779 | GEN_CHECK_OFF(TM, offVM);
|
---|
780 | GEN_CHECK_OFF(TM, pvGIPR3);
|
---|
781 | //GEN_CHECK_OFF(TM, pvGIPR0);
|
---|
782 | GEN_CHECK_OFF(TM, pvGIPRC);
|
---|
783 | GEN_CHECK_OFF(TM, fTSCTicking);
|
---|
784 | GEN_CHECK_OFF(TM, fTSCUseRealTSC);
|
---|
785 | GEN_CHECK_OFF(TM, fTSCTiedToExecution);
|
---|
786 | GEN_CHECK_OFF(TM, u64TSCOffset);
|
---|
787 | GEN_CHECK_OFF(TM, u64TSC);
|
---|
788 | GEN_CHECK_OFF(TM, cTSCTicksPerSecond);
|
---|
789 | GEN_CHECK_OFF(TM, fVirtualTicking);
|
---|
790 | GEN_CHECK_OFF(TM, fVirtualWarpDrive);
|
---|
791 | GEN_CHECK_OFF(TM, fVirtualSyncTicking);
|
---|
792 | GEN_CHECK_OFF(TM, fVirtualSyncCatchUp);
|
---|
793 | GEN_CHECK_OFF(TM, u32VirtualWarpDrivePercentage);
|
---|
794 | GEN_CHECK_OFF(TM, u64VirtualOffset);
|
---|
795 | GEN_CHECK_OFF(TM, u64Virtual);
|
---|
796 | GEN_CHECK_OFF(TM, u64VirtualRawPrev);
|
---|
797 | GEN_CHECK_OFF(TM, VirtualGetRawDataR3);
|
---|
798 | GEN_CHECK_OFF(TM, VirtualGetRawDataR3.pu64Prev);
|
---|
799 | GEN_CHECK_OFF(TM, VirtualGetRawDataR3.pfnBad);
|
---|
800 | GEN_CHECK_OFF(TM, VirtualGetRawDataR3.pfnRediscover);
|
---|
801 | GEN_CHECK_OFF(TM, VirtualGetRawDataR3.c1nsSteps);
|
---|
802 | GEN_CHECK_OFF(TM, VirtualGetRawDataR3.cBadPrev);
|
---|
803 | GEN_CHECK_OFF(TM, VirtualGetRawDataR3.cExpired);
|
---|
804 | GEN_CHECK_OFF(TM, VirtualGetRawDataR3.cUpdateRaces);
|
---|
805 | GEN_CHECK_OFF(TM, VirtualGetRawDataR0);
|
---|
806 | GEN_CHECK_OFF(TM, VirtualGetRawDataR0.pu64Prev);
|
---|
807 | GEN_CHECK_OFF(TM, VirtualGetRawDataR0.pfnBad);
|
---|
808 | GEN_CHECK_OFF(TM, VirtualGetRawDataR0.pfnRediscover);
|
---|
809 | GEN_CHECK_OFF(TM, VirtualGetRawDataR0.c1nsSteps);
|
---|
810 | GEN_CHECK_OFF(TM, VirtualGetRawDataR0.cBadPrev);
|
---|
811 | GEN_CHECK_OFF(TM, VirtualGetRawDataR0.cExpired);
|
---|
812 | GEN_CHECK_OFF(TM, VirtualGetRawDataR0.cUpdateRaces);
|
---|
813 | GEN_CHECK_OFF(TM, VirtualGetRawDataRC);
|
---|
814 | GEN_CHECK_OFF(TM, VirtualGetRawDataRC.pu64Prev);
|
---|
815 | GEN_CHECK_OFF(TM, VirtualGetRawDataRC.pfnBad);
|
---|
816 | GEN_CHECK_OFF(TM, VirtualGetRawDataRC.pfnRediscover);
|
---|
817 | GEN_CHECK_OFF(TM, VirtualGetRawDataRC.c1nsSteps);
|
---|
818 | GEN_CHECK_OFF(TM, VirtualGetRawDataRC.cBadPrev);
|
---|
819 | GEN_CHECK_OFF(TM, VirtualGetRawDataRC.cExpired);
|
---|
820 | GEN_CHECK_OFF(TM, VirtualGetRawDataRC.cUpdateRaces);
|
---|
821 | GEN_CHECK_OFF(TM, pfnVirtualGetRawR3);
|
---|
822 | GEN_CHECK_OFF(TM, pfnVirtualGetRawR0);
|
---|
823 | GEN_CHECK_OFF(TM, pfnVirtualGetRawRC);
|
---|
824 | GEN_CHECK_OFF(TM, u64VirtualWarpDriveStart);
|
---|
825 | GEN_CHECK_OFF(TM, u64VirtualSync);
|
---|
826 | GEN_CHECK_OFF(TM, offVirtualSync);
|
---|
827 | GEN_CHECK_OFF(TM, offVirtualSyncGivenUp);
|
---|
828 | GEN_CHECK_OFF(TM, u64VirtualSyncCatchUpPrev);
|
---|
829 | GEN_CHECK_OFF(TM, u32VirtualSyncCatchUpPercentage);
|
---|
830 | GEN_CHECK_OFF(TM, u32VirtualSyncScheduleSlack);
|
---|
831 | GEN_CHECK_OFF(TM, u64VirtualSyncCatchUpStopThreshold);
|
---|
832 | GEN_CHECK_OFF(TM, u64VirtualSyncCatchUpGiveUpThreshold);
|
---|
833 | GEN_CHECK_OFF(TM, aVirtualSyncCatchUpPeriods);
|
---|
834 | GEN_CHECK_OFF(TM, aVirtualSyncCatchUpPeriods[0].u64Start);
|
---|
835 | GEN_CHECK_OFF(TM, aVirtualSyncCatchUpPeriods[0].u32Percentage);
|
---|
836 | GEN_CHECK_OFF(TM, aVirtualSyncCatchUpPeriods[1].u64Start);
|
---|
837 | GEN_CHECK_OFF(TM, aVirtualSyncCatchUpPeriods[1].u32Percentage);
|
---|
838 | GEN_CHECK_OFF(TM, pTimer);
|
---|
839 | GEN_CHECK_OFF(TM, u32TimerMillies);
|
---|
840 | GEN_CHECK_OFF(TM, pFree);
|
---|
841 | GEN_CHECK_OFF(TM, pCreated);
|
---|
842 | GEN_CHECK_OFF(TM, paTimerQueuesR3);
|
---|
843 | GEN_CHECK_OFF(TM, paTimerQueuesR0);
|
---|
844 | GEN_CHECK_OFF(TM, paTimerQueuesRC);
|
---|
845 | GEN_CHECK_OFF(TM, StatDoQueues);
|
---|
846 | GEN_CHECK_OFF(TM, StatTimerCallbackSetFF);
|
---|
847 | GEN_CHECK_SIZE(TMTIMER);
|
---|
848 | GEN_CHECK_OFF(TMTIMER, u64Expire);
|
---|
849 | GEN_CHECK_OFF(TMTIMER, enmClock);
|
---|
850 | GEN_CHECK_OFF(TMTIMER, enmType);
|
---|
851 | GEN_CHECK_OFF(TMTIMER, u.Dev.pfnTimer);
|
---|
852 | GEN_CHECK_OFF(TMTIMER, u.Dev.pDevIns);
|
---|
853 | GEN_CHECK_OFF(TMTIMER, u.Drv.pfnTimer);
|
---|
854 | GEN_CHECK_OFF(TMTIMER, u.Drv.pDrvIns);
|
---|
855 | GEN_CHECK_OFF(TMTIMER, u.Internal.pfnTimer);
|
---|
856 | GEN_CHECK_OFF(TMTIMER, u.Internal.pvUser);
|
---|
857 | GEN_CHECK_OFF(TMTIMER, u.External.pfnTimer);
|
---|
858 | GEN_CHECK_OFF(TMTIMER, u.External.pvUser);
|
---|
859 | GEN_CHECK_OFF(TMTIMER, enmState);
|
---|
860 | GEN_CHECK_OFF(TMTIMER, offScheduleNext);
|
---|
861 | GEN_CHECK_OFF(TMTIMER, offNext);
|
---|
862 | GEN_CHECK_OFF(TMTIMER, offPrev);
|
---|
863 | GEN_CHECK_OFF(TMTIMER, pBigNext);
|
---|
864 | GEN_CHECK_OFF(TMTIMER, pBigPrev);
|
---|
865 | GEN_CHECK_OFF(TMTIMER, pszDesc);
|
---|
866 | GEN_CHECK_OFF(TMTIMER, pVMR0);
|
---|
867 | GEN_CHECK_OFF(TMTIMER, pVMR3);
|
---|
868 | GEN_CHECK_OFF(TMTIMER, pVMRC);
|
---|
869 | GEN_CHECK_SIZE(TMTIMERQUEUE);
|
---|
870 | GEN_CHECK_OFF(TMTIMERQUEUE, offActive);
|
---|
871 | GEN_CHECK_OFF(TMTIMERQUEUE, offSchedule);
|
---|
872 | GEN_CHECK_OFF(TMTIMERQUEUE, enmClock);
|
---|
873 |
|
---|
874 | GEN_CHECK_SIZE(TRPM); // has .mac
|
---|
875 | GEN_CHECK_SIZE(VM); // has .mac
|
---|
876 | GEN_CHECK_SIZE(VMM);
|
---|
877 | GEN_CHECK_OFF(VMM, offVM);
|
---|
878 | GEN_CHECK_OFF(VMM, cbCoreCode);
|
---|
879 | GEN_CHECK_OFF(VMM, HCPhysCoreCode);
|
---|
880 | GEN_CHECK_OFF(VMM, pvCoreCodeR3);
|
---|
881 | GEN_CHECK_OFF(VMM, pvCoreCodeR0);
|
---|
882 | GEN_CHECK_OFF(VMM, pvCoreCodeRC);
|
---|
883 | GEN_CHECK_OFF(VMM, enmSwitcher);
|
---|
884 | GEN_CHECK_OFF(VMM, aoffSwitchers);
|
---|
885 | GEN_CHECK_OFF(VMM, aoffSwitchers[1]);
|
---|
886 | GEN_CHECK_OFF(VMM, pfnHostToGuestR0);
|
---|
887 | GEN_CHECK_OFF(VMM, pfnGuestToHostRC);
|
---|
888 | GEN_CHECK_OFF(VMM, pfnCallTrampolineRC);
|
---|
889 | GEN_CHECK_OFF(VMM, pfnCPUMRCResumeGuest);
|
---|
890 | GEN_CHECK_OFF(VMM, pfnCPUMRCResumeGuestV86);
|
---|
891 | GEN_CHECK_OFF(VMM, iLastGZRc);
|
---|
892 | GEN_CHECK_OFF(VMM, pbEMTStackR3);
|
---|
893 | GEN_CHECK_OFF(VMM, pbEMTStackRC);
|
---|
894 | GEN_CHECK_OFF(VMM, pbEMTStackBottomRC);
|
---|
895 | GEN_CHECK_OFF(VMM, pRCLoggerRC);
|
---|
896 | GEN_CHECK_OFF(VMM, pRCLoggerR3);
|
---|
897 | GEN_CHECK_OFF(VMM, pR0LoggerR0);
|
---|
898 | GEN_CHECK_OFF(VMM, pR0LoggerR3);
|
---|
899 | GEN_CHECK_OFF(VMM, cbRCLogger);
|
---|
900 | GEN_CHECK_OFF(VMM, CritSectVMLock);
|
---|
901 | GEN_CHECK_OFF(VMM, pYieldTimer);
|
---|
902 | GEN_CHECK_OFF(VMM, cYieldResumeMillies);
|
---|
903 | GEN_CHECK_OFF(VMM, cYieldEveryMillies);
|
---|
904 | GEN_CHECK_OFF(VMM, enmCallHostOperation);
|
---|
905 | GEN_CHECK_OFF(VMM, rcCallHost);
|
---|
906 | GEN_CHECK_OFF(VMM, u64CallHostArg);
|
---|
907 | GEN_CHECK_OFF(VMM, CallHostR0JmpBuf);
|
---|
908 | GEN_CHECK_OFF(VMM, CallHostR0JmpBuf.SpCheck);
|
---|
909 | GEN_CHECK_OFF(VMM, CallHostR0JmpBuf.SpResume);
|
---|
910 | GEN_CHECK_OFF(VMM, StatRunRC);
|
---|
911 | GEN_CHECK_OFF(VMM, StatRZCallPGMLock);
|
---|
912 |
|
---|
913 | GEN_CHECK_SIZE(RTPINGPONG);
|
---|
914 | GEN_CHECK_SIZE(RTCRITSECT);
|
---|
915 | GEN_CHECK_OFF(RTCRITSECT, u32Magic);
|
---|
916 | GEN_CHECK_OFF(RTCRITSECT, cLockers);
|
---|
917 | GEN_CHECK_OFF(RTCRITSECT, NativeThreadOwner);
|
---|
918 | GEN_CHECK_OFF(RTCRITSECT, cNestings);
|
---|
919 | GEN_CHECK_OFF(RTCRITSECT, fFlags);
|
---|
920 | GEN_CHECK_OFF(RTCRITSECT, EventSem);
|
---|
921 | GEN_CHECK_OFF(RTCRITSECT, Strict.ThreadOwner);
|
---|
922 | GEN_CHECK_OFF(RTCRITSECT, Strict.pszEnterFile);
|
---|
923 | GEN_CHECK_OFF(RTCRITSECT, Strict.u32EnterLine);
|
---|
924 | GEN_CHECK_OFF(RTCRITSECT, Strict.uEnterId);
|
---|
925 |
|
---|
926 |
|
---|
927 | GEN_CHECK_SIZE(CSAM);
|
---|
928 | GEN_CHECK_OFF(CSAM, offVM);
|
---|
929 | GEN_CHECK_OFF(CSAM, pPageTree);
|
---|
930 | GEN_CHECK_OFF(CSAM, aDangerousInstr);
|
---|
931 | GEN_CHECK_OFF(CSAM, aDangerousInstr[1]);
|
---|
932 | GEN_CHECK_OFF(CSAM, aDangerousInstr[CSAM_MAX_DANGR_INSTR - 1]);
|
---|
933 | GEN_CHECK_OFF(CSAM, cDangerousInstr);
|
---|
934 | GEN_CHECK_OFF(CSAM, iDangerousInstr);
|
---|
935 | GEN_CHECK_OFF(CSAM, pPDBitmapGC);
|
---|
936 | GEN_CHECK_OFF(CSAM, pPDHCBitmapGC);
|
---|
937 | GEN_CHECK_OFF(CSAM, pPDBitmapHC);
|
---|
938 | GEN_CHECK_OFF(CSAM, pPDGCBitmapHC);
|
---|
939 | GEN_CHECK_OFF(CSAM, savedstate);
|
---|
940 | GEN_CHECK_OFF(CSAM, savedstate.pSSM);
|
---|
941 | GEN_CHECK_OFF(CSAM, savedstate.cPageRecords);
|
---|
942 | GEN_CHECK_OFF(CSAM, savedstate.cPatchPageRecords);
|
---|
943 | GEN_CHECK_OFF(CSAM, cDirtyPages);
|
---|
944 | GEN_CHECK_OFF(CSAM, pvDirtyBasePage);
|
---|
945 | GEN_CHECK_OFF(CSAM, pvDirtyBasePage[1]);
|
---|
946 | GEN_CHECK_OFF(CSAM, pvDirtyBasePage[CSAM_MAX_DIRTY_PAGES - 1]);
|
---|
947 | GEN_CHECK_OFF(CSAM, pvDirtyFaultPage);
|
---|
948 | GEN_CHECK_OFF(CSAM, pvDirtyFaultPage[1]);
|
---|
949 | GEN_CHECK_OFF(CSAM, pvDirtyFaultPage[CSAM_MAX_DIRTY_PAGES - 1]);
|
---|
950 | GEN_CHECK_OFF(CSAM, pvCallInstruction);
|
---|
951 | GEN_CHECK_OFF(CSAM, iCallInstruction);
|
---|
952 | GEN_CHECK_OFF(CSAM, fScanningStarted);
|
---|
953 | GEN_CHECK_OFF(CSAM, fGatesChecked);
|
---|
954 | GEN_CHECK_OFF(CSAM, StatNrTraps);
|
---|
955 | GEN_CHECK_OFF(CSAM, StatNrPages);
|
---|
956 |
|
---|
957 | GEN_CHECK_SIZE(PATM);
|
---|
958 | GEN_CHECK_OFF(PATM, offVM);
|
---|
959 | GEN_CHECK_OFF(PATM, pPatchMemGC);
|
---|
960 | GEN_CHECK_OFF(PATM, pPatchMemHC);
|
---|
961 | GEN_CHECK_OFF(PATM, cbPatchMem);
|
---|
962 | GEN_CHECK_OFF(PATM, offPatchMem);
|
---|
963 | GEN_CHECK_OFF(PATM, fOutOfMemory);
|
---|
964 | GEN_CHECK_OFF(PATM, deltaReloc);
|
---|
965 | GEN_CHECK_OFF(PATM, pGCStateGC);
|
---|
966 | GEN_CHECK_OFF(PATM, pGCStateHC);
|
---|
967 | GEN_CHECK_OFF(PATM, pGCStackGC);
|
---|
968 | GEN_CHECK_OFF(PATM, pGCStackHC);
|
---|
969 | GEN_CHECK_OFF(PATM, pCPUMCtxGC);
|
---|
970 | GEN_CHECK_OFF(PATM, pStatsGC);
|
---|
971 | GEN_CHECK_OFF(PATM, pStatsHC);
|
---|
972 | GEN_CHECK_OFF(PATM, uCurrentPatchIdx);
|
---|
973 | GEN_CHECK_OFF(PATM, ulCallDepth);
|
---|
974 | GEN_CHECK_OFF(PATM, cPageRecords);
|
---|
975 | GEN_CHECK_OFF(PATM, pPatchedInstrGCLowest);
|
---|
976 | GEN_CHECK_OFF(PATM, pPatchedInstrGCHighest);
|
---|
977 | GEN_CHECK_OFF(PATM, PatchLookupTreeHC);
|
---|
978 | GEN_CHECK_OFF(PATM, PatchLookupTreeGC);
|
---|
979 | GEN_CHECK_OFF(PATM, pfnHelperCallGC);
|
---|
980 | GEN_CHECK_OFF(PATM, pfnHelperRetGC);
|
---|
981 | GEN_CHECK_OFF(PATM, pfnHelperJumpGC);
|
---|
982 | GEN_CHECK_OFF(PATM, pfnHelperIretGC);
|
---|
983 | GEN_CHECK_OFF(PATM, pGlobalPatchRec);
|
---|
984 | GEN_CHECK_OFF(PATM, pfnSysEnterGC);
|
---|
985 | GEN_CHECK_OFF(PATM, pfnSysEnterPatchGC);
|
---|
986 | GEN_CHECK_OFF(PATM, uSysEnterPatchIdx);
|
---|
987 | GEN_CHECK_OFF(PATM, pvFaultMonitor);
|
---|
988 | GEN_CHECK_OFF(PATM, mmio);
|
---|
989 | GEN_CHECK_OFF(PATM, mmio.GCPhys);
|
---|
990 | GEN_CHECK_OFF(PATM, mmio.pCachedData);
|
---|
991 | GEN_CHECK_OFF(PATM, savedstate);
|
---|
992 | GEN_CHECK_OFF(PATM, savedstate.pSSM);
|
---|
993 | GEN_CHECK_OFF(PATM, savedstate.cPatches);
|
---|
994 | GEN_CHECK_OFF(PATM, StatNrOpcodeRead);
|
---|
995 | GEN_CHECK_OFF(PATM, StatU32FunctionMaxSlotsUsed);
|
---|
996 |
|
---|
997 | GEN_CHECK_SIZE(PATMGCSTATE);
|
---|
998 | GEN_CHECK_OFF(PATMGCSTATE, uVMFlags);
|
---|
999 | GEN_CHECK_OFF(PATMGCSTATE, uPendingAction);
|
---|
1000 | GEN_CHECK_OFF(PATMGCSTATE, uPatchCalls);
|
---|
1001 | GEN_CHECK_OFF(PATMGCSTATE, uScratch);
|
---|
1002 | GEN_CHECK_OFF(PATMGCSTATE, uIretEFlags);
|
---|
1003 | GEN_CHECK_OFF(PATMGCSTATE, uIretCS);
|
---|
1004 | GEN_CHECK_OFF(PATMGCSTATE, uIretEIP);
|
---|
1005 | GEN_CHECK_OFF(PATMGCSTATE, Psp);
|
---|
1006 | GEN_CHECK_OFF(PATMGCSTATE, fPIF);
|
---|
1007 | GEN_CHECK_OFF(PATMGCSTATE, GCPtrInhibitInterrupts);
|
---|
1008 | GEN_CHECK_OFF(PATMGCSTATE, Restore);
|
---|
1009 | GEN_CHECK_OFF(PATMGCSTATE, Restore.uEAX);
|
---|
1010 | GEN_CHECK_OFF(PATMGCSTATE, Restore.uECX);
|
---|
1011 | GEN_CHECK_OFF(PATMGCSTATE, Restore.uEDI);
|
---|
1012 | GEN_CHECK_OFF(PATMGCSTATE, Restore.eFlags);
|
---|
1013 | GEN_CHECK_OFF(PATMGCSTATE, Restore.uFlags);
|
---|
1014 | GEN_CHECK_SIZE(PATMTREES);
|
---|
1015 | GEN_CHECK_OFF(PATMTREES, PatchTree);
|
---|
1016 | GEN_CHECK_OFF(PATMTREES, PatchTreeByPatchAddr);
|
---|
1017 | GEN_CHECK_OFF(PATMTREES, PatchTreeByPage);
|
---|
1018 | GEN_CHECK_SIZE(PATMPATCHREC);
|
---|
1019 | GEN_CHECK_OFF(PATMPATCHREC, Core);
|
---|
1020 | GEN_CHECK_OFF(PATMPATCHREC, CoreOffset);
|
---|
1021 | GEN_CHECK_OFF(PATMPATCHREC, patch);
|
---|
1022 | GEN_CHECK_SIZE(PATCHINFO);
|
---|
1023 | GEN_CHECK_OFF(PATCHINFO, uState);
|
---|
1024 | GEN_CHECK_OFF(PATCHINFO, uOldState);
|
---|
1025 | GEN_CHECK_OFF(PATCHINFO, uOpMode);
|
---|
1026 | GEN_CHECK_OFF(PATCHINFO, pPrivInstrHC);
|
---|
1027 | GEN_CHECK_OFF(PATCHINFO, pPrivInstrGC);
|
---|
1028 | GEN_CHECK_OFF(PATCHINFO, aPrivInstr);
|
---|
1029 | GEN_CHECK_OFF(PATCHINFO, aPrivInstr[1]);
|
---|
1030 | GEN_CHECK_OFF(PATCHINFO, aPrivInstr[MAX_INSTR_SIZE - 1]);
|
---|
1031 | GEN_CHECK_OFF(PATCHINFO, cbPrivInstr);
|
---|
1032 | GEN_CHECK_OFF(PATCHINFO, opcode);
|
---|
1033 | GEN_CHECK_OFF(PATCHINFO, cbPatchJump);
|
---|
1034 | GEN_CHECK_OFF(PATCHINFO, pPatchJumpDestGC);
|
---|
1035 | GEN_CHECK_OFF(PATCHINFO, pPatchBlockOffset);
|
---|
1036 | GEN_CHECK_OFF(PATCHINFO, cbPatchBlockSize);
|
---|
1037 | GEN_CHECK_OFF(PATCHINFO, uCurPatchOffset);
|
---|
1038 | GEN_CHECK_OFF(PATCHINFO, flags);
|
---|
1039 | GEN_CHECK_OFF(PATCHINFO, pInstrGCLowest);
|
---|
1040 | GEN_CHECK_OFF(PATCHINFO, pInstrGCHighest);
|
---|
1041 | GEN_CHECK_OFF(PATCHINFO, FixupTree);
|
---|
1042 | GEN_CHECK_OFF(PATCHINFO, nrFixups);
|
---|
1043 | GEN_CHECK_OFF(PATCHINFO, JumpTree);
|
---|
1044 | GEN_CHECK_OFF(PATCHINFO, nrJumpRecs);
|
---|
1045 | GEN_CHECK_OFF(PATCHINFO, Patch2GuestAddrTree);
|
---|
1046 | GEN_CHECK_OFF(PATCHINFO, Guest2PatchAddrTree);
|
---|
1047 | GEN_CHECK_OFF(PATCHINFO, nrPatch2GuestRecs);
|
---|
1048 | GEN_CHECK_OFF(PATCHINFO, cacheRec);
|
---|
1049 | GEN_CHECK_OFF(PATCHINFO, cacheRec.pPatchLocStartHC);
|
---|
1050 | GEN_CHECK_OFF(PATCHINFO, cacheRec.pPatchLocEndHC);
|
---|
1051 | GEN_CHECK_OFF(PATCHINFO, cacheRec.pGuestLoc);
|
---|
1052 | GEN_CHECK_OFF(PATCHINFO, cacheRec.opsize);
|
---|
1053 | GEN_CHECK_OFF(PATCHINFO, pTempInfo);
|
---|
1054 | GEN_CHECK_OFF(PATCHINFO, cCodeWrites);
|
---|
1055 | GEN_CHECK_OFF(PATCHINFO, cTraps);
|
---|
1056 | GEN_CHECK_OFF(PATCHINFO, cInvalidWrites);
|
---|
1057 | GEN_CHECK_OFF(PATCHINFO, uPatchIdx);
|
---|
1058 | GEN_CHECK_OFF(PATCHINFO, bDirtyOpcode);
|
---|
1059 | GEN_CHECK_SIZE(PATMPATCHPAGE);
|
---|
1060 | GEN_CHECK_OFF(PATMPATCHPAGE, Core);
|
---|
1061 | GEN_CHECK_OFF(PATMPATCHPAGE, pLowestAddrGC);
|
---|
1062 | GEN_CHECK_OFF(PATMPATCHPAGE, pHighestAddrGC);
|
---|
1063 | GEN_CHECK_OFF(PATMPATCHPAGE, cCount);
|
---|
1064 | GEN_CHECK_OFF(PATMPATCHPAGE, cMaxPatches);
|
---|
1065 | GEN_CHECK_OFF(PATMPATCHPAGE, aPatch);
|
---|
1066 |
|
---|
1067 | return (0);
|
---|
1068 | }
|
---|
1069 |
|
---|