VirtualBox

source: vbox/trunk/src/VBox/Devices/testcase/tstDeviceStructSizeRC.cpp@ 92404

Last change on this file since 92404 was 89590, checked in by vboxsync, 4 years ago

Intel IOMMU: bugref:9967 Added to device struct size and alignment tests.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id Revision
File size: 87.8 KB
Line 
1/* $Id: tstDeviceStructSizeRC.cpp 89590 2021-06-10 08:43:08Z vboxsync $ */
2/** @file
3 * tstDeviceStructSizeGC - Generate structure member and size checks from the RC perspective.
4 *
5 * This is built using the VBoxRc template but linked into a host
6 * ring-3 executable, rather hacky.
7 */
8
9/*
10 * Copyright (C) 2006-2020 Oracle Corporation
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
21
22/*
23 * Sanity checks.
24 */
25#ifndef IN_RC
26# error Incorrect template!
27#endif
28#if defined(IN_RING3) || defined(IN_RING0)
29# error Incorrect template!
30#endif
31
32
33/*********************************************************************************************************************************
34* Header Files *
35*********************************************************************************************************************************/
36#define VBOX_DEVICE_STRUCT_TESTCASE
37#define VBOX_WITH_HGCM /* grumble */
38
39/* Check that important preprocessor macros does not get redefined: */
40#include <VBox/cdefs.h>
41#include <VBox/log.h>
42#ifdef DEBUG
43# define VBOX_DEVICE_STRUCT_TESTCASE_CHECK_DEBUG
44#else
45# undef VBOX_DEVICE_STRUCT_TESTCASE_CHECK_DEBUG
46#endif
47#ifdef LOG_ENABLED
48# define VBOX_DEVICE_STRUCT_TESTCASE_CHECK_LOG_ENABLED
49#else
50# undef VBOX_DEVICE_STRUCT_TESTCASE_CHECK_LOG_ENABLED
51#endif
52#ifdef VBOX_STRICT
53# define VBOX_DEVICE_STRUCT_TESTCASE_CHECK_VBOX_STRICT
54#else
55# undef VBOX_DEVICE_STRUCT_TESTCASE_CHECK_VBOX_STRICT
56#endif
57#ifdef RT_STRICT
58# define VBOX_DEVICE_STRUCT_TESTCASE_CHECK_RT_STRICT
59#else
60# undef VBOX_DEVICE_STRUCT_TESTCASE_CHECK_RT_STRICT
61#endif
62
63/* The structures we're checking: */
64#undef LOG_GROUP
65#include "../Bus/DevPciInternal.h"
66#undef LOG_GROUP
67#include "../EFI/DevSmc.cpp"
68#undef LOG_GROUP
69#include "../Graphics/DevVGA.cpp"
70#undef LOG_GROUP
71#include "../Input/DevPS2.cpp"
72#undef LOG_GROUP
73#include "../Input/PS2K.cpp"
74#undef LOG_GROUP
75#include "../Input/PS2M.cpp"
76#undef LOG_GROUP
77#include "../Network/DevPCNet.cpp"
78#undef LOG_GROUP
79#include "../PC/DevACPI.cpp"
80#undef LOG_GROUP
81#include "../PC/DevPIC.cpp"
82#undef LOG_GROUP
83#include "../PC/DevPit-i8254.cpp"
84#undef LOG_GROUP
85#include "../PC/DevRTC.cpp"
86# undef LOG_GROUP
87# include "../../VMM/VMMR3/APIC.cpp"
88#undef LOG_GROUP
89#include "../PC/DevIoApic.cpp"
90#undef LOG_GROUP
91#include "../PC/DevDMA.cpp"
92#undef LOG_GROUP
93#include "../Storage/DevATA.cpp"
94#ifdef VBOX_WITH_USB
95# undef LOG_GROUP
96# include "../USB/DevOHCI.cpp"
97# ifdef VBOX_WITH_EHCI_IMPL
98# undef LOG_GROUP
99# include "../USB/DevEHCI.cpp"
100# endif
101# ifdef VBOX_WITH_XHCI_IMPL
102# undef LOG_GROUP
103# include "../USB/DevXHCI.cpp"
104# endif
105#endif
106#undef LOG_GROUP
107#include "../VMMDev/VMMDev.cpp"
108#undef LOG_GROUP
109#include "../Parallel/DevParallel.cpp"
110#undef LOG_GROUP
111#include "../Serial/DevSerial.cpp"
112#undef LOG_GROUP
113#include "../Serial/DevOxPcie958.cpp"
114#undef LOG_GROUP
115#include "../Serial/UartCore.h"
116#ifdef VBOX_WITH_AHCI
117# undef LOG_GROUP
118# include "../Storage/DevAHCI.cpp"
119#endif
120#ifdef VBOX_WITH_E1000
121# undef LOG_GROUP
122# include "../Network/DevE1000.cpp"
123#endif
124#ifdef VBOX_WITH_VIRTIO
125# undef LOG_GROUP
126# include "../Network/DevVirtioNet.cpp"
127#endif
128#ifdef VBOX_WITH_BUSLOGIC
129# undef LOG_GROUP
130# include "../Storage/DevBusLogic.cpp"
131#endif
132#ifdef VBOX_WITH_LSILOGIC
133# undef LOG_GROUP
134# include "../Storage/DevLsiLogicSCSI.cpp"
135#endif
136#undef LOG_GROUP
137#include "../PC/DevHPET.cpp"
138#undef LOG_GROUP
139#include "../Audio/DevIchAc97.cpp"
140#undef LOG_GROUP
141#include "../Audio/DevHDA.cpp"
142#ifdef VBOX_WITH_NVME_IMPL
143# undef LOG_GROUP
144# include "../Storage/DevNVMe.cpp"
145#endif
146#ifdef VBOX_WITH_IOMMU_AMD
147# undef LOG_GROUP
148# include "../Bus/DevIommuAmd.cpp"
149#endif
150#ifdef VBOX_WITH_IOMMU_INTEL
151# undef LOG_GROUP
152# include "../Bus/DevIommuIntel.cpp"
153#endif
154
155/* Check that important preprocessor macros didn't get redefined: */
156#if defined(DEBUG) != defined(VBOX_DEVICE_STRUCT_TESTCASE_CHECK_DEBUG)
157# error "DEBUG was modified! This may throw off structure tests."
158#endif
159#if defined(LOG_ENABLED) != defined(VBOX_DEVICE_STRUCT_TESTCASE_CHECK_LOG_ENABLED)
160# error "LOG_ENABLED was modified! This may throw off structure tests."
161#endif
162#if defined(RT_STRICT) != defined(VBOX_DEVICE_STRUCT_TESTCASE_CHECK_RT_STRICT)
163# error "RT_STRICT was modified! This may throw off structure tests."
164#endif
165#if defined(VBOX_STRICT) != defined(VBOX_DEVICE_STRUCT_TESTCASE_CHECK_VBOX_STRICT)
166# error "VBOX_STRICT was modified! This may throw off structure tests."
167#endif
168
169
170/* we don't use iprt here because we're pretending to be in GC! */
171#include <stdio.h>
172
173#define GEN_CHECK_SIZE(s) printf(" CHECK_SIZE(%s, %d);\n", #s, (int)sizeof(s))
174#define GEN_CHECK_OFF(s, m) printf(" CHECK_OFF(%s, %d, %s);\n", #s, (int)RT_OFFSETOF(s, m), #m)
175#define GEN_CHECK_PADDING(s, m, a) printf(" CHECK_PADDING(%s, %s, %u);\n", #s, #m, (a))
176
177int main()
178{
179 /* misc */
180 GEN_CHECK_SIZE(PDMDEVINS);
181 GEN_CHECK_OFF(PDMDEVINS, Internal);
182 GEN_CHECK_OFF(PDMDEVINS, pReg);
183 GEN_CHECK_OFF(PDMDEVINS, pCfg);
184 GEN_CHECK_OFF(PDMDEVINS, iInstance);
185 GEN_CHECK_OFF(PDMDEVINS, IBase);
186 GEN_CHECK_OFF(PDMDEVINS, pHlpR3);
187 GEN_CHECK_OFF(PDMDEVINS, pHlpR0);
188 GEN_CHECK_OFF(PDMDEVINS, pHlpRC);
189 GEN_CHECK_OFF(PDMDEVINS, pvInstanceDataR3);
190 GEN_CHECK_OFF(PDMDEVINS, pvInstanceDataR0);
191 GEN_CHECK_OFF(PDMDEVINS, pvInstanceDataRC);
192 GEN_CHECK_OFF(PDMDEVINS, achInstanceData);
193
194 /* PDMPCIDEV */
195 GEN_CHECK_SIZE(PDMPCIDEV);
196 GEN_CHECK_SIZE(PDMPCIDEVINT);
197 GEN_CHECK_SIZE(PCIIOREGION); /** @todo fix name of PCIIOREGION */
198 GEN_CHECK_OFF(PDMPCIDEV, abConfig);
199 GEN_CHECK_OFF(PDMPCIDEV, uDevFn);
200 GEN_CHECK_OFF(PDMPCIDEV, pszNameR3);
201 GEN_CHECK_OFF(PDMPCIDEV, pfnRegionLoadChangeHookR3);
202 GEN_CHECK_OFF(PDMPCIDEV, Int);
203 GEN_CHECK_OFF(PDMPCIDEV, Int.s.aIORegions);
204 GEN_CHECK_OFF(PDMPCIDEV, Int.s.aIORegions[1]);
205 GEN_CHECK_OFF(PDMPCIDEV, Int.s.aIORegions[VBOX_PCI_NUM_REGIONS - 1]);
206 GEN_CHECK_OFF(PDMPCIDEV, Int.s.aIORegions[0].addr);
207 GEN_CHECK_OFF(PDMPCIDEV, Int.s.aIORegions[0].size);
208 GEN_CHECK_OFF(PDMPCIDEV, Int.s.aIORegions[0].type);
209 GEN_CHECK_OFF(PDMPCIDEV, Int.s.aIORegions[0].padding);
210 GEN_CHECK_OFF(PDMPCIDEV, Int.s.pBusR3);
211 GEN_CHECK_OFF(PDMPCIDEV, Int.s.pBusR0);
212 GEN_CHECK_OFF(PDMPCIDEV, Int.s.pBusRC);
213 GEN_CHECK_OFF(PDMPCIDEV, Int.s.pfnConfigRead);
214 GEN_CHECK_OFF(PDMPCIDEV, Int.s.pfnConfigWrite);
215 GEN_CHECK_OFF(PDMPCIDEV, Int.s.fFlags);
216 GEN_CHECK_OFF(PDMPCIDEV, Int.s.uIrqPinState);
217 GEN_CHECK_OFF(PDMPCIDEV, Int.s.pfnBridgeConfigRead);
218 GEN_CHECK_OFF(PDMPCIDEV, Int.s.pfnBridgeConfigWrite);
219 GEN_CHECK_PADDING(PDMPCIDEV, Int, 8);
220
221 /* DevPciInternal.h */
222 GEN_CHECK_SIZE(DEVPCIBUS);
223 GEN_CHECK_OFF(DEVPCIBUS, iBus);
224 GEN_CHECK_OFF(DEVPCIBUS, iDevSearch);
225 GEN_CHECK_OFF(DEVPCIBUS, cBridges);
226 GEN_CHECK_OFF(DEVPCIBUS, apDevices);
227 GEN_CHECK_OFF(DEVPCIBUS, apDevices[1]);
228 GEN_CHECK_OFF(DEVPCIBUS, papBridgesR3);
229 GEN_CHECK_OFF(DEVPCIBUS, PciDev);
230 GEN_CHECK_SIZE(PIIX3ISABRIDGE);
231 GEN_CHECK_SIZE(DEVPCIROOT);
232 GEN_CHECK_OFF(DEVPCIROOT, PciBus);
233 GEN_CHECK_OFF(DEVPCIROOT, fUseIoApic);
234 GEN_CHECK_OFF(DEVPCIROOT, u64PciConfigMMioAddress);
235 GEN_CHECK_OFF(DEVPCIROOT, u64PciConfigMMioLength);
236 GEN_CHECK_OFF(DEVPCIROOT, auPciApicIrqLevels);
237 GEN_CHECK_OFF(DEVPCIROOT, auPciApicIrqLevels[1]);
238 GEN_CHECK_OFF(DEVPCIROOT, uConfigReg);
239 GEN_CHECK_OFF(DEVPCIROOT, Piix3.iAcpiIrqLevel);
240 GEN_CHECK_OFF(DEVPCIROOT, Piix3.iAcpiIrq);
241 GEN_CHECK_OFF(DEVPCIROOT, Piix3.auPciLegacyIrqLevels);
242 GEN_CHECK_OFF(DEVPCIROOT, Piix3.auPciLegacyIrqLevels[1]);
243 GEN_CHECK_OFF(DEVPCIROOT, Piix3.PIIX3State);
244 GEN_CHECK_OFF(DEVPCIROOT, uPciBiosBus);
245 GEN_CHECK_OFF(DEVPCIROOT, uPciBiosIo);
246 GEN_CHECK_OFF(DEVPCIROOT, uPciBiosMmio);
247 GEN_CHECK_OFF(DEVPCIROOT, uPciBiosMmio64);
248
249 /* EFI/DevSMC.cpp */
250 GEN_CHECK_SIZE(DEVSMC);
251 GEN_CHECK_OFF(DEVSMC, bCmd);
252 GEN_CHECK_OFF(DEVSMC, offKey);
253 GEN_CHECK_OFF(DEVSMC, offValue);
254 GEN_CHECK_OFF(DEVSMC, cKeys);
255 GEN_CHECK_OFF(DEVSMC, CurKey);
256 GEN_CHECK_OFF(DEVSMC, u);
257 GEN_CHECK_OFF(DEVSMC, u.s);
258 GEN_CHECK_OFF(DEVSMC, u.s.bState);
259 GEN_CHECK_OFF(DEVSMC, u.s.bStatusCode);
260 GEN_CHECK_OFF(DEVSMC, u.s.bStatusCode);
261 GEN_CHECK_OFF(DEVSMC, szOsk0And1);
262 GEN_CHECK_OFF(DEVSMC, bDollaryNumber);
263 GEN_CHECK_OFF(DEVSMC, bShutdownReason);
264 GEN_CHECK_OFF(DEVSMC, bNinjaActionTimerJob);
265
266 /* DevVGA.cpp */
267 GEN_CHECK_SIZE(VGASTATE);
268 GEN_CHECK_OFF(VGASTATE, vram_ptrR3);
269 GEN_CHECK_OFF(VGASTATE, get_bpp);
270 GEN_CHECK_OFF(VGASTATE, get_offsets);
271 GEN_CHECK_OFF(VGASTATE, get_resolution);
272 GEN_CHECK_OFF(VGASTATE, rgb_to_pixel);
273 GEN_CHECK_OFF(VGASTATE, cursor_invalidate);
274 GEN_CHECK_OFF(VGASTATE, cursor_draw_line);
275 GEN_CHECK_OFF(VGASTATE, vram_size);
276 GEN_CHECK_OFF(VGASTATE, latch);
277 GEN_CHECK_OFF(VGASTATE, sr_index);
278 GEN_CHECK_OFF(VGASTATE, sr);
279 GEN_CHECK_OFF(VGASTATE, sr[1]);
280 GEN_CHECK_OFF(VGASTATE, gr_index);
281 GEN_CHECK_OFF(VGASTATE, gr);
282 GEN_CHECK_OFF(VGASTATE, gr[1]);
283 GEN_CHECK_OFF(VGASTATE, ar_index);
284 GEN_CHECK_OFF(VGASTATE, ar);
285 GEN_CHECK_OFF(VGASTATE, ar[1]);
286 GEN_CHECK_OFF(VGASTATE, ar_flip_flop);
287 GEN_CHECK_OFF(VGASTATE, cr_index);
288 GEN_CHECK_OFF(VGASTATE, cr);
289 GEN_CHECK_OFF(VGASTATE, cr[1]);
290 GEN_CHECK_OFF(VGASTATE, msr);
291 GEN_CHECK_OFF(VGASTATE, msr);
292 GEN_CHECK_OFF(VGASTATE, fcr);
293 GEN_CHECK_OFF(VGASTATE, st00);
294 GEN_CHECK_OFF(VGASTATE, st01);
295 GEN_CHECK_OFF(VGASTATE, dac_state);
296 GEN_CHECK_OFF(VGASTATE, dac_sub_index);
297 GEN_CHECK_OFF(VGASTATE, dac_read_index);
298 GEN_CHECK_OFF(VGASTATE, dac_write_index);
299 GEN_CHECK_OFF(VGASTATE, dac_cache);
300 GEN_CHECK_OFF(VGASTATE, dac_cache[1]);
301 GEN_CHECK_OFF(VGASTATE, palette);
302 GEN_CHECK_OFF(VGASTATE, palette[1]);
303 GEN_CHECK_OFF(VGASTATE, bank_offset);
304#ifdef CONFIG_BOCHS_VBE
305 GEN_CHECK_OFF(VGASTATE, vbe_index);
306 GEN_CHECK_OFF(VGASTATE, vbe_regs);
307 GEN_CHECK_OFF(VGASTATE, vbe_regs[1]);
308 GEN_CHECK_OFF(VGASTATE, vbe_regs[VBE_DISPI_INDEX_NB - 1]);
309 GEN_CHECK_OFF(VGASTATE, vbe_start_addr);
310 GEN_CHECK_OFF(VGASTATE, vbe_line_offset);
311 GEN_CHECK_OFF(VGASTATE, vbe_bank_max);
312#endif
313 GEN_CHECK_OFF(VGASTATE, font_offsets);
314 GEN_CHECK_OFF(VGASTATE, font_offsets[1]);
315 GEN_CHECK_OFF(VGASTATE, graphic_mode);
316 GEN_CHECK_OFF(VGASTATE, shift_control);
317 GEN_CHECK_OFF(VGASTATE, double_scan);
318 GEN_CHECK_OFF(VGASTATE, line_offset);
319 GEN_CHECK_OFF(VGASTATE, line_compare);
320 GEN_CHECK_OFF(VGASTATE, start_addr);
321 GEN_CHECK_OFF(VGASTATE, plane_updated);
322 GEN_CHECK_OFF(VGASTATE, last_cw);
323 GEN_CHECK_OFF(VGASTATE, last_ch);
324 GEN_CHECK_OFF(VGASTATE, last_width);
325 GEN_CHECK_OFF(VGASTATE, last_height);
326 GEN_CHECK_OFF(VGASTATE, last_scr_width);
327 GEN_CHECK_OFF(VGASTATE, last_scr_height);
328 GEN_CHECK_OFF(VGASTATE, last_bpp);
329 GEN_CHECK_OFF(VGASTATE, cursor_start);
330 GEN_CHECK_OFF(VGASTATE, cursor_end);
331 GEN_CHECK_OFF(VGASTATE, cursor_offset);
332 GEN_CHECK_OFF(VGASTATE, invalidated_y_table);
333 GEN_CHECK_OFF(VGASTATE, invalidated_y_table[1]);
334 GEN_CHECK_OFF(VGASTATE, invalidated_y_table[(VGA_MAX_HEIGHT / 32) - 1]);
335 GEN_CHECK_OFF(VGASTATE, last_palette);
336 GEN_CHECK_OFF(VGASTATE, last_palette[1]);
337 GEN_CHECK_OFF(VGASTATE, last_ch_attr);
338 GEN_CHECK_OFF(VGASTATE, last_ch_attr[CH_ATTR_SIZE - 1]);
339 GEN_CHECK_OFF(VGASTATE, u32Marker);
340 GEN_CHECK_OFF(VGASTATE, pDevInsRC);
341 GEN_CHECK_OFF(VGASTATE, vram_ptrRC);
342 GEN_CHECK_OFF(VGASTATE, pDevInsR3);
343#ifdef VBOX_WITH_HGSMI
344 GEN_CHECK_OFF(VGASTATE, pHGSMI);
345#endif
346#ifdef VBOX_WITH_VDMA
347 GEN_CHECK_OFF(VGASTATE, pVdma);
348#endif
349 GEN_CHECK_OFF(VGASTATE, IBase);
350 GEN_CHECK_OFF(VGASTATE, IPort);
351#if defined(VBOX_WITH_HGSMI) && defined(VBOX_WITH_VIDEOHWACCEL)
352 GEN_CHECK_OFF(VGASTATE, IVBVACallbacks);
353#endif
354 GEN_CHECK_OFF(VGASTATE, pDrvBase);
355 GEN_CHECK_OFF(VGASTATE, pDrv);
356 GEN_CHECK_OFF(VGASTATE, RefreshTimer);
357 GEN_CHECK_OFF(VGASTATE, pDevInsR0);
358#ifdef VBOX_WITH_VMSVGA
359 GEN_CHECK_OFF(VGASTATE, svga.pFIFOR3);
360 GEN_CHECK_OFF(VGASTATE, svga.pFIFOR0);
361 GEN_CHECK_OFF(VGASTATE, svga.pSvgaR3State);
362 GEN_CHECK_OFF(VGASTATE, svga.p3dState);
363 GEN_CHECK_OFF(VGASTATE, svga.pbVgaFrameBufferR3);
364 GEN_CHECK_OFF(VGASTATE, svga.GCPhysFIFO);
365 GEN_CHECK_OFF(VGASTATE, svga.cbFIFO);
366 GEN_CHECK_OFF(VGASTATE, svga.cbFIFOConfig);
367 GEN_CHECK_OFF(VGASTATE, svga.u32SVGAId);
368 GEN_CHECK_OFF(VGASTATE, svga.fConfigured);
369 GEN_CHECK_OFF(VGASTATE, svga.fBusy);
370 GEN_CHECK_OFF(VGASTATE, svga.fTraces);
371 GEN_CHECK_OFF(VGASTATE, svga.u32GuestId);
372 GEN_CHECK_OFF(VGASTATE, svga.cScratchRegion);
373 GEN_CHECK_OFF(VGASTATE, svga.u32IrqStatus);
374 GEN_CHECK_OFF(VGASTATE, svga.u32IrqMask);
375 GEN_CHECK_OFF(VGASTATE, svga.u32PitchLock);
376 GEN_CHECK_OFF(VGASTATE, svga.u32CurrentGMRId);
377 GEN_CHECK_OFF(VGASTATE, svga.u32RegCaps);
378 GEN_CHECK_OFF(VGASTATE, svga.u32IndexReg);
379 GEN_CHECK_OFF(VGASTATE, svga.hFIFORequestSem);
380 GEN_CHECK_OFF(VGASTATE, svga.hFIFOExtCmdSem);
381 GEN_CHECK_OFF(VGASTATE, svga.pFIFOIOThread);
382 GEN_CHECK_OFF(VGASTATE, svga.uWidth);
383 GEN_CHECK_OFF(VGASTATE, svga.uHeight);
384 GEN_CHECK_OFF(VGASTATE, svga.uBpp);
385 GEN_CHECK_OFF(VGASTATE, svga.cbScanline);
386 GEN_CHECK_OFF(VGASTATE, svga.u32MaxWidth);
387 GEN_CHECK_OFF(VGASTATE, svga.u32MaxHeight);
388 GEN_CHECK_OFF(VGASTATE, svga.viewport);
389 GEN_CHECK_OFF(VGASTATE, svga.u32ActionFlags);
390 GEN_CHECK_OFF(VGASTATE, svga.f3DEnabled);
391 GEN_CHECK_OFF(VGASTATE, svga.fVRAMTracking);
392 GEN_CHECK_OFF(VGASTATE, svga.u8FIFOExtCommand);
393 GEN_CHECK_OFF(VGASTATE, svga.fFifoExtCommandWakeup);
394 GEN_CHECK_OFF(VGASTATE, svga.au32ScratchRegion);
395 GEN_CHECK_OFF(VGASTATE, svga.StatRegBitsPerPixelWr);
396 GEN_CHECK_OFF(VGASTATE, svga.StatRegWriteOnlyRd);
397#endif
398 GEN_CHECK_OFF(VGASTATE, cMonitors);
399 GEN_CHECK_OFF(VGASTATE, cMilliesRefreshInterval);
400 GEN_CHECK_OFF(VGASTATE, au32DirtyBitmap);
401 GEN_CHECK_OFF(VGASTATE, au32DirtyBitmap[1]);
402 GEN_CHECK_OFF(VGASTATE, au32DirtyBitmap[(VGA_VRAM_MAX / PAGE_SIZE / 32) - 1]);
403 GEN_CHECK_OFF(VGASTATE, fHasDirtyBits);
404 GEN_CHECK_OFF(VGASTATE, fLFBUpdated);
405 GEN_CHECK_OFF(VGASTATE, fGCEnabled);
406 GEN_CHECK_OFF(VGASTATE, fR0Enabled);
407 GEN_CHECK_OFF(VGASTATE, fRemappedVGA);
408 GEN_CHECK_OFF(VGASTATE, fRenderVRAM);
409 GEN_CHECK_OFF(VGASTATE, GCPhysVRAM);
410 GEN_CHECK_OFF(VGASTATE, CritSect);
411 GEN_CHECK_OFF(VGASTATE, Dev);
412 GEN_CHECK_OFF(VGASTATE, StatRZMemoryRead);
413 GEN_CHECK_OFF(VGASTATE, StatR3MemoryRead);
414 GEN_CHECK_OFF(VGASTATE, StatRZMemoryWrite);
415 GEN_CHECK_OFF(VGASTATE, StatR3MemoryWrite);
416#ifdef VBE_BYTEWISE_IO
417 GEN_CHECK_OFF(VGASTATE, fReadVBEData);
418 GEN_CHECK_OFF(VGASTATE, fWriteVBEData);
419 GEN_CHECK_OFF(VGASTATE, fReadVBEIndex);
420 GEN_CHECK_OFF(VGASTATE, fWriteVBEIndex);
421 GEN_CHECK_OFF(VGASTATE, cbWriteVBEData);
422 GEN_CHECK_OFF(VGASTATE, cbWriteVBEIndex);
423# ifdef VBE_NEW_DYN_LIST
424 GEN_CHECK_OFF(VGASTATE, cbWriteVBEExtraAddress);
425# endif
426#endif
427#ifdef VBE_NEW_DYN_LIST
428 GEN_CHECK_OFF(VGASTATE, pbVBEExtraData);
429 GEN_CHECK_OFF(VGASTATE, cbVBEExtraData);
430 GEN_CHECK_OFF(VGASTATE, u16VBEExtraAddress);
431#endif
432 GEN_CHECK_OFF(VGASTATE, pbLogo);
433 GEN_CHECK_OFF(VGASTATE, pszLogoFile);
434 GEN_CHECK_OFF(VGASTATE, pbLogoBitmap);
435 GEN_CHECK_OFF(VGASTATE, offLogoData);
436 GEN_CHECK_OFF(VGASTATE, cbLogo);
437 GEN_CHECK_OFF(VGASTATE, LogoCommand);
438 GEN_CHECK_OFF(VGASTATE, cxLogo);
439 GEN_CHECK_OFF(VGASTATE, cyLogo);
440 GEN_CHECK_OFF(VGASTATE, cLogoPlanes);
441 GEN_CHECK_OFF(VGASTATE, cLogoBits);
442 GEN_CHECK_OFF(VGASTATE, LogoCompression);
443 GEN_CHECK_OFF(VGASTATE, cLogoUsedColors);
444 GEN_CHECK_OFF(VGASTATE, cLogoPalEntries);
445 GEN_CHECK_OFF(VGASTATE, fLogoClearScreen);
446 GEN_CHECK_OFF(VGASTATE, au32LogoPalette);
447 GEN_CHECK_OFF(VGASTATE, pbVgaBios);
448 GEN_CHECK_OFF(VGASTATE, cbVgaBios);
449 GEN_CHECK_OFF(VGASTATE, pszVgaBiosFile);
450#ifdef VBOX_WITH_HGSMI
451 GEN_CHECK_OFF(VGASTATE, IOPortBase);
452#endif
453#ifdef VBOX_WITH_WDDM
454 GEN_CHECK_OFF(VGASTATE, fGuestCaps);
455#endif
456
457 /* Input/pckbd.c */
458 GEN_CHECK_SIZE(KBDSTATE);
459 GEN_CHECK_OFF(KBDSTATE, write_cmd);
460 GEN_CHECK_OFF(KBDSTATE, status);
461 GEN_CHECK_OFF(KBDSTATE, mode);
462 GEN_CHECK_OFF(KBDSTATE, pDevInsR3);
463 GEN_CHECK_OFF(KBDSTATE, pDevInsR0);
464 GEN_CHECK_OFF(KBDSTATE, pDevInsRC);
465 GEN_CHECK_SIZE(KbdKeyQ);
466 GEN_CHECK_OFF(KbdCmdQ, rpos);
467 GEN_CHECK_OFF(KbdCmdQ, wpos);
468 GEN_CHECK_OFF(KbdCmdQ, cUsed);
469 GEN_CHECK_OFF(KbdCmdQ, cSize);
470 GEN_CHECK_OFF(KbdCmdQ, abQueue);
471 GEN_CHECK_SIZE(KbdCmdQ);
472 /* Input/PS2K.c */
473 GEN_CHECK_SIZE(PS2K);
474 GEN_CHECK_OFF(PS2K, fScanning);
475 GEN_CHECK_OFF(PS2K, fNumLockOn);
476 GEN_CHECK_OFF(PS2K, u8ScanSet);
477 GEN_CHECK_OFF(PS2K, u8TypematicCfg);
478 GEN_CHECK_OFF(PS2K, enmTypematicState);
479 GEN_CHECK_OFF(PS2K, keyQ);
480 GEN_CHECK_OFF(PS2K, cmdQ);
481 GEN_CHECK_OFF(PS2K, uTypematicDelay);
482 GEN_CHECK_OFF(PS2K, fThrottleActive);
483 GEN_CHECK_OFF(PS2K, pKbdDelayTimerRC);
484 GEN_CHECK_OFF(PS2K, pKbdDelayTimerR3);
485 GEN_CHECK_OFF(PS2K, pKbdDelayTimerR0);
486 GEN_CHECK_OFF(PS2K, pKbdTypematicTimerRC);
487 GEN_CHECK_OFF(PS2K, pKbdTypematicTimerR3);
488 GEN_CHECK_OFF(PS2K, pKbdTypematicTimerR0);
489 GEN_CHECK_OFF(PS2K, pThrottleTimerRC);
490 GEN_CHECK_OFF(PS2K, pThrottleTimerR3);
491 GEN_CHECK_OFF(PS2K, pThrottleTimerR0);
492 GEN_CHECK_OFF(PS2K, pCritSectR3);
493 GEN_CHECK_OFF(PS2K, Keyboard.IBase);
494 GEN_CHECK_OFF(PS2K, Keyboard.IPort);
495 GEN_CHECK_OFF(PS2K, Keyboard.pDrvBase);
496 GEN_CHECK_OFF(PS2K, Keyboard.pDrv);
497 /* Input/PS2M.c */
498 GEN_CHECK_SIZE(PS2M);
499 GEN_CHECK_OFF(PS2M, u8State);
500 GEN_CHECK_OFF(PS2M, u8SampleRate);
501 GEN_CHECK_OFF(PS2M, u8Resolution);
502 GEN_CHECK_OFF(PS2M, u8CurrCmd);
503 GEN_CHECK_OFF(PS2M, fThrottleActive);
504 GEN_CHECK_OFF(PS2M, fDelayReset);
505 GEN_CHECK_OFF(PS2M, enmMode);
506 GEN_CHECK_OFF(PS2M, enmProtocol);
507 GEN_CHECK_OFF(PS2M, enmKnockState);
508 GEN_CHECK_OFF(PS2M, evtQ);
509 GEN_CHECK_OFF(PS2M, cmdQ);
510 GEN_CHECK_OFF(PS2M, iAccumX);
511 GEN_CHECK_OFF(PS2M, fAccumB);
512 GEN_CHECK_OFF(PS2M, fCurrB);
513 GEN_CHECK_OFF(PS2M, uThrottleDelay);
514 GEN_CHECK_OFF(PS2M, pCritSectR3);
515 GEN_CHECK_OFF(PS2M, pDelayTimerR3);
516 GEN_CHECK_OFF(PS2M, pThrottleTimerR3);
517 GEN_CHECK_OFF(PS2M, pDelayTimerRC);
518 GEN_CHECK_OFF(PS2M, pThrottleTimerRC);
519 GEN_CHECK_OFF(PS2M, pDelayTimerR0);
520 GEN_CHECK_OFF(PS2M, pThrottleTimerR0);
521 GEN_CHECK_OFF(PS2M, Mouse.IBase);
522 GEN_CHECK_OFF(PS2M, Mouse.IPort);
523 GEN_CHECK_OFF(PS2M, Mouse.pDrvBase);
524 GEN_CHECK_OFF(PS2M, Mouse.pDrv);
525
526 /* Network/DevPCNet.cpp */
527 GEN_CHECK_SIZE(PCNETSTATE);
528 GEN_CHECK_OFF(PCNETSTATE, PciDev);
529#ifndef PCNET_NO_POLLING
530 GEN_CHECK_OFF(PCNETSTATE, pTimerPollR3);
531 GEN_CHECK_OFF(PCNETSTATE, pTimerPollR0);
532 GEN_CHECK_OFF(PCNETSTATE, pTimerPollRC);
533#endif
534 GEN_CHECK_OFF(PCNETSTATE, pTimerSoftIntR3);
535 GEN_CHECK_OFF(PCNETSTATE, pTimerSoftIntR0);
536 GEN_CHECK_OFF(PCNETSTATE, pTimerSoftIntRC);
537 GEN_CHECK_OFF(PCNETSTATE, u32RAP);
538 GEN_CHECK_OFF(PCNETSTATE, iISR);
539 GEN_CHECK_OFF(PCNETSTATE, u32Lnkst);
540 GEN_CHECK_OFF(PCNETSTATE, GCRDRA);
541 GEN_CHECK_OFF(PCNETSTATE, GCTDRA);
542 GEN_CHECK_OFF(PCNETSTATE, aPROM);
543 GEN_CHECK_OFF(PCNETSTATE, aPROM[1]);
544 GEN_CHECK_OFF(PCNETSTATE, aCSR);
545 GEN_CHECK_OFF(PCNETSTATE, aCSR[1]);
546 GEN_CHECK_OFF(PCNETSTATE, aCSR[CSR_MAX_REG - 1]);
547 GEN_CHECK_OFF(PCNETSTATE, aBCR);
548 GEN_CHECK_OFF(PCNETSTATE, aBCR[1]);
549 GEN_CHECK_OFF(PCNETSTATE, aBCR[BCR_MAX_RAP - 1]);
550 GEN_CHECK_OFF(PCNETSTATE, aMII);
551 GEN_CHECK_OFF(PCNETSTATE, aMII[1]);
552 GEN_CHECK_OFF(PCNETSTATE, aMII[MII_MAX_REG - 1]);
553 GEN_CHECK_OFF(PCNETSTATE, u16CSR0LastSeenByGuest);
554 GEN_CHECK_OFF(PCNETSTATE, u64LastPoll);
555 GEN_CHECK_OFF(PCNETSTATE, abLoopBuf);
556 GEN_CHECK_OFF(PCNETSTATE, abRecvBuf);
557 GEN_CHECK_OFF(PCNETSTATE, iLog2DescSize);
558 GEN_CHECK_OFF(PCNETSTATE, GCUpperPhys);
559 GEN_CHECK_OFF(PCNETSTATE, pXmitQueueR3);
560 GEN_CHECK_OFF(PCNETSTATE, pXmitQueueR0);
561 GEN_CHECK_OFF(PCNETSTATE, pXmitQueueRC);
562 GEN_CHECK_OFF(PCNETSTATE, pCanRxQueueR3);
563 GEN_CHECK_OFF(PCNETSTATE, pCanRxQueueR0);
564 GEN_CHECK_OFF(PCNETSTATE, pCanRxQueueRC);
565 GEN_CHECK_OFF(PCNETSTATE, pTimerRestore);
566 GEN_CHECK_OFF(PCNETSTATE, pDevInsR3);
567 GEN_CHECK_OFF(PCNETSTATE, pDevInsR0);
568 GEN_CHECK_OFF(PCNETSTATE, pDevInsRC);
569 GEN_CHECK_OFF(PCNETSTATE, pDrvR3);
570 GEN_CHECK_OFF(PCNETSTATE, pDrvBase);
571 GEN_CHECK_OFF(PCNETSTATE, IBase);
572 GEN_CHECK_OFF(PCNETSTATE, INetworkDown);
573 GEN_CHECK_OFF(PCNETSTATE, INetworkConfig);
574 GEN_CHECK_OFF(PCNETSTATE, MMIOBase);
575 GEN_CHECK_OFF(PCNETSTATE, IOPortBase);
576 GEN_CHECK_OFF(PCNETSTATE, fLinkUp);
577 GEN_CHECK_OFF(PCNETSTATE, fLinkTempDown);
578 GEN_CHECK_OFF(PCNETSTATE, cLinkDownReported);
579 GEN_CHECK_OFF(PCNETSTATE, MacConfigured);
580 GEN_CHECK_OFF(PCNETSTATE, Led);
581 GEN_CHECK_OFF(PCNETSTATE, ILeds);
582 GEN_CHECK_OFF(PCNETSTATE, pLedsConnector);
583 GEN_CHECK_OFF(PCNETSTATE, CritSect);
584#ifdef PCNET_NO_POLLING
585 GEN_CHECK_OFF(PCNETSTATE, TDRAPhysOld);
586 GEN_CHECK_OFF(PCNETSTATE, cbTDRAOld);
587 GEN_CHECK_OFF(PCNETSTATE, RDRAPhysOld);
588 GEN_CHECK_OFF(PCNETSTATE, cbRDRAOld);
589 GEN_CHECK_OFF(PCNETSTATE, pfnEMInterpretInstructionGC
590 GEN_CHECK_OFF(PCNETSTATE, pfnEMInterpretInstructionR0
591#endif
592 GEN_CHECK_OFF(PCNETSTATE, fGCEnabled);
593 GEN_CHECK_OFF(PCNETSTATE, fR0Enabled);
594 GEN_CHECK_OFF(PCNETSTATE, uDevType);
595 GEN_CHECK_OFF(PCNETSTATE, StatReceiveBytes);
596 GEN_CHECK_OFF(PCNETSTATE, StatTransmitBytes);
597#ifdef VBOX_WITH_STATISTICS
598 GEN_CHECK_OFF(PCNETSTATE, StatMMIOReadR3);
599 GEN_CHECK_OFF(PCNETSTATE, StatMMIOReadRZ);
600 GEN_CHECK_OFF(PCNETSTATE, StatMIIReads);
601# ifdef PCNET_NO_POLLING
602 GEN_CHECK_OFF(PCNETSTATE, StatRCVRingWrite);
603 GEN_CHECK_OFF(PCNETSTATE, StatRingWriteOutsideRangeR3);
604# endif
605#endif
606
607 /* PC/DevACPI.cpp */
608 GEN_CHECK_SIZE(ACPIState);
609 GEN_CHECK_OFF(ACPIState, dev);
610 GEN_CHECK_OFF(ACPIState, pm1a_en);
611 GEN_CHECK_OFF(ACPIState, pm1a_sts);
612 GEN_CHECK_OFF(ACPIState, pm1a_ctl);
613 GEN_CHECK_OFF(ACPIState, u64PmTimerInitial);
614 GEN_CHECK_OFF(ACPIState, pPmTimerR3);
615 GEN_CHECK_OFF(ACPIState, pPmTimerR0);
616 GEN_CHECK_OFF(ACPIState, pPmTimerRC);
617 GEN_CHECK_OFF(ACPIState, uPmTimerVal);
618 GEN_CHECK_OFF(ACPIState, gpe0_en);
619 GEN_CHECK_OFF(ACPIState, gpe0_sts);
620 GEN_CHECK_OFF(ACPIState, uBatteryIndex);
621 GEN_CHECK_OFF(ACPIState, au8BatteryInfo);
622 GEN_CHECK_OFF(ACPIState, uSystemInfoIndex);
623 GEN_CHECK_OFF(ACPIState, u64RamSize);
624 GEN_CHECK_OFF(ACPIState, uSleepState);
625 GEN_CHECK_OFF(ACPIState, au8RSDPPage);
626 GEN_CHECK_OFF(ACPIState, u8IndexShift);
627 GEN_CHECK_OFF(ACPIState, u8UseIOApic);
628 GEN_CHECK_OFF(ACPIState, fUseFdc);
629 GEN_CHECK_OFF(ACPIState, fUseHpet);
630 GEN_CHECK_OFF(ACPIState, fUseSmc);
631 GEN_CHECK_OFF(ACPIState, CpuSetAttached);
632 GEN_CHECK_OFF(ACPIState, idCpuLockCheck);
633 GEN_CHECK_OFF(ACPIState, CpuSetLocked);
634 GEN_CHECK_OFF(ACPIState, u32CpuEventType);
635 GEN_CHECK_OFF(ACPIState, u32CpuEvent);
636 GEN_CHECK_OFF(ACPIState, fCpuHotPlug);
637 GEN_CHECK_OFF(ACPIState, u32NicPciAddress);
638 GEN_CHECK_OFF(ACPIState, u32HbcPciAddress);
639 GEN_CHECK_OFF(ACPIState, u32IommuPciAddress);
640 GEN_CHECK_OFF(ACPIState, u32SbIoApicPciAddress);
641 GEN_CHECK_OFF(ACPIState, u64PciConfigMMioAddress);
642 GEN_CHECK_OFF(ACPIState, IBase);
643 GEN_CHECK_OFF(ACPIState, IACPIPort);
644 GEN_CHECK_OFF(ACPIState, pDevInsR3);
645 GEN_CHECK_OFF(ACPIState, pDevInsR0);
646 GEN_CHECK_OFF(ACPIState, pDrvBase);
647 GEN_CHECK_OFF(ACPIState, pDrv);
648 GEN_CHECK_OFF(ACPIState, u16SMBusSlvDat);
649
650 /* PC/DevPIC.cpp */
651 GEN_CHECK_SIZE(PICSTATE);
652 GEN_CHECK_OFF(PICSTATE, last_irr);
653 GEN_CHECK_OFF(PICSTATE, irr);
654 GEN_CHECK_OFF(PICSTATE, imr);
655 GEN_CHECK_OFF(PICSTATE, isr);
656 GEN_CHECK_OFF(PICSTATE, priority_add);
657 GEN_CHECK_OFF(PICSTATE, irq_base);
658 GEN_CHECK_OFF(PICSTATE, read_reg_select);
659 GEN_CHECK_OFF(PICSTATE, poll);
660 GEN_CHECK_OFF(PICSTATE, special_mask);
661 GEN_CHECK_OFF(PICSTATE, init_state);
662 GEN_CHECK_OFF(PICSTATE, auto_eoi);
663 GEN_CHECK_OFF(PICSTATE, rotate_on_auto_eoi);
664 GEN_CHECK_OFF(PICSTATE, special_fully_nested_mode);
665 GEN_CHECK_OFF(PICSTATE, init4);
666 GEN_CHECK_OFF(PICSTATE, elcr);
667 GEN_CHECK_OFF(PICSTATE, elcr_mask);
668 GEN_CHECK_OFF(PICSTATE, pDevInsR3);
669 GEN_CHECK_OFF(PICSTATE, pDevInsR0);
670 GEN_CHECK_OFF(PICSTATE, pDevInsRC);
671 GEN_CHECK_OFF(PICSTATE, idxPic);
672 GEN_CHECK_OFF(PICSTATE, auTags);
673
674 GEN_CHECK_SIZE(DEVPIC);
675 GEN_CHECK_OFF(DEVPIC, aPics);
676 GEN_CHECK_OFF(DEVPIC, aPics[1]);
677 GEN_CHECK_OFF(DEVPIC, pDevInsR3);
678 GEN_CHECK_OFF(DEVPIC, pDevInsR0);
679 GEN_CHECK_OFF(DEVPIC, pDevInsRC);
680 GEN_CHECK_OFF(DEVPIC, pPicHlpR3);
681 GEN_CHECK_OFF(DEVPIC, pPicHlpR0);
682 GEN_CHECK_OFF(DEVPIC, pPicHlpRC);
683#ifdef VBOX_WITH_STATISTICS
684 GEN_CHECK_OFF(DEVPIC, StatSetIrqGC);
685 GEN_CHECK_OFF(DEVPIC, StatClearedActiveSlaveIRQ);
686#endif
687
688 /* PC/DevPit-i8254.cpp */
689 GEN_CHECK_SIZE(DMAState);
690 GEN_CHECK_OFF(DMAState, DMAC);
691 GEN_CHECK_OFF(DMAState, DMAC[0].ChState[0]);
692 GEN_CHECK_OFF(DMAState, DMAC[0].ChState[1]);
693 GEN_CHECK_OFF(DMAState, DMAC[0].u8Mask);
694 GEN_CHECK_OFF(DMAState, DMAC[1].ChState[0]);
695 GEN_CHECK_OFF(DMAState, DMAC[1].ChState[1]);
696 GEN_CHECK_OFF(DMAState, DMAC[1].u8Mask);
697
698 /* PC/DevPit-i8254.cpp */
699 GEN_CHECK_SIZE(PITCHANNEL);
700 GEN_CHECK_OFF(PITCHANNEL, pPitR3);
701 GEN_CHECK_OFF(PITCHANNEL, pTimerR3);
702 GEN_CHECK_OFF(PITCHANNEL, pPitR0);
703 GEN_CHECK_OFF(PITCHANNEL, pTimerR0);
704 GEN_CHECK_OFF(PITCHANNEL, pPitRC);
705 GEN_CHECK_OFF(PITCHANNEL, pTimerRC);
706 GEN_CHECK_OFF(PITCHANNEL, u64ReloadTS);
707 GEN_CHECK_OFF(PITCHANNEL, u64NextTS);
708 GEN_CHECK_OFF(PITCHANNEL, count_load_time);
709 GEN_CHECK_OFF(PITCHANNEL, next_transition_time);
710 GEN_CHECK_OFF(PITCHANNEL, irq);
711 GEN_CHECK_OFF(PITCHANNEL, cRelLogEntries);
712 GEN_CHECK_OFF(PITCHANNEL, count);
713 GEN_CHECK_OFF(PITCHANNEL, latched_count);
714 GEN_CHECK_OFF(PITCHANNEL, count_latched);
715 GEN_CHECK_OFF(PITCHANNEL, status_latched);
716 GEN_CHECK_OFF(PITCHANNEL, status);
717 GEN_CHECK_OFF(PITCHANNEL, read_state);
718 GEN_CHECK_OFF(PITCHANNEL, write_state);
719 GEN_CHECK_OFF(PITCHANNEL, write_latch);
720 GEN_CHECK_OFF(PITCHANNEL, rw_mode);
721 GEN_CHECK_OFF(PITCHANNEL, mode);
722 GEN_CHECK_OFF(PITCHANNEL, bcd);
723 GEN_CHECK_OFF(PITCHANNEL, gate);
724 GEN_CHECK_SIZE(PITSTATE);
725 GEN_CHECK_OFF(PITSTATE, channels);
726 GEN_CHECK_OFF(PITSTATE, channels[1]);
727 GEN_CHECK_OFF(PITSTATE, speaker_data_on);
728// GEN_CHECK_OFF(PITSTATE, dummy_refresh_clock);
729 GEN_CHECK_OFF(PITSTATE, IOPortBaseCfg);
730 GEN_CHECK_OFF(PITSTATE, fSpeakerCfg);
731 GEN_CHECK_OFF(PITSTATE, pDevIns);
732 GEN_CHECK_OFF(PITSTATE, StatPITIrq);
733 GEN_CHECK_OFF(PITSTATE, StatPITHandler);
734
735 /* PC/DevRTC.cpp */
736 GEN_CHECK_SIZE(RTCSTATE);
737 GEN_CHECK_OFF(RTCSTATE, cmos_data);
738 GEN_CHECK_OFF(RTCSTATE, cmos_data[1]);
739 GEN_CHECK_OFF(RTCSTATE, cmos_index);
740 GEN_CHECK_OFF(RTCSTATE, current_tm);
741 GEN_CHECK_OFF(RTCSTATE, current_tm.tm_sec);
742 GEN_CHECK_OFF(RTCSTATE, current_tm.tm_min);
743 GEN_CHECK_OFF(RTCSTATE, current_tm.tm_hour);
744 GEN_CHECK_OFF(RTCSTATE, current_tm.tm_mday);
745 GEN_CHECK_OFF(RTCSTATE, current_tm.tm_mon);
746 GEN_CHECK_OFF(RTCSTATE, current_tm.tm_year);
747 GEN_CHECK_OFF(RTCSTATE, current_tm.tm_wday);
748 GEN_CHECK_OFF(RTCSTATE, current_tm.tm_yday);
749 GEN_CHECK_OFF(RTCSTATE, irq);
750 GEN_CHECK_OFF(RTCSTATE, fUTC);
751 GEN_CHECK_OFF(RTCSTATE, IOPortBase);
752 GEN_CHECK_OFF(RTCSTATE, pPeriodicTimerR0);
753 GEN_CHECK_OFF(RTCSTATE, pPeriodicTimerR3);
754 GEN_CHECK_OFF(RTCSTATE, pPeriodicTimerRC);
755 GEN_CHECK_OFF(RTCSTATE, next_periodic_time);
756 GEN_CHECK_OFF(RTCSTATE, next_second_time);
757 GEN_CHECK_OFF(RTCSTATE, pSecondTimerR0);
758 GEN_CHECK_OFF(RTCSTATE, pSecondTimerR3);
759 GEN_CHECK_OFF(RTCSTATE, pSecondTimerRC);
760 GEN_CHECK_OFF(RTCSTATE, pSecondTimer2R0);
761 GEN_CHECK_OFF(RTCSTATE, pSecondTimer2R3);
762 GEN_CHECK_OFF(RTCSTATE, pSecondTimer2RC);
763 GEN_CHECK_OFF(RTCSTATE, pDevInsR0);
764 GEN_CHECK_OFF(RTCSTATE, pDevInsR3);
765 GEN_CHECK_OFF(RTCSTATE, pDevInsRC);
766 GEN_CHECK_OFF(RTCSTATE, RtcReg);
767 GEN_CHECK_OFF(RTCSTATE, pRtcHlpR3);
768 GEN_CHECK_OFF(RTCSTATE, cRelLogEntries);
769 GEN_CHECK_OFF(RTCSTATE, CurLogPeriod);
770 GEN_CHECK_OFF(RTCSTATE, CurHintPeriod);
771
772 GEN_CHECK_SIZE(APIC);
773 GEN_CHECK_OFF(APIC, pApicDevR0);
774 GEN_CHECK_OFF(APIC, pApicDevR3);
775 GEN_CHECK_OFF(APIC, pApicDevRC);
776 GEN_CHECK_OFF(APIC, HCPhysApicPib);
777 GEN_CHECK_OFF(APIC, pvApicPibR0);
778 GEN_CHECK_OFF(APIC, pvApicPibR3);
779 GEN_CHECK_OFF(APIC, pvApicPibRC);
780 GEN_CHECK_OFF(APIC, cbApicPib);
781 GEN_CHECK_OFF(APIC, fVirtApicRegsEnabled);
782 GEN_CHECK_OFF(APIC, fPostedIntrsEnabled);
783 GEN_CHECK_OFF(APIC, fSupportsTscDeadline);
784 GEN_CHECK_OFF(APIC, fIoApicPresent);
785 GEN_CHECK_OFF(APIC, fRZEnabled);
786 GEN_CHECK_OFF(APIC, enmMaxMode);
787
788 GEN_CHECK_SIZE(APICCPU);
789 GEN_CHECK_OFF(APICCPU, pvApicPageR0);
790 GEN_CHECK_OFF(APICCPU, pvApicPageR3);
791 GEN_CHECK_OFF(APICCPU, pvApicPageRC);
792 GEN_CHECK_OFF(APICCPU, cbApicPage);
793 GEN_CHECK_OFF(APICCPU, uEsrInternal);
794 GEN_CHECK_OFF(APICCPU, uApicBaseMsr);
795 GEN_CHECK_OFF(APICCPU, HCPhysApicPib);
796 GEN_CHECK_OFF(APICCPU, pvApicPibR0);
797 GEN_CHECK_OFF(APICCPU, pvApicPibR3);
798 GEN_CHECK_OFF(APICCPU, pvApicPibRC);
799 GEN_CHECK_OFF(APICCPU, ApicPibLevel);
800 GEN_CHECK_OFF(APICCPU, pTimerR0);
801 GEN_CHECK_OFF(APICCPU, pTimerR3);
802 GEN_CHECK_OFF(APICCPU, pTimerRC);
803 GEN_CHECK_OFF(APICCPU, TimerCritSect);
804 GEN_CHECK_OFF(APICCPU, u64TimerInitial);
805 GEN_CHECK_OFF(APICCPU, uHintedTimerInitialCount);
806 GEN_CHECK_OFF(APICCPU, uHintedTimerShift);
807# ifdef VBOX_WITH_STATISTICS
808 GEN_CHECK_OFF(APICCPU, StatMmioReadRZ);
809 GEN_CHECK_OFF(APICCPU, StatMmioReadR3);
810 GEN_CHECK_OFF(APICCPU, StatMmioWriteRZ);
811 GEN_CHECK_OFF(APICCPU, StatMmioWriteR3);
812 GEN_CHECK_OFF(APICCPU, StatMsrReadRZ);
813 GEN_CHECK_OFF(APICCPU, StatMsrReadR3);
814 GEN_CHECK_OFF(APICCPU, StatMsrWriteRZ);
815 GEN_CHECK_OFF(APICCPU, StatMsrWriteR3);
816 GEN_CHECK_OFF(APICCPU, StatUpdatePendingIntrs);
817 GEN_CHECK_OFF(APICCPU, StatPostIntr);
818 GEN_CHECK_OFF(APICCPU, StatPostIntrAlreadyPending);
819 GEN_CHECK_OFF(APICCPU, StatTimerCallback);
820 GEN_CHECK_OFF(APICCPU, StatTprWrite);
821 GEN_CHECK_OFF(APICCPU, StatTprRead);
822 GEN_CHECK_OFF(APICCPU, StatEoiWrite);
823 GEN_CHECK_OFF(APICCPU, StatMaskedByTpr);
824 GEN_CHECK_OFF(APICCPU, StatMaskedByPpr);
825 GEN_CHECK_OFF(APICCPU, StatTimerIcrWrite);
826 GEN_CHECK_OFF(APICCPU, StatIcrLoWrite);
827 GEN_CHECK_OFF(APICCPU, StatIcrHiWrite);
828 GEN_CHECK_OFF(APICCPU, StatIcrFullWrite);
829# endif /* VBOX_WITH_STATISTICS */
830
831 /* PC/DevIoApic.cpp */
832 GEN_CHECK_SIZE(IOAPIC);
833 GEN_CHECK_OFF(IOAPIC, pDevInsR3);
834 GEN_CHECK_OFF(IOAPIC, pIoApicHlpR3);
835 GEN_CHECK_OFF(IOAPIC, pDevInsR0);
836 GEN_CHECK_OFF(IOAPIC, pIoApicHlpR0);
837 GEN_CHECK_OFF(IOAPIC, pDevInsRC);
838 GEN_CHECK_OFF(IOAPIC, pIoApicHlpRC);
839 GEN_CHECK_OFF(IOAPIC, u8Id);
840 GEN_CHECK_OFF(IOAPIC, u8Index);
841 GEN_CHECK_OFF(IOAPIC, cCpus);
842 GEN_CHECK_OFF(IOAPIC, au64RedirTable);
843 GEN_CHECK_OFF(IOAPIC, uIrr);
844# ifdef VBOX_WITH_STATISTICS
845 GEN_CHECK_OFF(IOAPIC, StatMmioReadRZ);
846 GEN_CHECK_OFF(IOAPIC, StatMmioReadR3);
847 GEN_CHECK_OFF(IOAPIC, StatMmioWriteRZ);
848 GEN_CHECK_OFF(IOAPIC, StatMmioWriteR3);
849 GEN_CHECK_OFF(IOAPIC, StatSetIrqRZ);
850 GEN_CHECK_OFF(IOAPIC, StatSetIrqR3);
851 GEN_CHECK_OFF(IOAPIC, StatSetEoiRZ);
852 GEN_CHECK_OFF(IOAPIC, StatSetEoiR3);
853# endif
854
855 /* Storage/DevATA.cpp */
856 GEN_CHECK_SIZE(BMDMAState);
857 GEN_CHECK_OFF(BMDMAState, u8Cmd);
858 GEN_CHECK_OFF(BMDMAState, u8Status);
859 GEN_CHECK_OFF(BMDMAState, GCPhysAddr);
860 GEN_CHECK_SIZE(BMDMADesc);
861 GEN_CHECK_OFF(BMDMADesc, GCPhysBuffer);
862 GEN_CHECK_OFF(BMDMADesc, cbBuffer);
863 GEN_CHECK_SIZE(ATADevState);
864 GEN_CHECK_OFF(ATADevState, fLBA48);
865 GEN_CHECK_OFF(ATADevState, fATAPI);
866 GEN_CHECK_OFF(ATADevState, fIrqPending);
867 GEN_CHECK_OFF(ATADevState, cMultSectors);
868 GEN_CHECK_OFF(ATADevState, cbSector);
869 GEN_CHECK_OFF(ATADevState, PCHSGeometry.cCylinders);
870 GEN_CHECK_OFF(ATADevState, PCHSGeometry.cHeads);
871 GEN_CHECK_OFF(ATADevState, PCHSGeometry.cSectors);
872 GEN_CHECK_OFF(ATADevState, cSectorsPerIRQ);
873 GEN_CHECK_OFF(ATADevState, cTotalSectors);
874 GEN_CHECK_OFF(ATADevState, uATARegFeature);
875 GEN_CHECK_OFF(ATADevState, uATARegFeatureHOB);
876 GEN_CHECK_OFF(ATADevState, uATARegError);
877 GEN_CHECK_OFF(ATADevState, uATARegNSector);
878 GEN_CHECK_OFF(ATADevState, uATARegNSectorHOB);
879 GEN_CHECK_OFF(ATADevState, uATARegSector);
880 GEN_CHECK_OFF(ATADevState, uATARegSectorHOB);
881 GEN_CHECK_OFF(ATADevState, uATARegLCyl);
882 GEN_CHECK_OFF(ATADevState, uATARegLCylHOB);
883 GEN_CHECK_OFF(ATADevState, uATARegHCyl);
884 GEN_CHECK_OFF(ATADevState, uATARegHCylHOB);
885 GEN_CHECK_OFF(ATADevState, uATARegSelect);
886 GEN_CHECK_OFF(ATADevState, uATARegStatus);
887 GEN_CHECK_OFF(ATADevState, uATARegCommand);
888 GEN_CHECK_OFF(ATADevState, uATARegDevCtl);
889 GEN_CHECK_OFF(ATADevState, uATATransferMode);
890 GEN_CHECK_OFF(ATADevState, uTxDir);
891 GEN_CHECK_OFF(ATADevState, iBeginTransfer);
892 GEN_CHECK_OFF(ATADevState, iSourceSink);
893 GEN_CHECK_OFF(ATADevState, fDMA);
894 GEN_CHECK_OFF(ATADevState, fATAPITransfer);
895 GEN_CHECK_OFF(ATADevState, cbTotalTransfer);
896 GEN_CHECK_OFF(ATADevState, cbElementaryTransfer);
897 GEN_CHECK_OFF(ATADevState, iIOBufferCur);
898 GEN_CHECK_OFF(ATADevState, iIOBufferEnd);
899 GEN_CHECK_OFF(ATADevState, iIOBufferPIODataStart);
900 GEN_CHECK_OFF(ATADevState, iIOBufferPIODataEnd);
901 GEN_CHECK_OFF(ATADevState, iATAPILBA);
902 GEN_CHECK_OFF(ATADevState, cbATAPISector);
903 GEN_CHECK_OFF(ATADevState, aATAPICmd);
904 GEN_CHECK_OFF(ATADevState, aATAPICmd[ATAPI_PACKET_SIZE - 1]);
905 GEN_CHECK_OFF(ATADevState, abATAPISense);
906 GEN_CHECK_OFF(ATADevState, abATAPISense[ATAPI_SENSE_SIZE - 1]);
907 GEN_CHECK_OFF(ATADevState, cNotifiedMediaChange);
908 GEN_CHECK_OFF(ATADevState, MediaEventStatus);
909 GEN_CHECK_OFF(ATADevState, MediaTrackType);
910 GEN_CHECK_OFF(ATADevState, Led);
911 GEN_CHECK_OFF(ATADevState, cbIOBuffer);
912 GEN_CHECK_OFF(ATADevState, pbIOBufferR3);
913 GEN_CHECK_OFF(ATADevState, pbIOBufferR0);
914 GEN_CHECK_OFF(ATADevState, pbIOBufferRC);
915 GEN_CHECK_OFF(ATADevState, StatATADMA);
916 GEN_CHECK_OFF(ATADevState, StatATAPIO);
917 GEN_CHECK_OFF(ATADevState, StatATAPIDMA);
918 GEN_CHECK_OFF(ATADevState, StatATAPIPIO);
919 GEN_CHECK_OFF(ATADevState, StatReads);
920 GEN_CHECK_OFF(ATADevState, StatBytesRead);
921 GEN_CHECK_OFF(ATADevState, StatWrites);
922 GEN_CHECK_OFF(ATADevState, StatBytesWritten);
923 GEN_CHECK_OFF(ATADevState, StatFlushes);
924 GEN_CHECK_OFF(ATADevState, fATAPIPassthrough);
925 GEN_CHECK_OFF(ATADevState, fOverwriteInquiry);
926 GEN_CHECK_OFF(ATADevState, cErrors);
927 GEN_CHECK_OFF(ATADevState, pDrvBase);
928 GEN_CHECK_OFF(ATADevState, pDrvMedia);
929 GEN_CHECK_OFF(ATADevState, pDrvMount);
930 GEN_CHECK_OFF(ATADevState, IBase);
931 GEN_CHECK_OFF(ATADevState, IPort);
932 GEN_CHECK_OFF(ATADevState, IMountNotify);
933 GEN_CHECK_OFF(ATADevState, iLUN);
934 GEN_CHECK_OFF(ATADevState, pDevInsR3);
935 GEN_CHECK_OFF(ATADevState, pDevInsR0);
936 GEN_CHECK_OFF(ATADevState, pDevInsRC);
937 GEN_CHECK_OFF(ATADevState, pControllerR3);
938 GEN_CHECK_OFF(ATADevState, pControllerR0);
939 GEN_CHECK_OFF(ATADevState, pControllerRC);
940 GEN_CHECK_OFF(ATADevState, szSerialNumber);
941 GEN_CHECK_OFF(ATADevState, szSerialNumber[ATA_SERIAL_NUMBER_LENGTH]);
942 GEN_CHECK_OFF(ATADevState, szFirmwareRevision);
943 GEN_CHECK_OFF(ATADevState, szFirmwareRevision[ATA_FIRMWARE_REVISION_LENGTH]);
944 GEN_CHECK_OFF(ATADevState, szModelNumber);
945 GEN_CHECK_OFF(ATADevState, szModelNumber[ATA_MODEL_NUMBER_LENGTH]);
946 GEN_CHECK_OFF(ATADevState, szInquiryVendorId);
947 GEN_CHECK_OFF(ATADevState, szInquiryVendorId[SCSI_INQUIRY_VENDOR_ID_LENGTH]);
948 GEN_CHECK_OFF(ATADevState, szInquiryProductId);
949 GEN_CHECK_OFF(ATADevState, szInquiryProductId[SCSI_INQUIRY_PRODUCT_ID_LENGTH]);
950 GEN_CHECK_OFF(ATADevState, szInquiryRevision);
951 GEN_CHECK_OFF(ATADevState, szInquiryRevision[SCSI_INQUIRY_REVISION_LENGTH]);
952 GEN_CHECK_OFF(ATADevState, pTrackList);
953 GEN_CHECK_SIZE(ATATransferRequest);
954 GEN_CHECK_OFF(ATATransferRequest, iIf);
955 GEN_CHECK_OFF(ATATransferRequest, iBeginTransfer);
956 GEN_CHECK_OFF(ATATransferRequest, iSourceSink);
957 GEN_CHECK_OFF(ATATransferRequest, cbTotalTransfer);
958 GEN_CHECK_OFF(ATATransferRequest, uTxDir);
959 GEN_CHECK_SIZE(ATAAbortRequest);
960 GEN_CHECK_OFF(ATAAbortRequest, iIf);
961 GEN_CHECK_OFF(ATAAbortRequest, fResetDrive);
962 GEN_CHECK_SIZE(ATARequest);
963 GEN_CHECK_OFF(ATARequest, ReqType);
964 GEN_CHECK_OFF(ATARequest, u);
965 GEN_CHECK_OFF(ATARequest, u.t);
966 GEN_CHECK_OFF(ATARequest, u.a);
967 GEN_CHECK_SIZE(ATACONTROLLER);
968 GEN_CHECK_OFF(ATACONTROLLER, IOPortBase1);
969 GEN_CHECK_OFF(ATACONTROLLER, IOPortBase2);
970 GEN_CHECK_OFF(ATACONTROLLER, irq);
971 GEN_CHECK_OFF(ATACONTROLLER, lock);
972 GEN_CHECK_OFF(ATACONTROLLER, iSelectedIf);
973 GEN_CHECK_OFF(ATACONTROLLER, iAIOIf);
974 GEN_CHECK_OFF(ATACONTROLLER, uAsyncIOState);
975 GEN_CHECK_OFF(ATACONTROLLER, fChainedTransfer);
976 GEN_CHECK_OFF(ATACONTROLLER, fReset);
977 GEN_CHECK_OFF(ATACONTROLLER, fRedo);
978 GEN_CHECK_OFF(ATACONTROLLER, fRedoIdle);
979 GEN_CHECK_OFF(ATACONTROLLER, fRedoDMALastDesc);
980 GEN_CHECK_OFF(ATACONTROLLER, BmDma);
981 GEN_CHECK_OFF(ATACONTROLLER, GCPhysFirstDMADesc);
982 GEN_CHECK_OFF(ATACONTROLLER, GCPhysLastDMADesc);
983 GEN_CHECK_OFF(ATACONTROLLER, GCPhysRedoDMABuffer);
984 GEN_CHECK_OFF(ATACONTROLLER, cbRedoDMABuffer);
985 GEN_CHECK_OFF(ATACONTROLLER, aIfs);
986 GEN_CHECK_OFF(ATACONTROLLER, aIfs[1]);
987 GEN_CHECK_OFF(ATACONTROLLER, pDevInsR3);
988 GEN_CHECK_OFF(ATACONTROLLER, pDevInsR0);
989 GEN_CHECK_OFF(ATACONTROLLER, pDevInsRC);
990 GEN_CHECK_OFF(ATACONTROLLER, fShutdown);
991 GEN_CHECK_OFF(ATACONTROLLER, AsyncIOThread);
992 GEN_CHECK_OFF(ATACONTROLLER, hAsyncIOSem);
993 GEN_CHECK_OFF(ATACONTROLLER, aAsyncIORequests[4]);
994 GEN_CHECK_OFF(ATACONTROLLER, AsyncIOReqHead);
995 GEN_CHECK_OFF(ATACONTROLLER, AsyncIOReqTail);
996 GEN_CHECK_OFF(ATACONTROLLER, AsyncIORequestLock);
997 GEN_CHECK_OFF(ATACONTROLLER, SuspendIOSem);
998 GEN_CHECK_OFF(ATACONTROLLER, fSignalIdle);
999 GEN_CHECK_OFF(ATACONTROLLER, DelayIRQMillies);
1000 GEN_CHECK_OFF(ATACONTROLLER, u64ResetTime);
1001 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncOps);
1002 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncMinWait);
1003 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncMaxWait);
1004 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncTimeUS);
1005 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncTime);
1006 GEN_CHECK_OFF(ATACONTROLLER, StatLockWait);
1007 GEN_CHECK_SIZE(PCIATAState);
1008 GEN_CHECK_OFF(PCIATAState, dev);
1009 GEN_CHECK_OFF(PCIATAState, aCts);
1010 GEN_CHECK_OFF(PCIATAState, aCts[1]);
1011 GEN_CHECK_OFF(PCIATAState, pDevIns);
1012 GEN_CHECK_OFF(PCIATAState, IBase);
1013 GEN_CHECK_OFF(PCIATAState, ILeds);
1014 GEN_CHECK_OFF(PCIATAState, pLedsConnector);
1015 GEN_CHECK_OFF(PCIATAState, fRCEnabled);
1016 GEN_CHECK_OFF(PCIATAState, fR0Enabled);
1017
1018#ifdef VBOX_WITH_USB
1019 /* USB/DevOHCI.cpp */
1020 GEN_CHECK_SIZE(OHCIHUBPORT);
1021 GEN_CHECK_OFF(OHCIHUBPORT, fReg);
1022 GEN_CHECK_OFF(OHCIHUBPORT, pDev);
1023
1024 GEN_CHECK_SIZE(OHCIROOTHUB);
1025 GEN_CHECK_OFF(OHCIROOTHUB, pIBase);
1026 GEN_CHECK_OFF(OHCIROOTHUB, pIRhConn);
1027 GEN_CHECK_OFF(OHCIROOTHUB, pIDev);
1028 GEN_CHECK_OFF(OHCIROOTHUB, IBase);
1029 GEN_CHECK_OFF(OHCIROOTHUB, IRhPort);
1030 GEN_CHECK_OFF(OHCIROOTHUB, status);
1031 GEN_CHECK_OFF(OHCIROOTHUB, desc_a);
1032 GEN_CHECK_OFF(OHCIROOTHUB, desc_b);
1033 GEN_CHECK_OFF(OHCIROOTHUB, aPorts);
1034 GEN_CHECK_OFF(OHCIROOTHUB, aPorts[1]);
1035 GEN_CHECK_OFF(OHCIROOTHUB, aPorts[OHCI_NDP_MAX - 1]);
1036 GEN_CHECK_OFF(OHCIROOTHUB, pOhci);
1037
1038 GEN_CHECK_SIZE(OHCI);
1039 GEN_CHECK_OFF(OHCI, PciDev);
1040 GEN_CHECK_OFF(OHCI, MMIOBase);
1041 GEN_CHECK_OFF(OHCI, pEndOfFrameTimerR3);
1042 GEN_CHECK_OFF(OHCI, pEndOfFrameTimerR0);
1043 GEN_CHECK_OFF(OHCI, pEndOfFrameTimerRC);
1044 GEN_CHECK_OFF(OHCI, pDevInsR3);
1045 GEN_CHECK_OFF(OHCI, pDevInsR0);
1046 GEN_CHECK_OFF(OHCI, pDevInsRC);
1047 GEN_CHECK_OFF(OHCI, SofTime);
1048 //GEN_CHECK_OFF(OHCI, dqic:3);
1049 //GEN_CHECK_OFF(OHCI, fno:1);
1050 GEN_CHECK_OFF(OHCI, RootHub);
1051 GEN_CHECK_OFF(OHCI, ctl);
1052 GEN_CHECK_OFF(OHCI, status);
1053 GEN_CHECK_OFF(OHCI, intr_status);
1054 GEN_CHECK_OFF(OHCI, intr);
1055 GEN_CHECK_OFF(OHCI, hcca);
1056 GEN_CHECK_OFF(OHCI, per_cur);
1057 GEN_CHECK_OFF(OHCI, ctrl_cur);
1058 GEN_CHECK_OFF(OHCI, ctrl_head);
1059 GEN_CHECK_OFF(OHCI, bulk_cur);
1060 GEN_CHECK_OFF(OHCI, bulk_head);
1061 GEN_CHECK_OFF(OHCI, done);
1062 //GEN_CHECK_OFF(OHCI, fsmps:15);
1063 //GEN_CHECK_OFF(OHCI, fit:1);
1064 //GEN_CHECK_OFF(OHCI, fi:14);
1065 //GEN_CHECK_OFF(OHCI, frt:1);
1066 GEN_CHECK_OFF(OHCI, HcFmNumber);
1067 GEN_CHECK_OFF(OHCI, pstart);
1068 GEN_CHECK_OFF(OHCI, cTicksPerFrame);
1069 GEN_CHECK_OFF(OHCI, cTicksPerUsbTick);
1070 GEN_CHECK_OFF(OHCI, cInFlight);
1071 GEN_CHECK_OFF(OHCI, aInFlight);
1072 GEN_CHECK_OFF(OHCI, aInFlight[0].GCPhysTD);
1073 GEN_CHECK_OFF(OHCI, aInFlight[0].pUrb);
1074 GEN_CHECK_OFF(OHCI, aInFlight[1]);
1075 GEN_CHECK_OFF(OHCI, cInDoneQueue);
1076 GEN_CHECK_OFF(OHCI, aInDoneQueue);
1077 GEN_CHECK_OFF(OHCI, aInDoneQueue[0].GCPhysTD);
1078 GEN_CHECK_OFF(OHCI, aInDoneQueue[1]);
1079 GEN_CHECK_OFF(OHCI, u32FmDoneQueueTail);
1080 GEN_CHECK_OFF(OHCI, pLoad);
1081# ifdef VBOX_WITH_STATISTICS
1082 GEN_CHECK_OFF(OHCI, StatCanceledIsocUrbs);
1083 GEN_CHECK_OFF(OHCI, StatCanceledGenUrbs);
1084 GEN_CHECK_OFF(OHCI, StatDroppedUrbs);
1085 GEN_CHECK_OFF(OHCI, StatTimer);
1086# endif
1087 GEN_CHECK_OFF(OHCI, CsIrq);
1088 GEN_CHECK_OFF(OHCI, CritSect);
1089
1090# ifdef VBOX_WITH_EHCI_IMPL
1091 /* USB/DevEHCI.cpp */
1092 GEN_CHECK_SIZE(EHCIHUBPORT);
1093 GEN_CHECK_OFF(EHCIHUBPORT, fReg);
1094 GEN_CHECK_OFF(EHCIHUBPORT, pDev);
1095
1096 GEN_CHECK_SIZE(EHCIROOTHUB);
1097 GEN_CHECK_OFF(EHCIROOTHUB, pIBase);
1098 GEN_CHECK_OFF(EHCIROOTHUB, pIRhConn);
1099 GEN_CHECK_OFF(EHCIROOTHUB, pIDev);
1100 GEN_CHECK_OFF(EHCIROOTHUB, IBase);
1101 GEN_CHECK_OFF(EHCIROOTHUB, IRhPort);
1102 GEN_CHECK_OFF(EHCIROOTHUB, Led);
1103 GEN_CHECK_OFF(EHCIROOTHUB, ILeds);
1104 GEN_CHECK_OFF(EHCIROOTHUB, pLedsConnector);
1105 GEN_CHECK_OFF(EHCIROOTHUB, aPorts);
1106 GEN_CHECK_OFF(EHCIROOTHUB, aPorts[1]);
1107 GEN_CHECK_OFF(EHCIROOTHUB, aPorts[EHCI_NDP_MAX - 1]);
1108 GEN_CHECK_OFF(EHCIROOTHUB, pEhci);
1109
1110 GEN_CHECK_SIZE(EHCI);
1111 GEN_CHECK_OFF(EHCI, PciDev);
1112 GEN_CHECK_OFF(EHCI, MMIOBase);
1113 GEN_CHECK_OFF(EHCI, pDevInsR3);
1114 GEN_CHECK_OFF(EHCI, pDevInsR0);
1115 GEN_CHECK_OFF(EHCI, pDevInsRC);
1116 GEN_CHECK_OFF(EHCI, MMIOBase);
1117 GEN_CHECK_OFF(EHCI, SofTime);
1118 GEN_CHECK_OFF(EHCI, RootHub);
1119 GEN_CHECK_OFF(EHCI, cap_length);
1120 GEN_CHECK_OFF(EHCI, hci_version);
1121 GEN_CHECK_OFF(EHCI, hcs_params);
1122 GEN_CHECK_OFF(EHCI, hcc_params);
1123 GEN_CHECK_OFF(EHCI, cmd);
1124 GEN_CHECK_OFF(EHCI, intr_status);
1125 GEN_CHECK_OFF(EHCI, intr);
1126 GEN_CHECK_OFF(EHCI, frame_idx);
1127 GEN_CHECK_OFF(EHCI, ds_segment);
1128 GEN_CHECK_OFF(EHCI, periodic_list_base);
1129 GEN_CHECK_OFF(EHCI, async_list_base);
1130 GEN_CHECK_OFF(EHCI, config);
1131 GEN_CHECK_OFF(EHCI, uIrqInterval);
1132 GEN_CHECK_OFF(EHCI, HcFmNumber);
1133 GEN_CHECK_OFF(EHCI, uFramesPerTimerCall);
1134 GEN_CHECK_OFF(EHCI, cTicksPerFrame);
1135 GEN_CHECK_OFF(EHCI, cTicksPerUsbTick);
1136 GEN_CHECK_OFF(EHCI, cInFlight);
1137 GEN_CHECK_OFF(EHCI, aInFlight);
1138 GEN_CHECK_OFF(EHCI, aInFlight[0].GCPhysTD);
1139 GEN_CHECK_OFF(EHCI, aInFlight[0].pUrb);
1140 GEN_CHECK_OFF(EHCI, aInFlight[1]);
1141 GEN_CHECK_OFF(EHCI, aInFlight[256]);
1142 GEN_CHECK_OFF(EHCI, pLoad);
1143 GEN_CHECK_OFF(EHCI, fAsyncTraversalTimerActive);
1144# ifdef VBOX_WITH_STATISTICS
1145 GEN_CHECK_OFF(EHCI, StatCanceledIsocUrbs);
1146 GEN_CHECK_OFF(EHCI, StatCanceledGenUrbs);
1147 GEN_CHECK_OFF(EHCI, StatDroppedUrbs);
1148# endif
1149 GEN_CHECK_OFF(EHCI, u64TimerHz);
1150 GEN_CHECK_OFF(EHCI, cIdleCycles);
1151 GEN_CHECK_OFF(EHCI, uFrameRate);
1152 GEN_CHECK_OFF(EHCI, fIdle);
1153 GEN_CHECK_OFF(EHCI, hThreadFrame);
1154 GEN_CHECK_OFF(EHCI, hSemEventFrame);
1155 GEN_CHECK_OFF(EHCI, fBusStarted);
1156 GEN_CHECK_OFF(EHCI, CsIrq);
1157 GEN_CHECK_OFF(EHCI, uFrameRateDefault);
1158 GEN_CHECK_OFF(EHCI, nsWait);
1159 GEN_CHECK_OFF(EHCI, CritSect);
1160# endif /* VBOX_WITH_EHCI_IMPL */
1161
1162# ifdef VBOX_WITH_XHCI_IMPL
1163 /* USB/DevXHCI.cpp */
1164 GEN_CHECK_SIZE(XHCIHUBPORT);
1165 GEN_CHECK_OFF(XHCIHUBPORT, portsc);
1166 GEN_CHECK_OFF(XHCIHUBPORT, portpm);
1167 GEN_CHECK_OFF(XHCIHUBPORT, portli);
1168 GEN_CHECK_OFF(XHCIHUBPORT, pDev);
1169
1170 GEN_CHECK_SIZE(XHCIROOTHUB);
1171 GEN_CHECK_OFF(XHCIROOTHUB, pIBase);
1172 GEN_CHECK_OFF(XHCIROOTHUB, pIRhConn);
1173 GEN_CHECK_OFF(XHCIROOTHUB, pIDev);
1174 GEN_CHECK_OFF(XHCIROOTHUB, IBase);
1175 GEN_CHECK_OFF(XHCIROOTHUB, IRhPort);
1176 GEN_CHECK_OFF(XHCIROOTHUB, Led);
1177 GEN_CHECK_OFF(XHCIROOTHUB, cPortsImpl);
1178 GEN_CHECK_OFF(XHCIROOTHUB, pXhci);
1179
1180 GEN_CHECK_SIZE(XHCIINTRPTR);
1181 GEN_CHECK_OFF(XHCIINTRPTR, iman);
1182 GEN_CHECK_OFF(XHCIINTRPTR, imod);
1183 GEN_CHECK_OFF(XHCIINTRPTR, erstba);
1184 GEN_CHECK_OFF(XHCIINTRPTR, erdp);
1185 GEN_CHECK_OFF(XHCIINTRPTR, erep);
1186 GEN_CHECK_OFF(XHCIINTRPTR, erst_idx);
1187 GEN_CHECK_OFF(XHCIINTRPTR, trb_count);
1188 GEN_CHECK_OFF(XHCIINTRPTR, evtr_pcs);
1189 GEN_CHECK_OFF(XHCIINTRPTR, ipe);
1190
1191 GEN_CHECK_SIZE(XHCI);
1192 GEN_CHECK_OFF(XHCI, PciDev);
1193 GEN_CHECK_OFF(XHCI, pDevInsR3);
1194 GEN_CHECK_OFF(XHCI, pDevInsR0);
1195 GEN_CHECK_OFF(XHCI, pDevInsRC);
1196 GEN_CHECK_OFF(XHCI, pNotifierQueueR3);
1197 GEN_CHECK_OFF(XHCI, pNotifierQueueR0);
1198 GEN_CHECK_OFF(XHCI, pNotifierQueueRC);
1199 GEN_CHECK_OFF(XHCI, pWrapTimerR3);
1200 GEN_CHECK_OFF(XHCI, pWrapTimerR0);
1201 GEN_CHECK_OFF(XHCI, pWrapTimerRC);
1202 GEN_CHECK_OFF(XHCI, pWorkerThread);
1203 GEN_CHECK_OFF(XHCI, pSupDrvSession);
1204 GEN_CHECK_OFF(XHCI, hEvtProcess);
1205 GEN_CHECK_OFF(XHCI, fWrkThreadSleeping);
1206 GEN_CHECK_OFF(XHCI, u32TasksNew);
1207 GEN_CHECK_OFF(XHCI, ILeds);
1208 GEN_CHECK_OFF(XHCI, pLedsConnector);
1209 GEN_CHECK_OFF(XHCI, MMIOBase);
1210 GEN_CHECK_OFF(XHCI, RootHub2);
1211 GEN_CHECK_OFF(XHCI, RootHub3);
1212 GEN_CHECK_OFF(XHCI, aPorts);
1213 GEN_CHECK_OFF(XHCI, aPorts[1]);
1214 GEN_CHECK_OFF(XHCI, aPorts[XHCI_NDP_MAX - 1]);
1215 GEN_CHECK_OFF(XHCI, cap_length);
1216 GEN_CHECK_OFF(XHCI, hci_version);
1217 GEN_CHECK_OFF(XHCI, hcs_params3);
1218 GEN_CHECK_OFF(XHCI, hcc_params);
1219 GEN_CHECK_OFF(XHCI, dbell_off);
1220 GEN_CHECK_OFF(XHCI, rts_off);
1221 GEN_CHECK_OFF(XHCI, cmd);
1222 GEN_CHECK_OFF(XHCI, status);
1223 GEN_CHECK_OFF(XHCI, dnctrl);
1224 GEN_CHECK_OFF(XHCI, config);
1225 GEN_CHECK_OFF(XHCI, crcr);
1226 GEN_CHECK_OFF(XHCI, dcbaap);
1227 GEN_CHECK_OFF(XHCI, abExtCap);
1228 GEN_CHECK_OFF(XHCI, cbExtCap);
1229 GEN_CHECK_OFF(XHCI, cmdr_dqp);
1230 GEN_CHECK_OFF(XHCI, cmdr_ccs);
1231 GEN_CHECK_OFF(XHCI, aSlotState);
1232 GEN_CHECK_OFF(XHCI, aBellsRung);
1233 GEN_CHECK_OFF(XHCI, pLoad);
1234# ifdef VBOX_WITH_STATISTICS
1235 GEN_CHECK_OFF(XHCI, StatErrorIsocUrbs);
1236 GEN_CHECK_OFF(XHCI, StatErrorIsocPkts);
1237 GEN_CHECK_OFF(XHCI, StatEventsWritten);
1238 GEN_CHECK_OFF(XHCI, StatEventsDropped);
1239 GEN_CHECK_OFF(XHCI, StatIntrsPending);
1240 GEN_CHECK_OFF(XHCI, StatIntrsSet);
1241 GEN_CHECK_OFF(XHCI, StatIntrsNotSet);
1242 GEN_CHECK_OFF(XHCI, StatIntrsCleared);
1243# endif
1244# endif /* VBOX_WITH_XHCI_IMPL */
1245#endif /* VBOX_WITH_USB */
1246
1247 /* Parallel/DevParallel.cpp */
1248 GEN_CHECK_SIZE(PARALLELPORT);
1249 GEN_CHECK_OFF(PARALLELPORT, pDevInsR3);
1250 GEN_CHECK_OFF(PARALLELPORT, pDevInsR0);
1251 GEN_CHECK_OFF(PARALLELPORT, pDevInsRC);
1252 GEN_CHECK_OFF(PARALLELPORT, IBase);
1253 GEN_CHECK_OFF(PARALLELPORT, IHostParallelPort);
1254 GEN_CHECK_OFF(PARALLELPORT, pDrvHostParallelConnector);
1255 GEN_CHECK_OFF(PARALLELPORT, fGCEnabled);
1256 GEN_CHECK_OFF(PARALLELPORT, fR0Enabled);
1257 GEN_CHECK_OFF(PARALLELPORT, fEppTimeout);
1258 GEN_CHECK_OFF(PARALLELPORT, IOBase);
1259 GEN_CHECK_OFF(PARALLELPORT, iIrq);
1260 GEN_CHECK_OFF(PARALLELPORT, regData);
1261 GEN_CHECK_OFF(PARALLELPORT, regStatus);
1262 GEN_CHECK_OFF(PARALLELPORT, regControl);
1263 GEN_CHECK_OFF(PARALLELPORT, regEppAddr);
1264 GEN_CHECK_OFF(PARALLELPORT, regEppData);
1265#if 0
1266 GEN_CHECK_OFF(PARALLELPORT, reg_ecp_ecr);
1267 GEN_CHECK_OFF(PARALLELPORT, reg_ecp_base_plus_400h);
1268 GEN_CHECK_OFF(PARALLELPORT, reg_ecp_config_b);
1269 GEN_CHECK_OFF(PARALLELPORT, ecp_fifo);
1270 GEN_CHECK_OFF(PARALLELPORT, ecp_fifo[1]);
1271 GEN_CHECK_OFF(PARALLELPORT, act_fifo_pos_write);
1272 GEN_CHECK_OFF(PARALLELPORT, act_fifo_pos_read);
1273#endif
1274
1275 /* Serial/UartCore.cpp */
1276 GEN_CHECK_SIZE(UARTCORE);
1277 GEN_CHECK_OFF(UARTCORE, CritSect);
1278 GEN_CHECK_OFF(UARTCORE, pDevInsR3);
1279 GEN_CHECK_OFF(UARTCORE, pDevInsR0);
1280 GEN_CHECK_OFF(UARTCORE, pDevInsRC);
1281 GEN_CHECK_OFF(UARTCORE, iLUN);
1282 GEN_CHECK_OFF(UARTCORE, IBase);
1283 GEN_CHECK_OFF(UARTCORE, ISerialPort);
1284 GEN_CHECK_OFF(UARTCORE, pDrvBase);
1285 GEN_CHECK_OFF(UARTCORE, pDrvSerial);
1286 GEN_CHECK_OFF(UARTCORE, fFlags);
1287 GEN_CHECK_OFF(UARTCORE, enmType);
1288 GEN_CHECK_OFF(UARTCORE, pTimerRcvFifoTimeoutR3);
1289 GEN_CHECK_OFF(UARTCORE, pTimerTxUnconnectedR3);
1290 GEN_CHECK_OFF(UARTCORE, pfnUartIrqReqR3);
1291 GEN_CHECK_OFF(UARTCORE, pTimerRcvFifoTimeoutR0);
1292 GEN_CHECK_OFF(UARTCORE, pTimerTxUnconnectedR0);
1293 GEN_CHECK_OFF(UARTCORE, pfnUartIrqReqR0);
1294 GEN_CHECK_OFF(UARTCORE, pTimerRcvFifoTimeoutRC);
1295 GEN_CHECK_OFF(UARTCORE, pTimerTxUnconnectedRC);
1296 GEN_CHECK_OFF(UARTCORE, pfnUartIrqReqRC);
1297 GEN_CHECK_OFF(UARTCORE, uRegDivisor);
1298 GEN_CHECK_OFF(UARTCORE, uRegRbr);
1299 GEN_CHECK_OFF(UARTCORE, uRegThr);
1300 GEN_CHECK_OFF(UARTCORE, uRegIer);
1301 GEN_CHECK_OFF(UARTCORE, uRegIir);
1302 GEN_CHECK_OFF(UARTCORE, uRegFcr);
1303 GEN_CHECK_OFF(UARTCORE, uRegLcr);
1304 GEN_CHECK_OFF(UARTCORE, uRegMcr);
1305 GEN_CHECK_OFF(UARTCORE, uRegLsr);
1306 GEN_CHECK_OFF(UARTCORE, uRegMsr);
1307 GEN_CHECK_OFF(UARTCORE, uRegScr);
1308 GEN_CHECK_OFF(UARTCORE, fIrqCtiPending);
1309 GEN_CHECK_OFF(UARTCORE, fThreEmptyPending);
1310 GEN_CHECK_OFF(UARTCORE, FifoXmit);
1311 GEN_CHECK_OFF(UARTCORE, FifoRecv);
1312 GEN_CHECK_OFF(UARTCORE, cSymbolXferTicks);
1313 GEN_CHECK_OFF(UARTCORE, cbAvailRdr);
1314
1315 /* Serial/DevSerial.cpp */
1316 GEN_CHECK_SIZE(DEVSERIAL);
1317 GEN_CHECK_OFF(DEVSERIAL, pDevInsR3);
1318 GEN_CHECK_OFF(DEVSERIAL, pDevInsR0);
1319 GEN_CHECK_OFF(DEVSERIAL, pDevInsRC);
1320 GEN_CHECK_OFF(DEVSERIAL, fR0Enabled);
1321 GEN_CHECK_OFF(DEVSERIAL, fRCEnabled);
1322 GEN_CHECK_OFF(DEVSERIAL, uIrq);
1323 GEN_CHECK_OFF(DEVSERIAL, PortBase);
1324 GEN_CHECK_OFF(DEVSERIAL, UartCore);
1325
1326 /* Serial/DevOxPcie958.cpp */
1327 GEN_CHECK_SIZE(DEVOX958);
1328 GEN_CHECK_OFF(DEVOX958, PciDev);
1329 GEN_CHECK_OFF(DEVOX958, pDevInsR3);
1330 GEN_CHECK_OFF(DEVOX958, pDevInsR0);
1331 GEN_CHECK_OFF(DEVOX958, pDevInsRC);
1332 GEN_CHECK_OFF(DEVOX958, fR0Enabled);
1333 GEN_CHECK_OFF(DEVOX958, fRCEnabled);
1334 GEN_CHECK_OFF(DEVOX958, u32RegIrqStsGlob);
1335 GEN_CHECK_OFF(DEVOX958, u32RegIrqEnGlob);
1336 GEN_CHECK_OFF(DEVOX958, u32RegIrqEnWake);
1337 GEN_CHECK_OFF(DEVOX958, cUarts);
1338 GEN_CHECK_OFF(DEVOX958, GCPhysMMIO);
1339 GEN_CHECK_OFF(DEVOX958, aUarts);
1340 GEN_CHECK_OFF(DEVOX958, aUarts[OX958_UARTS_MAX - 1]);
1341
1342#ifdef VBOX_WITH_AHCI
1343 /* Storage/DevAHCI.cpp */
1344
1345 GEN_CHECK_SIZE(AHCIPort);
1346 GEN_CHECK_OFF(AHCIPort, pDevInsR3);
1347 GEN_CHECK_OFF(AHCIPort, pDevInsR0);
1348 GEN_CHECK_OFF(AHCIPort, pDevInsRC);
1349 GEN_CHECK_OFF(AHCIPort, pAhciR3);
1350 GEN_CHECK_OFF(AHCIPort, pAhciR0);
1351 GEN_CHECK_OFF(AHCIPort, pAhciRC);
1352 GEN_CHECK_OFF(AHCIPort, regCLB);
1353 GEN_CHECK_OFF(AHCIPort, regCLBU);
1354 GEN_CHECK_OFF(AHCIPort, regFB);
1355 GEN_CHECK_OFF(AHCIPort, regFBU);
1356 GEN_CHECK_OFF(AHCIPort, regIS);
1357 GEN_CHECK_OFF(AHCIPort, regIE);
1358 GEN_CHECK_OFF(AHCIPort, regCMD);
1359 GEN_CHECK_OFF(AHCIPort, regTFD);
1360 GEN_CHECK_OFF(AHCIPort, regSIG);
1361 GEN_CHECK_OFF(AHCIPort, regSSTS);
1362 GEN_CHECK_OFF(AHCIPort, regSCTL);
1363 GEN_CHECK_OFF(AHCIPort, regSERR);
1364 GEN_CHECK_OFF(AHCIPort, regSACT);
1365 GEN_CHECK_OFF(AHCIPort, regCI);
1366 GEN_CHECK_OFF(AHCIPort, cTasksActive);
1367 GEN_CHECK_OFF(AHCIPort, GCPhysAddrClb);
1368 GEN_CHECK_OFF(AHCIPort, GCPhysAddrFb);
1369 GEN_CHECK_OFF(AHCIPort, fPoweredOn);
1370 GEN_CHECK_OFF(AHCIPort, fSpunUp);
1371 GEN_CHECK_OFF(AHCIPort, fFirstD2HFisSent);
1372 GEN_CHECK_OFF(AHCIPort, fATAPI);
1373 GEN_CHECK_OFF(AHCIPort, fPortReset);
1374 GEN_CHECK_OFF(AHCIPort, fTrimEnabled);
1375 GEN_CHECK_OFF(AHCIPort, fResetDevice);
1376 GEN_CHECK_OFF(AHCIPort, fHotpluggable);
1377 GEN_CHECK_OFF(AHCIPort, fRedo);
1378 GEN_CHECK_OFF(AHCIPort, fWrkThreadSleeping);
1379 GEN_CHECK_OFF(AHCIPort, cTotalSectors);
1380 GEN_CHECK_OFF(AHCIPort, cbSector);
1381 GEN_CHECK_OFF(AHCIPort, cMultSectors);
1382 GEN_CHECK_OFF(AHCIPort, uATATransferMode);
1383 GEN_CHECK_OFF(AHCIPort, abATAPISense);
1384 GEN_CHECK_OFF(AHCIPort, cLogSectorsPerPhysicalExp);
1385 GEN_CHECK_OFF(AHCIPort, iLUN);
1386 GEN_CHECK_OFF(AHCIPort, u32TasksFinished);
1387 GEN_CHECK_OFF(AHCIPort, u32QueuedTasksFinished);
1388 GEN_CHECK_OFF(AHCIPort, u32TasksNew);
1389 GEN_CHECK_OFF(AHCIPort, u32TasksRedo);
1390 GEN_CHECK_OFF(AHCIPort, u32CurrentCommandSlot);
1391 GEN_CHECK_OFF(AHCIPort, pDrvBase);
1392 GEN_CHECK_OFF(AHCIPort, pDrvMedia);
1393 GEN_CHECK_OFF(AHCIPort, pDrvMediaEx);
1394 GEN_CHECK_OFF(AHCIPort, pszDesc);
1395 GEN_CHECK_OFF(AHCIPort, IBase);
1396 GEN_CHECK_OFF(AHCIPort, IPort);
1397 GEN_CHECK_OFF(AHCIPort, IMediaExPort);
1398 GEN_CHECK_OFF(AHCIPort, PCHSGeometry);
1399 GEN_CHECK_OFF(AHCIPort, Led);
1400 GEN_CHECK_OFF(AHCIPort, pAsyncIOThread);
1401
1402 GEN_CHECK_OFF(AHCIPort, pTaskErr);
1403 GEN_CHECK_OFF(AHCIPort, hEvtProcess);
1404 GEN_CHECK_OFF(AHCIPort, szSerialNumber);
1405 GEN_CHECK_OFF(AHCIPort, szSerialNumber[AHCI_SERIAL_NUMBER_LENGTH]); /* One additional byte for the termination.*/
1406 GEN_CHECK_OFF(AHCIPort, szFirmwareRevision);
1407 GEN_CHECK_OFF(AHCIPort, szFirmwareRevision[AHCI_FIRMWARE_REVISION_LENGTH]); /* One additional byte for the termination.*/
1408 GEN_CHECK_OFF(AHCIPort, szModelNumber);
1409 GEN_CHECK_OFF(AHCIPort, szModelNumber[AHCI_MODEL_NUMBER_LENGTH]); /* One additional byte for the termination.*/
1410 GEN_CHECK_OFF(AHCIPort, szInquiryVendorId);
1411 GEN_CHECK_OFF(AHCIPort, szInquiryVendorId[AHCI_ATAPI_INQUIRY_VENDOR_ID_LENGTH]); /* One additional byte for the termination.*/
1412 GEN_CHECK_OFF(AHCIPort, szInquiryProductId);
1413 GEN_CHECK_OFF(AHCIPort, szInquiryProductId[AHCI_ATAPI_INQUIRY_PRODUCT_ID_LENGTH]); /* One additional byte for the termination.*/
1414 GEN_CHECK_OFF(AHCIPort, szInquiryRevision);
1415 GEN_CHECK_OFF(AHCIPort, szInquiryRevision[AHCI_ATAPI_INQUIRY_REVISION_LENGTH]); /* One additional byte for the termination.*/
1416 GEN_CHECK_OFF(AHCIPort, cErrors);
1417 GEN_CHECK_OFF(AHCIPort, fRedo);
1418
1419 GEN_CHECK_SIZE(AHCI);
1420 GEN_CHECK_OFF(AHCI, dev);
1421 GEN_CHECK_OFF(AHCI, pDevInsR3);
1422 GEN_CHECK_OFF(AHCI, pDevInsR0);
1423 GEN_CHECK_OFF(AHCI, pDevInsRC);
1424 GEN_CHECK_OFF(AHCI, IBase);
1425 GEN_CHECK_OFF(AHCI, ILeds);
1426 GEN_CHECK_OFF(AHCI, pLedsConnector);
1427 GEN_CHECK_OFF(AHCI, MMIOBase);
1428 GEN_CHECK_OFF(AHCI, regHbaCap);
1429 GEN_CHECK_OFF(AHCI, regHbaCtrl);
1430 GEN_CHECK_OFF(AHCI, regHbaIs);
1431 GEN_CHECK_OFF(AHCI, regHbaPi);
1432 GEN_CHECK_OFF(AHCI, regHbaVs);
1433 GEN_CHECK_OFF(AHCI, regHbaCccCtl);
1434 GEN_CHECK_OFF(AHCI, regHbaCccPorts);
1435 GEN_CHECK_OFF(AHCI, regIdx);
1436 GEN_CHECK_OFF(AHCI, pHbaCccTimerR3);
1437 GEN_CHECK_OFF(AHCI, pHbaCccTimerR0);
1438 GEN_CHECK_OFF(AHCI, pHbaCccTimerRC);
1439 GEN_CHECK_OFF(AHCI, pNotifierQueueR3);
1440 GEN_CHECK_OFF(AHCI, pNotifierQueueR0);
1441 GEN_CHECK_OFF(AHCI, pNotifierQueueRC);
1442 GEN_CHECK_OFF(AHCI, uCccPortNr);
1443 GEN_CHECK_OFF(AHCI, uCccTimeout);
1444 GEN_CHECK_OFF(AHCI, uCccNr);
1445 GEN_CHECK_OFF(AHCI, uCccCurrentNr);
1446 GEN_CHECK_OFF(AHCI, ahciPort);
1447 GEN_CHECK_OFF(AHCI, ahciPort[AHCI_MAX_NR_PORTS_IMPL-1]);
1448 GEN_CHECK_OFF(AHCI, lock);
1449 GEN_CHECK_OFF(AHCI, u32PortsInterrupted);
1450 GEN_CHECK_OFF(AHCI, cThreadsActive);
1451 GEN_CHECK_OFF(AHCI, fReset);
1452 GEN_CHECK_OFF(AHCI, f64BitAddr);
1453 GEN_CHECK_OFF(AHCI, fGCEnabled);
1454 GEN_CHECK_OFF(AHCI, fR0Enabled);
1455 GEN_CHECK_OFF(AHCI, fSignalIdle);
1456 GEN_CHECK_OFF(AHCI, fBootable);
1457 GEN_CHECK_OFF(AHCI, fLegacyPortResetMethod);
1458 GEN_CHECK_OFF(AHCI, cPortsImpl);
1459 GEN_CHECK_OFF(AHCI, cCmdSlotsAvail);
1460 GEN_CHECK_OFF(AHCI, f8ByteMMIO4BytesWrittenSuccessfully);
1461 GEN_CHECK_OFF(AHCI, pSupDrvSession);
1462#endif /* VBOX_WITH_AHCI */
1463
1464#ifdef VBOX_WITH_E1000
1465 GEN_CHECK_SIZE(EEPROM93C46);
1466 GEN_CHECK_OFF(EEPROM93C46, m_eState);
1467 GEN_CHECK_OFF(EEPROM93C46, m_au16Data);
1468 GEN_CHECK_OFF(EEPROM93C46, m_fWriteEnabled);
1469 GEN_CHECK_OFF(EEPROM93C46, m_u16Word);
1470 GEN_CHECK_OFF(EEPROM93C46, m_u16Mask);
1471 GEN_CHECK_OFF(EEPROM93C46, m_u16Addr);
1472 GEN_CHECK_OFF(EEPROM93C46, m_u32InternalWires);
1473 GEN_CHECK_OFF(EEPROM93C46, m_eOp);
1474
1475 GEN_CHECK_SIZE(E1KSTATE);
1476 GEN_CHECK_OFF(E1KSTATE, IBase);
1477 GEN_CHECK_OFF(E1KSTATE, INetworkDown);
1478 GEN_CHECK_OFF(E1KSTATE, INetworkConfig);
1479 GEN_CHECK_OFF(E1KSTATE, ILeds);
1480 GEN_CHECK_OFF(E1KSTATE, pDrvBase);
1481 GEN_CHECK_OFF(E1KSTATE, pDrvR3);
1482 GEN_CHECK_OFF(E1KSTATE, pDrvR0);
1483 GEN_CHECK_OFF(E1KSTATE, pDrvRC);
1484 GEN_CHECK_OFF(E1KSTATE, pLedsConnector);
1485 GEN_CHECK_OFF(E1KSTATE, pDevInsR3);
1486 GEN_CHECK_OFF(E1KSTATE, pDevInsR0);
1487 GEN_CHECK_OFF(E1KSTATE, pDevInsRC);
1488 GEN_CHECK_OFF(E1KSTATE, pTxQueueR3);
1489 GEN_CHECK_OFF(E1KSTATE, pTxQueueR0);
1490 GEN_CHECK_OFF(E1KSTATE, pTxQueueRC);
1491 GEN_CHECK_OFF(E1KSTATE, pCanRxQueueR3);
1492 GEN_CHECK_OFF(E1KSTATE, pCanRxQueueR0);
1493 GEN_CHECK_OFF(E1KSTATE, pCanRxQueueRC);
1494 GEN_CHECK_OFF(E1KSTATE, pRIDTimerR3);
1495 GEN_CHECK_OFF(E1KSTATE, pRIDTimerR0);
1496 GEN_CHECK_OFF(E1KSTATE, pRIDTimerRC);
1497 GEN_CHECK_OFF(E1KSTATE, pRADTimerR3);
1498 GEN_CHECK_OFF(E1KSTATE, pRADTimerR0);
1499 GEN_CHECK_OFF(E1KSTATE, pRADTimerRC);
1500 GEN_CHECK_OFF(E1KSTATE, pTIDTimerR3);
1501 GEN_CHECK_OFF(E1KSTATE, pTIDTimerR0);
1502 GEN_CHECK_OFF(E1KSTATE, pTIDTimerRC);
1503 GEN_CHECK_OFF(E1KSTATE, pTADTimerR3);
1504 GEN_CHECK_OFF(E1KSTATE, pTADTimerR0);
1505 GEN_CHECK_OFF(E1KSTATE, pTADTimerRC);
1506 GEN_CHECK_OFF(E1KSTATE, pIntTimerR3);
1507 GEN_CHECK_OFF(E1KSTATE, pIntTimerR0);
1508 GEN_CHECK_OFF(E1KSTATE, pIntTimerRC);
1509 GEN_CHECK_OFF(E1KSTATE, pLUTimerR3);
1510 GEN_CHECK_OFF(E1KSTATE, pLUTimerR0);
1511 GEN_CHECK_OFF(E1KSTATE, pLUTimerRC);
1512 GEN_CHECK_OFF(E1KSTATE, cs);
1513# ifndef E1K_GLOBAL_MUTEX
1514 GEN_CHECK_OFF(E1KSTATE, csRx);
1515# endif
1516 GEN_CHECK_OFF(E1KSTATE, addrMMReg);
1517 GEN_CHECK_OFF(E1KSTATE, macConfigured);
1518 GEN_CHECK_OFF(E1KSTATE, IOPortBase);
1519 GEN_CHECK_OFF(E1KSTATE, pciDevice);
1520 GEN_CHECK_OFF(E1KSTATE, u64AckedAt);
1521 GEN_CHECK_OFF(E1KSTATE, fIntRaised);
1522 GEN_CHECK_OFF(E1KSTATE, fCableConnected);
1523 GEN_CHECK_OFF(E1KSTATE, fR0Enabled);
1524 GEN_CHECK_OFF(E1KSTATE, fRCEnabled);
1525 GEN_CHECK_OFF(E1KSTATE, auRegs[E1K_NUM_OF_32BIT_REGS]);
1526 GEN_CHECK_OFF(E1KSTATE, led);
1527 GEN_CHECK_OFF(E1KSTATE, u32PktNo);
1528 GEN_CHECK_OFF(E1KSTATE, uSelectedReg);
1529 GEN_CHECK_OFF(E1KSTATE, auMTA[128]);
1530 GEN_CHECK_OFF(E1KSTATE, aRecAddr);
1531 GEN_CHECK_OFF(E1KSTATE, auVFTA[128]);
1532 GEN_CHECK_OFF(E1KSTATE, u16RxBSize);
1533 GEN_CHECK_OFF(E1KSTATE, fLocked);
1534 GEN_CHECK_OFF(E1KSTATE, fDelayInts);
1535 GEN_CHECK_OFF(E1KSTATE, fIntMaskUsed);
1536 GEN_CHECK_OFF(E1KSTATE, fMaybeOutOfSpace);
1537 GEN_CHECK_OFF(E1KSTATE, hEventMoreRxDescAvail);
1538 GEN_CHECK_OFF(E1KSTATE, contextTSE);
1539 GEN_CHECK_OFF(E1KSTATE, contextNormal);
1540# ifdef E1K_WITH_TXD_CACHE
1541 GEN_CHECK_OFF(E1KSTATE, aTxDescriptors);
1542 GEN_CHECK_OFF(E1KSTATE, nTxDFetched);
1543 GEN_CHECK_OFF(E1KSTATE, iTxDCurrent);
1544 GEN_CHECK_OFF(E1KSTATE, fGSO);
1545 GEN_CHECK_OFF(E1KSTATE, cbTxAlloc);
1546# endif
1547 GEN_CHECK_OFF(E1KSTATE, GsoCtx);
1548 GEN_CHECK_OFF(E1KSTATE, uTxFallback);
1549 GEN_CHECK_OFF(E1KSTATE, fVTag);
1550 GEN_CHECK_OFF(E1KSTATE, u16VTagTCI);
1551 GEN_CHECK_OFF(E1KSTATE, aTxPacketFallback[E1K_MAX_TX_PKT_SIZE]);
1552 GEN_CHECK_OFF(E1KSTATE, u16TxPktLen);
1553 GEN_CHECK_OFF(E1KSTATE, fIPcsum);
1554 GEN_CHECK_OFF(E1KSTATE, fTCPcsum);
1555 GEN_CHECK_OFF(E1KSTATE, u32PayRemain);
1556 GEN_CHECK_OFF(E1KSTATE, u16HdrRemain);
1557 GEN_CHECK_OFF(E1KSTATE, u16SavedFlags);
1558 GEN_CHECK_OFF(E1KSTATE, u32SavedCsum);
1559 GEN_CHECK_OFF(E1KSTATE, eeprom);
1560 GEN_CHECK_OFF(E1KSTATE, phy);
1561 GEN_CHECK_OFF(E1KSTATE, StatReceiveBytes);
1562#endif /* VBOX_WITH_E1000 */
1563
1564#ifdef VBOX_WITH_VIRTIO
1565 GEN_CHECK_OFF(VPCISTATE, cs);
1566 GEN_CHECK_OFF(VPCISTATE, szInstance);
1567 GEN_CHECK_OFF(VPCISTATE, IBase);
1568 GEN_CHECK_OFF(VPCISTATE, ILeds);
1569 GEN_CHECK_OFF(VPCISTATE, pLedsConnector);
1570 GEN_CHECK_OFF(VPCISTATE, pDevInsR3);
1571 GEN_CHECK_OFF(VPCISTATE, pDevInsR0);
1572 GEN_CHECK_OFF(VPCISTATE, pDevInsRC);
1573 GEN_CHECK_OFF(VPCISTATE, pciDevice);
1574 GEN_CHECK_OFF(VPCISTATE, IOPortBase);
1575 GEN_CHECK_OFF(VPCISTATE, led);
1576 GEN_CHECK_OFF(VPCISTATE, uGuestFeatures);
1577 GEN_CHECK_OFF(VPCISTATE, uQueueSelector);
1578 GEN_CHECK_OFF(VPCISTATE, uStatus);
1579 GEN_CHECK_OFF(VPCISTATE, uISR);
1580 GEN_CHECK_OFF(VPCISTATE, Queues);
1581 GEN_CHECK_OFF(VPCISTATE, Queues[VIRTIO_MAX_NQUEUES]);
1582 GEN_CHECK_OFF(VNETSTATE, VPCI);
1583 GEN_CHECK_OFF(VNETSTATE, INetworkDown);
1584 GEN_CHECK_OFF(VNETSTATE, INetworkConfig);
1585 GEN_CHECK_OFF(VNETSTATE, pDrvBase);
1586 GEN_CHECK_OFF(VNETSTATE, pCanRxQueueR3);
1587 GEN_CHECK_OFF(VNETSTATE, pCanRxQueueR0);
1588 GEN_CHECK_OFF(VNETSTATE, pCanRxQueueRC);
1589 GEN_CHECK_OFF(VNETSTATE, pLinkUpTimer);
1590# ifdef VNET_TX_DELAY
1591 GEN_CHECK_OFF(VNETSTATE, pTxTimerR3);
1592 GEN_CHECK_OFF(VNETSTATE, pTxTimerR0);
1593 GEN_CHECK_OFF(VNETSTATE, pTxTimerRC);
1594# endif /* VNET_TX_DELAY */
1595 GEN_CHECK_OFF(VNETSTATE, config);
1596 GEN_CHECK_OFF(VNETSTATE, macConfigured);
1597 GEN_CHECK_OFF(VNETSTATE, fCableConnected);
1598 GEN_CHECK_OFF(VNETSTATE, u32PktNo);
1599 GEN_CHECK_OFF(VNETSTATE, fPromiscuous);
1600 GEN_CHECK_OFF(VNETSTATE, fAllMulti);
1601 GEN_CHECK_OFF(VNETSTATE, pRxQueue);
1602 GEN_CHECK_OFF(VNETSTATE, pTxQueue);
1603 GEN_CHECK_OFF(VNETSTATE, pCtlQueue);
1604 GEN_CHECK_OFF(VNETSTATE, fMaybeOutOfSpace);
1605 GEN_CHECK_OFF(VNETSTATE, hEventMoreRxDescAvail);
1606#endif /* VBOX_WITH_VIRTIO */
1607
1608 /* VMMDev*.cpp/h */
1609 GEN_CHECK_SIZE(VMMDEV);
1610 GEN_CHECK_OFF(VMMDEV, PciDev);
1611 GEN_CHECK_OFF(VMMDEV, CritSect);
1612 GEN_CHECK_OFF(VMMDEV, hypervisorSize);
1613 GEN_CHECK_OFF(VMMDEV, mouseCapabilities);
1614 GEN_CHECK_OFF(VMMDEV, mouseXAbs);
1615 GEN_CHECK_OFF(VMMDEV, mouseYAbs);
1616 GEN_CHECK_OFF(VMMDEV, fHostCursorRequested);
1617 GEN_CHECK_OFF(VMMDEV, pDevInsR3);
1618 GEN_CHECK_OFF(VMMDEV, pDevInsR0);
1619 GEN_CHECK_OFF(VMMDEV, pDevInsRC);
1620 GEN_CHECK_OFF(VMMDEV, IBase);
1621 GEN_CHECK_OFF(VMMDEV, IPort);
1622#ifdef VBOX_WITH_HGCM
1623 GEN_CHECK_OFF(VMMDEV, IHGCMPort);
1624#endif
1625 GEN_CHECK_OFF(VMMDEV, pDrvBase);
1626 GEN_CHECK_OFF(VMMDEV, pDrv);
1627#ifdef VBOX_WITH_HGCM
1628 GEN_CHECK_OFF(VMMDEV, pHGCMDrv);
1629#endif
1630 GEN_CHECK_OFF(VMMDEV, szMsg);
1631 GEN_CHECK_OFF(VMMDEV, iMsg);
1632 GEN_CHECK_OFF(VMMDEV, irq);
1633 GEN_CHECK_OFF(VMMDEV, u32HostEventFlags);
1634 GEN_CHECK_OFF(VMMDEV, u32GuestFilterMask);
1635 GEN_CHECK_OFF(VMMDEV, u32NewGuestFilterMask);
1636 GEN_CHECK_OFF(VMMDEV, fNewGuestFilterMask);
1637 GEN_CHECK_OFF(VMMDEV, GCPhysVMMDevRAM);
1638 GEN_CHECK_OFF(VMMDEV, pVMMDevRAMR3);
1639 GEN_CHECK_OFF(VMMDEV, pVMMDevRAMR0);
1640 GEN_CHECK_OFF(VMMDEV, pVMMDevRAMRC);
1641 GEN_CHECK_OFF(VMMDEV, pVMMDevHeapR3);
1642 GEN_CHECK_OFF(VMMDEV, GCPhysVMMDevHeap);
1643 GEN_CHECK_OFF(VMMDEV, guestInfo);
1644 GEN_CHECK_OFF(VMMDEV, guestCaps);
1645 GEN_CHECK_OFF(VMMDEV, fu32AdditionsOk);
1646 GEN_CHECK_OFF(VMMDEV, u32VideoAccelEnabled);
1647 GEN_CHECK_OFF(VMMDEV, displayChangeData);
1648 GEN_CHECK_OFF(VMMDEV, pCredentials);
1649 GEN_CHECK_OFF(VMMDEV, cMbMemoryBalloon);
1650 GEN_CHECK_OFF(VMMDEV, cMbMemoryBalloonLast);
1651 GEN_CHECK_OFF(VMMDEV, cbGuestRAM);
1652 GEN_CHECK_OFF(VMMDEV, idSession);
1653 GEN_CHECK_OFF(VMMDEV, u32StatIntervalSize);
1654 GEN_CHECK_OFF(VMMDEV, u32LastStatIntervalSize);
1655 GEN_CHECK_OFF(VMMDEV, fLastSeamlessEnabled),
1656 GEN_CHECK_OFF(VMMDEV, fSeamlessEnabled);
1657 GEN_CHECK_OFF(VMMDEV, fVRDPEnabled);
1658 GEN_CHECK_OFF(VMMDEV, uVRDPExperienceLevel);
1659#ifdef VMMDEV_WITH_ALT_TIMESYNC
1660 GEN_CHECK_OFF(VMMDEV, hostTime);
1661 GEN_CHECK_OFF(VMMDEV, fTimesyncBackdoorLo);
1662#endif
1663 GEN_CHECK_OFF(VMMDEV, fGetHostTimeDisabled);
1664 GEN_CHECK_OFF(VMMDEV, fBackdoorLogDisabled);
1665 GEN_CHECK_OFF(VMMDEV, fKeepCredentials);
1666 GEN_CHECK_OFF(VMMDEV, fHeapEnabled);
1667#ifdef VBOX_WITH_HGCM
1668 GEN_CHECK_OFF(VMMDEV, listHGCMCmd);
1669 GEN_CHECK_OFF(VMMDEV, critsectHGCMCmdList);
1670 GEN_CHECK_OFF(VMMDEV, u32HGCMEnabled);
1671#endif
1672 GEN_CHECK_OFF(VMMDEV, SharedFolders);
1673 GEN_CHECK_OFF(VMMDEV, SharedFolders.Led);
1674 GEN_CHECK_OFF(VMMDEV, SharedFolders.ILeds);
1675 GEN_CHECK_OFF(VMMDEV, SharedFolders.pLedsConnector);
1676 GEN_CHECK_OFF(VMMDEV, fCpuHotPlugEventsEnabled);
1677 GEN_CHECK_OFF(VMMDEV, enmCpuHotPlugEvent);
1678 GEN_CHECK_OFF(VMMDEV, idCpuCore);
1679 GEN_CHECK_OFF(VMMDEV, idCpuPackage);
1680 GEN_CHECK_OFF(VMMDEV, StatMemBalloonChunks);
1681 GEN_CHECK_OFF(VMMDEV, fRZEnabled);
1682 GEN_CHECK_OFF(VMMDEV, fTestingEnabled);
1683 GEN_CHECK_OFF(VMMDEV, fTestingMMIO);
1684 GEN_CHECK_OFF(VMMDEV, u32TestingHighTimestamp);
1685 GEN_CHECK_OFF(VMMDEV, u32TestingCmd);
1686 GEN_CHECK_OFF(VMMDEV, offTestingData);
1687 GEN_CHECK_OFF(VMMDEV, TestingData);
1688 GEN_CHECK_OFF(VMMDEV, TestingData.Value.u64Value);
1689 GEN_CHECK_OFF(VMMDEV, TestingData.Value.u32Unit);
1690 GEN_CHECK_OFF(VMMDEV, TestingData.Value.szName);
1691 GEN_CHECK_OFF(VMMDEV, nsLastHeartbeatTS);
1692 GEN_CHECK_OFF(VMMDEV, fFlatlined);
1693 GEN_CHECK_OFF(VMMDEV, fHeartbeatActive);
1694 GEN_CHECK_OFF(VMMDEV, cNsHeartbeatInterval);
1695 GEN_CHECK_OFF(VMMDEV, cNsHeartbeatTimeout);
1696 GEN_CHECK_OFF(VMMDEV, pFlatlinedTimer);
1697
1698#ifdef VBOX_WITH_BUSLOGIC
1699 GEN_CHECK_SIZE(BUSLOGICDEVICE);
1700 GEN_CHECK_OFF(BUSLOGICDEVICE, pBusLogicR3);
1701 GEN_CHECK_OFF(BUSLOGICDEVICE, pBusLogicR0);
1702 GEN_CHECK_OFF(BUSLOGICDEVICE, pBusLogicRC);
1703 GEN_CHECK_OFF(BUSLOGICDEVICE, fPresent);
1704 GEN_CHECK_OFF(BUSLOGICDEVICE, iLUN);
1705 GEN_CHECK_OFF(BUSLOGICDEVICE, IBase);
1706 GEN_CHECK_OFF(BUSLOGICDEVICE, IMediaPort);
1707 GEN_CHECK_OFF(BUSLOGICDEVICE, IMediaExPort);
1708 GEN_CHECK_OFF(BUSLOGICDEVICE, ILed);
1709 GEN_CHECK_OFF(BUSLOGICDEVICE, pDrvBase);
1710 GEN_CHECK_OFF(BUSLOGICDEVICE, pDrvMedia);
1711 GEN_CHECK_OFF(BUSLOGICDEVICE, pDrvMediaEx);
1712 GEN_CHECK_OFF(BUSLOGICDEVICE, Led);
1713 GEN_CHECK_OFF(BUSLOGICDEVICE, cOutstandingRequests);
1714
1715 GEN_CHECK_SIZE(BUSLOGIC);
1716 GEN_CHECK_OFF(BUSLOGIC, dev);
1717 GEN_CHECK_OFF(BUSLOGIC, pDevInsR3);
1718 GEN_CHECK_OFF(BUSLOGIC, pDevInsR0);
1719 GEN_CHECK_OFF(BUSLOGIC, pDevInsRC);
1720 GEN_CHECK_OFF(BUSLOGIC, IOPortBase);
1721 GEN_CHECK_OFF(BUSLOGIC, MMIOBase);
1722 GEN_CHECK_OFF(BUSLOGIC, regStatus);
1723 GEN_CHECK_OFF(BUSLOGIC, regInterrupt);
1724 GEN_CHECK_OFF(BUSLOGIC, regGeometry);
1725 GEN_CHECK_OFF(BUSLOGIC, LocalRam);
1726 GEN_CHECK_OFF(BUSLOGIC, uOperationCode);
1727 GEN_CHECK_OFF(BUSLOGIC, aCommandBuffer);
1728 GEN_CHECK_OFF(BUSLOGIC, aCommandBuffer[BUSLOGIC_COMMAND_SIZE_MAX]);
1729 GEN_CHECK_OFF(BUSLOGIC, iParameter);
1730 GEN_CHECK_OFF(BUSLOGIC, cbCommandParametersLeft);
1731 GEN_CHECK_OFF(BUSLOGIC, fUseLocalRam);
1732 GEN_CHECK_OFF(BUSLOGIC, aReplyBuffer);
1733 GEN_CHECK_OFF(BUSLOGIC, aReplyBuffer[BUSLOGIC_REPLY_SIZE_MAX]);
1734 GEN_CHECK_OFF(BUSLOGIC, iReply);
1735 GEN_CHECK_OFF(BUSLOGIC, cbReplyParametersLeft);
1736 GEN_CHECK_OFF(BUSLOGIC, fIRQEnabled);
1737 GEN_CHECK_OFF(BUSLOGIC, cMailbox);
1738 GEN_CHECK_OFF(BUSLOGIC, GCPhysAddrMailboxOutgoingBase);
1739 GEN_CHECK_OFF(BUSLOGIC, uMailboxOutgoingPositionCurrent);
1740 GEN_CHECK_OFF(BUSLOGIC, cMailboxesReady);
1741 GEN_CHECK_OFF(BUSLOGIC, fNotificationSent);
1742 GEN_CHECK_OFF(BUSLOGIC, GCPhysAddrMailboxIncomingBase);
1743 GEN_CHECK_OFF(BUSLOGIC, uMailboxIncomingPositionCurrent);
1744 GEN_CHECK_OFF(BUSLOGIC, fStrictRoundRobinMode);
1745 GEN_CHECK_OFF(BUSLOGIC, fExtendedLunCCBFormat);
1746 GEN_CHECK_OFF(BUSLOGIC, pNotifierQueueR3);
1747 GEN_CHECK_OFF(BUSLOGIC, pNotifierQueueR0);
1748 GEN_CHECK_OFF(BUSLOGIC, pNotifierQueueRC);
1749 GEN_CHECK_OFF(BUSLOGIC, CritSectIntr);
1750 GEN_CHECK_OFF(BUSLOGIC, aDeviceStates);
1751 GEN_CHECK_OFF(BUSLOGIC, aDeviceStates[BUSLOGIC_MAX_DEVICES-1]);
1752 GEN_CHECK_OFF(BUSLOGIC, IBase);
1753 GEN_CHECK_OFF(BUSLOGIC, ILeds);
1754 GEN_CHECK_OFF(BUSLOGIC, pLedsConnector);
1755 GEN_CHECK_OFF(BUSLOGIC, pMediaNotify);
1756 GEN_CHECK_OFF(BUSLOGIC, fSignalIdle);
1757 GEN_CHECK_OFF(BUSLOGIC, fWrkThreadSleeping);
1758 GEN_CHECK_OFF(BUSLOGIC, pSupDrvSession);
1759 GEN_CHECK_OFF(BUSLOGIC, hEvtProcess);
1760 GEN_CHECK_OFF(BUSLOGIC, paGCPhysAddrCCBRedo);
1761 GEN_CHECK_OFF(BUSLOGIC, cReqsRedo);
1762# ifdef LOG_ENABLED
1763 GEN_CHECK_OFF(BUSLOGIC, cInMailboxesReady);
1764# endif
1765#endif /* VBOX_WITH_BUSLOGIC */
1766
1767#ifdef VBOX_WITH_LSILOGIC
1768 GEN_CHECK_SIZE(LSILOGICSCSI);
1769 GEN_CHECK_OFF(LSILOGICSCSI, PciDev);
1770 GEN_CHECK_OFF(LSILOGICSCSI, pDevInsR3);
1771 GEN_CHECK_OFF(LSILOGICSCSI, pDevInsR0);
1772 GEN_CHECK_OFF(LSILOGICSCSI, pDevInsRC);
1773 GEN_CHECK_OFF(LSILOGICSCSI, fGCEnabled);
1774 GEN_CHECK_OFF(LSILOGICSCSI, fR0Enabled);
1775 GEN_CHECK_OFF(LSILOGICSCSI, enmState);
1776 GEN_CHECK_OFF(LSILOGICSCSI, enmWhoInit);
1777 GEN_CHECK_OFF(LSILOGICSCSI, enmDoorbellState);
1778 GEN_CHECK_OFF(LSILOGICSCSI, fDiagnosticEnabled);
1779 GEN_CHECK_OFF(LSILOGICSCSI, fNotificationSent);
1780 GEN_CHECK_OFF(LSILOGICSCSI, fEventNotificationEnabled);
1781 GEN_CHECK_OFF(LSILOGICSCSI, fDiagRegsEnabled);
1782 GEN_CHECK_OFF(LSILOGICSCSI, pNotificationQueueR3);
1783 GEN_CHECK_OFF(LSILOGICSCSI, pNotificationQueueR0);
1784 GEN_CHECK_OFF(LSILOGICSCSI, pNotificationQueueRC);
1785 GEN_CHECK_OFF(LSILOGICSCSI, cDeviceStates);
1786 GEN_CHECK_OFF(LSILOGICSCSI, paDeviceStates);
1787 GEN_CHECK_OFF(LSILOGICSCSI, GCPhysMMIOBase);
1788 GEN_CHECK_OFF(LSILOGICSCSI, IOPortBase);
1789 GEN_CHECK_OFF(LSILOGICSCSI, uInterruptMask);
1790 GEN_CHECK_OFF(LSILOGICSCSI, uInterruptStatus);
1791 GEN_CHECK_OFF(LSILOGICSCSI, aMessage);
1792 GEN_CHECK_OFF(LSILOGICSCSI, aMessage[sizeof(MptConfigurationRequest)-1]);
1793 GEN_CHECK_OFF(LSILOGICSCSI, iMessage);
1794 GEN_CHECK_OFF(LSILOGICSCSI, cMessage);
1795 GEN_CHECK_OFF(LSILOGICSCSI, ReplyBuffer);
1796 GEN_CHECK_OFF(LSILOGICSCSI, uNextReplyEntryRead);
1797 GEN_CHECK_OFF(LSILOGICSCSI, cReplySize);
1798 GEN_CHECK_OFF(LSILOGICSCSI, u16IOCFaultCode);
1799 GEN_CHECK_OFF(LSILOGICSCSI, u32HostMFAHighAddr);
1800 GEN_CHECK_OFF(LSILOGICSCSI, u32SenseBufferHighAddr);
1801 GEN_CHECK_OFF(LSILOGICSCSI, cMaxDevices);
1802 GEN_CHECK_OFF(LSILOGICSCSI, cMaxBuses);
1803 GEN_CHECK_OFF(LSILOGICSCSI, cbReplyFrame);
1804 GEN_CHECK_OFF(LSILOGICSCSI, iDiagnosticAccess);
1805 GEN_CHECK_OFF(LSILOGICSCSI, cReplyQueueEntries);
1806 GEN_CHECK_OFF(LSILOGICSCSI, cRequestQueueEntries);
1807 GEN_CHECK_OFF(LSILOGICSCSI, ReplyPostQueueCritSect);
1808 GEN_CHECK_OFF(LSILOGICSCSI, ReplyFreeQueueCritSect);
1809 GEN_CHECK_OFF(LSILOGICSCSI, RequestQueueCritSect);
1810 GEN_CHECK_OFF(LSILOGICSCSI, ReplyFreeQueueWriteCritSect);
1811 GEN_CHECK_OFF(LSILOGICSCSI, pReplyFreeQueueBaseR3);
1812 GEN_CHECK_OFF(LSILOGICSCSI, pReplyPostQueueBaseR3);
1813 GEN_CHECK_OFF(LSILOGICSCSI, pRequestQueueBaseR3);
1814 GEN_CHECK_OFF(LSILOGICSCSI, pReplyFreeQueueBaseR0);
1815 GEN_CHECK_OFF(LSILOGICSCSI, pReplyPostQueueBaseR0);
1816 GEN_CHECK_OFF(LSILOGICSCSI, pRequestQueueBaseR0);
1817 GEN_CHECK_OFF(LSILOGICSCSI, pReplyFreeQueueBaseRC);
1818 GEN_CHECK_OFF(LSILOGICSCSI, pReplyPostQueueBaseRC);
1819 GEN_CHECK_OFF(LSILOGICSCSI, pRequestQueueBaseRC);
1820 GEN_CHECK_OFF(LSILOGICSCSI, uReplyFreeQueueNextEntryFreeWrite);
1821 GEN_CHECK_OFF(LSILOGICSCSI, uReplyFreeQueueNextAddressRead);
1822 GEN_CHECK_OFF(LSILOGICSCSI, uReplyPostQueueNextEntryFreeWrite);
1823 GEN_CHECK_OFF(LSILOGICSCSI, uReplyPostQueueNextAddressRead);
1824 GEN_CHECK_OFF(LSILOGICSCSI, uRequestQueueNextEntryFreeWrite);
1825 GEN_CHECK_OFF(LSILOGICSCSI, uRequestQueueNextAddressRead);
1826 GEN_CHECK_OFF(LSILOGICSCSI, u16NextHandle);
1827 GEN_CHECK_OFF(LSILOGICSCSI, enmCtrlType);
1828 GEN_CHECK_OFF(LSILOGICSCSI, IBase);
1829 GEN_CHECK_OFF(LSILOGICSCSI, ILeds);
1830 GEN_CHECK_OFF(LSILOGICSCSI, pLedsConnector);
1831 GEN_CHECK_OFF(LSILOGICSCSI, pMediaNotify);
1832 GEN_CHECK_OFF(LSILOGICSCSI, pConfigurationPages);
1833 GEN_CHECK_OFF(LSILOGICSCSI, fSignalIdle);
1834 GEN_CHECK_OFF(LSILOGICSCSI, fRedo);
1835 GEN_CHECK_OFF(LSILOGICSCSI, fWrkThreadSleeping);
1836 GEN_CHECK_OFF(LSILOGICSCSI, pTasksRedoHead);
1837 GEN_CHECK_OFF(LSILOGICSCSI, u32DiagMemAddr);
1838 GEN_CHECK_OFF(LSILOGICSCSI, cbMemRegns);
1839 GEN_CHECK_OFF(LSILOGICSCSI, ListMemRegns);
1840 GEN_CHECK_OFF(LSILOGICSCSI, pSupDrvSession);
1841 GEN_CHECK_OFF(LSILOGICSCSI, pThreadWrk);
1842 GEN_CHECK_OFF(LSILOGICSCSI, hEvtProcess);
1843#endif /* VBOX_WITH_LSILOGIC */
1844
1845 GEN_CHECK_SIZE(HPET);
1846 GEN_CHECK_OFF(HPET, pDevInsR3);
1847 GEN_CHECK_OFF(HPET, pDevInsR0);
1848 GEN_CHECK_OFF(HPET, pDevInsRC);
1849 GEN_CHECK_OFF(HPET, u64HpetOffset);
1850 GEN_CHECK_OFF(HPET, u32Capabilities);
1851 GEN_CHECK_OFF(HPET, u32Period);
1852 GEN_CHECK_OFF(HPET, u64HpetConfig);
1853 GEN_CHECK_OFF(HPET, u64Isr);
1854 GEN_CHECK_OFF(HPET, u64HpetCounter);
1855 GEN_CHECK_OFF(HPET, CritSect);
1856 GEN_CHECK_OFF(HPET, fIch9);
1857
1858 GEN_CHECK_SIZE(HPETTIMER);
1859 GEN_CHECK_OFF(HPETTIMER, pTimerR3);
1860 GEN_CHECK_OFF(HPETTIMER, pHpetR3);
1861 GEN_CHECK_OFF(HPETTIMER, pTimerR0);
1862 GEN_CHECK_OFF(HPETTIMER, pHpetR0);
1863 GEN_CHECK_OFF(HPETTIMER, pTimerRC);
1864 GEN_CHECK_OFF(HPETTIMER, pHpetRC);
1865 GEN_CHECK_OFF(HPETTIMER, idxTimer);
1866 GEN_CHECK_OFF(HPETTIMER, u64Config);
1867 GEN_CHECK_OFF(HPETTIMER, u64Cmp);
1868 GEN_CHECK_OFF(HPETTIMER, u64Fsb);
1869 GEN_CHECK_OFF(HPETTIMER, u64Period);
1870 GEN_CHECK_OFF(HPETTIMER, u8Wrap);
1871
1872 GEN_CHECK_SIZE(AC97DRIVER);
1873 GEN_CHECK_OFF(AC97DRIVER, Node);
1874 GEN_CHECK_OFF(AC97DRIVER, pAC97State);
1875 GEN_CHECK_OFF(AC97DRIVER, fFlags);
1876 GEN_CHECK_OFF(AC97DRIVER, uLUN);
1877 GEN_CHECK_OFF(AC97DRIVER, fAttached);
1878 GEN_CHECK_OFF(AC97DRIVER, pConnector);
1879 GEN_CHECK_OFF(AC97DRIVER, LineIn);
1880 GEN_CHECK_OFF(AC97DRIVER, MicIn);
1881 GEN_CHECK_OFF(AC97DRIVER, Out);
1882
1883 GEN_CHECK_SIZE(AC97STATE);
1884 GEN_CHECK_OFF(AC97STATE, CritSect);
1885 GEN_CHECK_OFF(AC97STATE, pDevInsR3);
1886 GEN_CHECK_OFF(AC97STATE, pDevInsR0);
1887 GEN_CHECK_OFF(AC97STATE, pDevInsRC);
1888 GEN_CHECK_OFF(AC97STATE, fRZEnabled);
1889 GEN_CHECK_OFF(AC97STATE, glob_cnt);
1890 GEN_CHECK_OFF(AC97STATE, glob_sta);
1891 GEN_CHECK_OFF(AC97STATE, cas);
1892 GEN_CHECK_OFF(AC97STATE, last_samp);
1893 GEN_CHECK_OFF(AC97STATE, mixer_data);
1894 GEN_CHECK_OFF(AC97STATE, aStreams);
1895 GEN_CHECK_OFF(AC97STATE, uTimerHz);
1896 GEN_CHECK_OFF(AC97STATE, pTimerRC);
1897 GEN_CHECK_OFF(AC97STATE, pTimerR3);
1898 GEN_CHECK_OFF(AC97STATE, pTimerR0);
1899#ifdef VBOX_WITH_STATISTICS
1900 GEN_CHECK_OFF(AC97STATE, StatTimer);
1901 GEN_CHECK_OFF(AC97STATE, StatIn);
1902 GEN_CHECK_OFF(AC97STATE, StatOut);
1903 GEN_CHECK_OFF(AC97STATE, StatBytesRead);
1904 GEN_CHECK_OFF(AC97STATE, StatBytesWritten);
1905#endif
1906 GEN_CHECK_OFF(AC97STATE, lstDrv);
1907 GEN_CHECK_OFF(AC97STATE, pMixer);
1908 GEN_CHECK_OFF(AC97STATE, pSinkOut);
1909 GEN_CHECK_OFF(AC97STATE, pSinkLineIn);
1910 GEN_CHECK_OFF(AC97STATE, pSinkMicIn);
1911 GEN_CHECK_OFF(AC97STATE, silence);
1912 GEN_CHECK_OFF(AC97STATE, bup_flag);
1913 GEN_CHECK_OFF(AC97STATE, IBase);
1914 GEN_CHECK_OFF(AC97STATE, IOPortBase);
1915 GEN_CHECK_OFF(AC97STATE, uCodecModel);
1916
1917 GEN_CHECK_SIZE(AC97STREAM);
1918 GEN_CHECK_OFF(AC97STREAM, pAC97State);
1919
1920 GEN_CHECK_SIZE(AC97STREAMSTATE);
1921 GEN_CHECK_OFF(AC97STREAMSTATE, CritSect);
1922 GEN_CHECK_OFF(AC97STREAMSTATE, pCircBuf);
1923 GEN_CHECK_OFF(AC97STREAMSTATE, tsTransferLast);
1924
1925 GEN_CHECK_SIZE(HDADRIVERSTREAM);
1926 GEN_CHECK_OFF(HDADRIVERSTREAM, pMixStrm);
1927
1928 GEN_CHECK_SIZE(HDADRIVER);
1929 GEN_CHECK_OFF(HDADRIVER, Node);
1930 GEN_CHECK_OFF(HDADRIVER, pHDAState);
1931 GEN_CHECK_OFF(HDADRIVER, fFlags);
1932 GEN_CHECK_OFF(HDADRIVER, uLUN);
1933 GEN_CHECK_OFF(HDADRIVER, fAttached);
1934 GEN_CHECK_OFF(HDADRIVER, pConnector);
1935 GEN_CHECK_OFF(HDADRIVER, LineIn);
1936#ifdef VBOX_WITH_HDA_MIC_IN
1937 GEN_CHECK_OFF(HDADRIVER, MicIn);
1938#endif
1939 GEN_CHECK_OFF(HDADRIVER, Front);
1940#ifdef VBOX_WITH_HDA_51_SURROUND
1941 GEN_CHECK_OFF(HDADRIVER, CenterLFE);
1942 GEN_CHECK_OFF(HDADRIVER, Rear);
1943#endif
1944
1945 GEN_CHECK_SIZE(HDABDLESTATE);
1946 GEN_CHECK_OFF(HDABDLESTATE, u32BDLIndex);
1947 GEN_CHECK_OFF(HDABDLESTATE, cbBelowFIFOW);
1948 GEN_CHECK_OFF(HDABDLESTATE, u32BufOff);
1949
1950 GEN_CHECK_SIZE(HDABDLEDESC);
1951 GEN_CHECK_OFF(HDABDLEDESC, u64BufAddr);
1952 GEN_CHECK_OFF(HDABDLEDESC, u32BufSize);
1953 GEN_CHECK_OFF(HDABDLEDESC, fFlags);
1954
1955 GEN_CHECK_SIZE(HDABDLE);
1956 GEN_CHECK_OFF(HDABDLE, Desc);
1957 GEN_CHECK_OFF(HDABDLE, State);
1958
1959 GEN_CHECK_SIZE(HDASTREAMMAP);
1960
1961 GEN_CHECK_SIZE(HDASTREAMSTATE);
1962 GEN_CHECK_OFF(HDASTREAMSTATE, uCurBDLE);
1963 GEN_CHECK_OFF(HDASTREAMSTATE, fInReset);
1964 GEN_CHECK_OFF(HDASTREAMSTATE, Mapping);
1965 GEN_CHECK_OFF(HDASTREAMSTATE, BDLE);
1966 GEN_CHECK_OFF(HDASTREAMSTATE, pCircBuf);
1967
1968 GEN_CHECK_SIZE(HDASTREAMDBGINFORT);
1969
1970 GEN_CHECK_SIZE(HDASTREAMDBGINFO);
1971 GEN_CHECK_OFF(HDASTREAMDBGINFO, Runtime);
1972
1973 GEN_CHECK_SIZE(HDASTREAM);
1974 GEN_CHECK_OFF(HDASTREAM, u8SD);
1975 GEN_CHECK_OFF(HDASTREAM, u64BDLBase);
1976 GEN_CHECK_OFF(HDASTREAM, u16FMT);
1977 GEN_CHECK_OFF(HDASTREAM, u16FIFOS);
1978 GEN_CHECK_OFF(HDASTREAM, u16LVI);
1979 GEN_CHECK_OFF(HDASTREAM, State);
1980 GEN_CHECK_OFF(HDASTREAM, Dbg);
1981 GEN_CHECK_OFF(HDASTREAM, CritSect);
1982
1983 GEN_CHECK_SIZE(HDASTATE);
1984 GEN_CHECK_OFF(HDASTATE, PciDev);
1985 GEN_CHECK_OFF(HDASTATE, pDevInsR3);
1986 GEN_CHECK_OFF(HDASTATE, pDevInsR0);
1987 GEN_CHECK_OFF(HDASTATE, pDevInsRC);
1988 GEN_CHECK_OFF(HDASTATE, IBase);
1989 GEN_CHECK_OFF(HDASTATE, MMIOBaseAddr);
1990 GEN_CHECK_OFF(HDASTATE, au32Regs[0]);
1991 GEN_CHECK_OFF(HDASTATE, au32Regs[HDA_NUM_REGS]);
1992 GEN_CHECK_OFF(HDASTATE, aStreams);
1993 GEN_CHECK_OFF(HDASTATE, aTags);
1994 GEN_CHECK_OFF(HDASTATE, u64CORBBase);
1995 GEN_CHECK_OFF(HDASTATE, u64RIRBBase);
1996 GEN_CHECK_OFF(HDASTATE, u64DPBase);
1997 GEN_CHECK_OFF(HDASTATE, pu32CorbBuf);
1998 GEN_CHECK_OFF(HDASTATE, cbCorbBuf);
1999 GEN_CHECK_OFF(HDASTATE, pu64RirbBuf);
2000 GEN_CHECK_OFF(HDASTATE, cbRirbBuf);
2001 GEN_CHECK_OFF(HDASTATE, fRZEnabled);
2002#ifdef VBOX_WITH_STATISTICS
2003# ifndef VBOX_WITH_AUDIO_CALLBACKS
2004 GEN_CHECK_OFF(HDASTATE, StatTimer);
2005# endif
2006 GEN_CHECK_OFF(HDASTATE, StatBytesRead);
2007 GEN_CHECK_OFF(HDASTATE, StatBytesWritten);
2008#endif /* VBOX_WITH_STATISTICS */
2009 GEN_CHECK_OFF(HDASTATE, pCodec);
2010 GEN_CHECK_OFF(HDASTATE, lstDrv);
2011 GEN_CHECK_OFF(HDASTATE, pMixer);
2012 GEN_CHECK_OFF(HDASTATE, SinkFront);
2013#ifdef VBOX_WITH_HDA_51_SURROUND
2014 GEN_CHECK_OFF(HDASTATE, SinkCenterLFE);
2015 GEN_CHECK_OFF(HDASTATE, SinkRear);
2016#endif
2017 GEN_CHECK_OFF(HDASTATE, SinkLineIn);
2018#ifdef VBOX_WITH_HDA_MIC_IN
2019 GEN_CHECK_OFF(HDASTATE, SinkMicIn);
2020#endif
2021 GEN_CHECK_OFF(HDASTATE, u64WalClk);
2022 GEN_CHECK_OFF(HDASTATE, u16RespIntCnt);
2023 GEN_CHECK_OFF(HDASTATE, cPosAdjustFrames);
2024 GEN_CHECK_OFF(HDASTATE, u8IRQL);
2025
2026#ifdef VBOX_WITH_NVME_IMPL
2027 GEN_CHECK_SIZE(NVMEQUEUEHDR);
2028 GEN_CHECK_OFF(NVMEQUEUEHDR, u16Id);
2029 GEN_CHECK_OFF(NVMEQUEUEHDR, cEntries);
2030 GEN_CHECK_OFF(NVMEQUEUEHDR, enmState);
2031 GEN_CHECK_OFF(NVMEQUEUEHDR, GCPhysBase);
2032 GEN_CHECK_OFF(NVMEQUEUEHDR, cbEntry);
2033 GEN_CHECK_OFF(NVMEQUEUEHDR, idxHead);
2034 GEN_CHECK_OFF(NVMEQUEUEHDR, idxTail);
2035 GEN_CHECK_OFF(NVMEQUEUEHDR, fPhysCont);
2036 GEN_CHECK_OFF(NVMEQUEUEHDR, enmType);
2037
2038 GEN_CHECK_SIZE(NVMEQUEUESUBM);
2039 GEN_CHECK_OFF(NVMEQUEUESUBM, Hdr);
2040 GEN_CHECK_OFF(NVMEQUEUESUBM, u16CompletionQueueId);
2041 GEN_CHECK_OFF(NVMEQUEUESUBM, enmPriority);
2042 GEN_CHECK_OFF(NVMEQUEUESUBM, hEvtProcess);
2043 GEN_CHECK_OFF(NVMEQUEUESUBM, pWrkThrdR3);
2044 GEN_CHECK_OFF(NVMEQUEUESUBM, NdLstWrkThrdAssgnd);
2045 GEN_CHECK_OFF(NVMEQUEUESUBM, cReqsActive);
2046
2047 GEN_CHECK_SIZE(NVMEQUEUECOMP);
2048 GEN_CHECK_OFF(NVMEQUEUECOMP, Hdr);
2049 GEN_CHECK_OFF(NVMEQUEUECOMP, fIntrEnabled);
2050 GEN_CHECK_OFF(NVMEQUEUECOMP, u32IntrVec);
2051 GEN_CHECK_OFF(NVMEQUEUECOMP, cSubmQueuesRef);
2052 GEN_CHECK_OFF(NVMEQUEUECOMP, cWaiters);
2053 GEN_CHECK_OFF(NVMEQUEUECOMP, LstCompletionsWaiting);
2054 GEN_CHECK_OFF(NVMEQUEUECOMP, hMtx);
2055
2056 GEN_CHECK_SIZE(NVME);
2057 GEN_CHECK_OFF(NVME, PciDev);
2058 GEN_CHECK_OFF(NVME, pDevInsR3);
2059 GEN_CHECK_OFF(NVME, pDevInsR0);
2060 GEN_CHECK_OFF(NVME, pDevInsRC);
2061 GEN_CHECK_OFF(NVME, IBase);
2062 GEN_CHECK_OFF(NVME, ILeds);
2063 GEN_CHECK_OFF(NVME, pLedsConnector);
2064 GEN_CHECK_OFF(NVME, pSupDrvSession);
2065 GEN_CHECK_OFF(NVME, GCPhysMMIO);
2066 GEN_CHECK_OFF(NVME, IOPortBase);
2067 GEN_CHECK_OFF(NVME, cQueuesSubmMax);
2068 GEN_CHECK_OFF(NVME, cQueuesCompMax);
2069 GEN_CHECK_OFF(NVME, cQueueEntriesMax);
2070 GEN_CHECK_OFF(NVME, cTimeoutMax);
2071 GEN_CHECK_OFF(NVME, cWrkThrdsMax);
2072 GEN_CHECK_OFF(NVME, cCompQueuesWaitersMax);
2073 GEN_CHECK_OFF(NVME, cNamespaces);
2074 GEN_CHECK_OFF(NVME, szSerialNumber);
2075 GEN_CHECK_OFF(NVME, szModelNumber);
2076 GEN_CHECK_OFF(NVME, szFirmwareRevision);
2077 GEN_CHECK_OFF(NVME, fRCEnabled);
2078 GEN_CHECK_OFF(NVME, fR0Enabled);
2079 GEN_CHECK_OFF(NVME, enmState);
2080 GEN_CHECK_OFF(NVME, u32IntrMask);
2081 GEN_CHECK_OFF(NVME, aIntrVecs);
2082 GEN_CHECK_OFF(NVME, u32IoCompletionQueueEntrySize);
2083 GEN_CHECK_OFF(NVME, u32IoSubmissionQueueEntrySize);
2084 GEN_CHECK_OFF(NVME, uShutdwnNotifierLast);
2085 GEN_CHECK_OFF(NVME, uAmsSet);
2086 GEN_CHECK_OFF(NVME, uMpsSet);
2087 GEN_CHECK_OFF(NVME, uCssSet);
2088 GEN_CHECK_OFF(NVME, u32RegIdx);
2089 GEN_CHECK_OFF(NVME, cbPage);
2090 GEN_CHECK_OFF(NVME, paQueuesSubmR3);
2091 GEN_CHECK_OFF(NVME, paQueuesCompR3);
2092 GEN_CHECK_OFF(NVME, paQueuesSubmR0);
2093 GEN_CHECK_OFF(NVME, paQueuesCompR0);
2094 GEN_CHECK_OFF(NVME, paQueuesSubmRC);
2095 GEN_CHECK_OFF(NVME, paQueuesCompRC);
2096 GEN_CHECK_OFF(NVME, pvCtrlMemBufR3);
2097 GEN_CHECK_OFF(NVME, GCPhysCtrlMemBuf);
2098 GEN_CHECK_OFF(NVME, cbCtrlMemBuf);
2099 GEN_CHECK_OFF(NVME, u32CtrlMemBufSz);
2100 GEN_CHECK_OFF(NVME, pWakeQueueR3);
2101 GEN_CHECK_OFF(NVME, pWakeQueueR0);
2102 GEN_CHECK_OFF(NVME, pWakeQueueRC);
2103 GEN_CHECK_OFF(NVME, cAsyncEvtReqsMax);
2104 GEN_CHECK_OFF(NVME, CritSectAsyncEvtReqs);
2105 GEN_CHECK_OFF(NVME, paAsyncEvtReqCids);
2106 GEN_CHECK_OFF(NVME, paNamespaces);
2107 GEN_CHECK_OFF(NVME, cWrkThrdsCur);
2108 GEN_CHECK_OFF(NVME, cWrkThrdsActive);
2109 GEN_CHECK_OFF(NVME, LstWrkThrds);
2110 GEN_CHECK_OFF(NVME, CritSectWrkThrds);
2111 GEN_CHECK_OFF(NVME, fSignalIdle);
2112# ifdef VBOX_WITH_STATISTICS
2113 GEN_CHECK_OFF(NVME, aStatMemXfer[0]);
2114 GEN_CHECK_OFF(NVME, aStatMemXfer[NVME_CMBSZ_SUPP_BIT_IDX_MAX]);
2115# endif
2116#endif
2117
2118#ifdef VBOX_WITH_IOMMU_AMD
2119# ifdef IOMMU_WITH_DTE_CACHE
2120 GEN_CHECK_SIZE(DTECACHE);
2121# endif
2122# ifdef IOMMU_WITH_DTE_CACHE
2123 GEN_CHECK_SIZE(IRTECACHE);
2124# endif
2125 GEN_CHECK_SIZE(IOMMU);
2126 GEN_CHECK_OFF(IOMMU, idxIommu);
2127 GEN_CHECK_OFF(IOMMU, u32Magic);
2128 GEN_CHECK_OFF(IOMMU, hMmio);
2129 GEN_CHECK_OFF(IOMMU, hEvtCmdThread);
2130 GEN_CHECK_OFF(IOMMU, fCmdThreadSignaled);
2131# ifdef IOMMU_WITH_DTE_CACHE
2132 GEN_CHECK_OFF(IOMMU, CritSectCache);
2133 GEN_CHECK_OFF(IOMMU, aDeviceIds);
2134 GEN_CHECK_OFF(IOMMU, aDteCache);
2135# endif
2136# ifdef IOMMU_WITH_IRTE_CACHE
2137 GEN_CHECK_OFF(IOMMU, aIrteCache);
2138# endif
2139 GEN_CHECK_OFF(IOMMU, IommuBar);
2140 GEN_CHECK_OFF(IOMMU, aDevTabBaseAddrs);
2141 GEN_CHECK_OFF(IOMMU, CmdBufBaseAddr);
2142 GEN_CHECK_OFF(IOMMU, EvtLogBaseAddr);
2143 GEN_CHECK_OFF(IOMMU, Ctrl);
2144 GEN_CHECK_OFF(IOMMU, ExclRangeBaseAddr);
2145 GEN_CHECK_OFF(IOMMU, ExclRangeLimit);
2146 GEN_CHECK_OFF(IOMMU, ExtFeat);
2147 GEN_CHECK_OFF(IOMMU, PprLogBaseAddr);
2148 GEN_CHECK_OFF(IOMMU, HwEvtHi);
2149 GEN_CHECK_OFF(IOMMU, HwEvtLo);
2150 GEN_CHECK_OFF(IOMMU, HwEvtStatus);
2151 GEN_CHECK_OFF(IOMMU, GALogBaseAddr);
2152 GEN_CHECK_OFF(IOMMU, GALogTailAddr);
2153 GEN_CHECK_OFF(IOMMU, PprLogBBaseAddr);
2154 GEN_CHECK_OFF(IOMMU, EvtLogBBaseAddr);
2155 GEN_CHECK_OFF(IOMMU, DevSpecificFeat);
2156 GEN_CHECK_OFF(IOMMU, DevSpecificCtrl);
2157 GEN_CHECK_OFF(IOMMU, DevSpecificStatus);
2158 GEN_CHECK_OFF(IOMMU, MiscInfo);
2159 GEN_CHECK_OFF(IOMMU, PerfOptCtrl);
2160 GEN_CHECK_OFF(IOMMU, XtGenIntrCtrl);
2161 GEN_CHECK_OFF(IOMMU, XtPprIntrCtrl);
2162 GEN_CHECK_OFF(IOMMU, XtGALogIntrCtrl);
2163 GEN_CHECK_OFF(IOMMU, aMarcApers);
2164 GEN_CHECK_OFF(IOMMU, RsvdReg);
2165 GEN_CHECK_OFF(IOMMU, CmdBufHeadPtr);
2166 GEN_CHECK_OFF(IOMMU, CmdBufTailPtr);
2167 GEN_CHECK_OFF(IOMMU, EvtLogHeadPtr);
2168 GEN_CHECK_OFF(IOMMU, EvtLogTailPtr);
2169 GEN_CHECK_OFF(IOMMU, Status);
2170 GEN_CHECK_OFF(IOMMU, PprLogHeadPtr);
2171 GEN_CHECK_OFF(IOMMU, PprLogTailPtr);
2172 GEN_CHECK_OFF(IOMMU, GALogHeadPtr);
2173 GEN_CHECK_OFF(IOMMU, GALogTailPtr);
2174 GEN_CHECK_OFF(IOMMU, PprLogBHeadPtr);
2175 GEN_CHECK_OFF(IOMMU, PprLogBTailPtr);
2176 GEN_CHECK_OFF(IOMMU, EvtLogBHeadPtr);
2177 GEN_CHECK_OFF(IOMMU, EvtLogBTailPtr);
2178 GEN_CHECK_OFF(IOMMU, PprLogAutoResp);
2179 GEN_CHECK_OFF(IOMMU, PprLogOverflowEarly);
2180 GEN_CHECK_OFF(IOMMU, PprLogBOverflowEarly);
2181# ifdef VBOX_WITH_STATISTICS
2182 GEN_CHECK_OFF(IOMMU, StatMmioReadR3);
2183 GEN_CHECK_OFF(IOMMU, StatMmioReadRZ);
2184 GEN_CHECK_OFF(IOMMU, StatMmioWriteR3);
2185 GEN_CHECK_OFF(IOMMU, StatMmioWriteRZ);
2186 GEN_CHECK_OFF(IOMMU, StatMsiRemapR3);
2187 GEN_CHECK_OFF(IOMMU, StatMsiRemapRZ);
2188 GEN_CHECK_OFF(IOMMU, StatMemReadR3);
2189 GEN_CHECK_OFF(IOMMU, StatMemReadRZ);
2190 GEN_CHECK_OFF(IOMMU, StatMemWriteR3);
2191 GEN_CHECK_OFF(IOMMU, StatMemWriteRZ);
2192 GEN_CHECK_OFF(IOMMU, StatMemBulkReadR3);
2193 GEN_CHECK_OFF(IOMMU, StatMemBulkReadRZ);
2194 GEN_CHECK_OFF(IOMMU, StatMemBulkWriteR3);
2195 GEN_CHECK_OFF(IOMMU, StatMemBulkWriteRZ);
2196 GEN_CHECK_OFF(IOMMU, StatCmd);
2197 GEN_CHECK_OFF(IOMMU, StatCmdCompWait);
2198 GEN_CHECK_OFF(IOMMU, StatCmdInvDte);
2199 GEN_CHECK_OFF(IOMMU, StatCmdInvIommuPages);
2200 GEN_CHECK_OFF(IOMMU, StatCmdInvIotlbPages);
2201 GEN_CHECK_OFF(IOMMU, StatCmdInvIntrTable);
2202 GEN_CHECK_OFF(IOMMU, StatCmdPrefIommuPages);
2203 GEN_CHECK_OFF(IOMMU, StatCmdCompletePprReq);
2204 GEN_CHECK_OFF(IOMMU, StatCmdInvIommuAll);
2205 GEN_CHECK_OFF(IOMMU, StatIotlbeCached);
2206 GEN_CHECK_OFF(IOMMU, StatIotlbeLazyEvictReuse);
2207 GEN_CHECK_OFF(IOMMU, StatProfDteLookup);
2208 GEN_CHECK_OFF(IOMMU, StatProfIotlbeLookup);
2209 GEN_CHECK_OFF(IOMMU, StatProfIrteLookup);
2210 GEN_CHECK_OFF(IOMMU, StatProfIrteCacheLookup);
2211 GEN_CHECK_OFF(IOMMU, StatAccessCacheHit);
2212 GEN_CHECK_OFF(IOMMU, StatAccessCacheHitFull);
2213 GEN_CHECK_OFF(IOMMU, StatAccessCacheMiss);
2214 GEN_CHECK_OFF(IOMMU, StatAccessCacheNonContig);
2215 GEN_CHECK_OFF(IOMMU, StatAccessCachePermDenied);
2216 GEN_CHECK_OFF(IOMMU, StatAccessDteNonContig);
2217 GEN_CHECK_OFF(IOMMU, StatAccessDtePermDenied);
2218 GEN_CHECK_OFF(IOMMU, StatIntrCacheHit);
2219 GEN_CHECK_OFF(IOMMU, StatIntrCacheMiss);
2220# endif
2221#endif
2222
2223#ifdef VBOX_WITH_IOMMU_INTEL
2224 GEN_CHECK_SIZE(DMAR);
2225 GEN_CHECK_OFF(DMAR, idxIommu);
2226 GEN_CHECK_OFF(DMAR, abRegs0);
2227 GEN_CHECK_OFF(DMAR, abRegs1);
2228 GEN_CHECK_OFF(DMAR, uIrtaReg);
2229 GEN_CHECK_OFF(DMAR, uRtaddrReg);
2230 GEN_CHECK_OFF(DMAR, uVerReg);
2231 GEN_CHECK_OFF(DMAR, fCapReg);
2232 GEN_CHECK_OFF(DMAR, fExtCapReg);
2233 GEN_CHECK_OFF(DMAR, fHawBaseMask);
2234 GEN_CHECK_OFF(DMAR, fMgawInvMask);
2235 GEN_CHECK_OFF(DMAR, cMaxPagingLevel);
2236 GEN_CHECK_OFF(DMAR, fPermValidMask);
2237 GEN_CHECK_OFF(DMAR, hEvtInvQueue);
2238 GEN_CHECK_OFF(DMAR, enmDiag);
2239 GEN_CHECK_OFF(DMAR, hMmio);
2240# ifdef VBOX_WITH_STATISTICS
2241 GEN_CHECK_OFF(DMAR, StatMmioReadR3);
2242 GEN_CHECK_OFF(DMAR, StatMmioReadRZ);
2243 GEN_CHECK_OFF(DMAR, StatMmioWriteR3);
2244 GEN_CHECK_OFF(DMAR, StatMmioWriteRZ);
2245 GEN_CHECK_OFF(DMAR, StatMsiRemapCfiR3);
2246 GEN_CHECK_OFF(DMAR, StatMsiRemapCfiRZ);
2247 GEN_CHECK_OFF(DMAR, StatMsiRemapRfiR3);
2248 GEN_CHECK_OFF(DMAR, StatMsiRemapRfiRZ);
2249 GEN_CHECK_OFF(DMAR, StatMemReadR3);
2250 GEN_CHECK_OFF(DMAR, StatMemReadRZ);
2251 GEN_CHECK_OFF(DMAR, StatMemWriteR3);
2252 GEN_CHECK_OFF(DMAR, StatMemWriteRZ);
2253 GEN_CHECK_OFF(DMAR, StatMemBulkReadR3);
2254 GEN_CHECK_OFF(DMAR, StatMemBulkReadRZ);
2255 GEN_CHECK_OFF(DMAR, StatMemBulkWriteR3);
2256 GEN_CHECK_OFF(DMAR, StatMemBulkWriteRZ);
2257 GEN_CHECK_OFF(DMAR, StatCcInvDsc);
2258 GEN_CHECK_OFF(DMAR, StatIotlbInvDsc);
2259 GEN_CHECK_OFF(DMAR, StatDevtlbInvDsc);
2260 GEN_CHECK_OFF(DMAR, StatIecInvDsc);
2261 GEN_CHECK_OFF(DMAR, StatInvWaitDsc);
2262 GEN_CHECK_OFF(DMAR, StatPasidIotlbInvDsc);
2263 GEN_CHECK_OFF(DMAR, StatPasidCacheInvDsc);
2264 GEN_CHECK_OFF(DMAR, StatPasidDevtlbInvDsc);
2265# endif
2266
2267 GEN_CHECK_SIZE(DMARIOPAGE);
2268 GEN_CHECK_OFF(DMARIOPAGE, GCPhysBase);
2269 GEN_CHECK_OFF(DMARIOPAGE, cShift);
2270 GEN_CHECK_OFF(DMARIOPAGE, fPerm);
2271
2272 GEN_CHECK_SIZE(DMARIOADDRRANGE);
2273 GEN_CHECK_OFF(DMARIOADDRRANGE, uAddr);
2274 GEN_CHECK_OFF(DMARIOADDRRANGE, cb);
2275 GEN_CHECK_OFF(DMARIOADDRRANGE, fPerm);
2276
2277 GEN_CHECK_SIZE(DMARMEMREQIN);
2278 GEN_CHECK_OFF(DMARMEMREQIN, AddrRange);
2279 GEN_CHECK_OFF(DMARMEMREQIN, idDevice);
2280 GEN_CHECK_OFF(DMARMEMREQIN, Pasid);
2281 GEN_CHECK_OFF(DMARMEMREQIN, enmAddrType);
2282 GEN_CHECK_OFF(DMARMEMREQIN, enmReqType);
2283
2284 GEN_CHECK_SIZE(DMARMEMREQOUT);
2285 GEN_CHECK_OFF(DMARMEMREQOUT, AddrRange);
2286 GEN_CHECK_OFF(DMARMEMREQOUT, idDomain);
2287
2288 GEN_CHECK_SIZE(DMARMEMREQAUX);
2289 GEN_CHECK_OFF(DMARMEMREQAUX, fTtm
2290 GEN_CHECK_OFF(DMARMEMREQAUX, fFpd);
2291 GEN_CHECK_OFF(DMARMEMREQAUX, cPagingLevel);
2292 GEN_CHECK_OFF(DMARMEMREQAUX, GCPhysFlPt);
2293 GEN_CHECK_OFF(DMARMEMREQAUX, GCPhysSlPt);
2294
2295 GEN_CHECK_SIZE(DMARMEMREQREMAP);
2296 GEN_CHECK_OFF(DMARMEMREQREMAP, In);
2297 GEN_CHECK_OFF(DMARMEMREQREMAP, Aux);
2298 GEN_CHECK_OFF(DMARMEMREQREMAP, Out);
2299#endif
2300
2301 return (0);
2302}
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