VirtualBox

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

Last change on this file since 37126 was 36878, checked in by vboxsync, 13 years ago

AHCI: Support access through the index/data register pair from the I/O port space (as described in 10.14 of the AHCI 1.2 spec). Required for the BIOS driver

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 68.2 KB
Line 
1/* $Id: tstDeviceStructSizeRC.cpp 36878 2011-04-28 19:48:01Z 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-2010 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#undef LOG_GROUP
39#include "../Bus/DevPCI.cpp" /* must be first! */
40#undef LOG_GROUP
41#include "../Bus/DevPciIch9.cpp"
42#undef LOG_GROUP
43#include "../Graphics/DevVGA.cpp"
44#undef LOG_GROUP
45#include "../Input/DevPS2.cpp"
46#undef LOG_GROUP
47#include "../Network/DevPCNet.cpp"
48#undef LOG_GROUP
49#include "../PC/DevACPI.cpp"
50#undef LOG_GROUP
51#include "../PC/DevPIC.cpp"
52#undef LOG_GROUP
53#include "../PC/DevPit-i8254.cpp"
54#undef LOG_GROUP
55#include "../PC/DevRTC.cpp"
56#undef LOG_GROUP
57#include "../PC/DevAPIC.cpp"
58#undef LOG_GROUP
59#include "../Storage/DevATA.cpp"
60#ifdef VBOX_WITH_USB
61# undef LOG_GROUP
62# include "../USB/DevOHCI.cpp"
63# ifdef VBOX_WITH_EHCI
64# include "../USB/DevEHCI.cpp"
65# endif
66#endif
67#undef LOG_GROUP
68#include "../VMMDev/VMMDev.cpp"
69#undef LOG_GROUP
70#include "../Parallel/DevParallel.cpp"
71#undef LOG_GROUP
72#include "../Serial/DevSerial.cpp"
73#ifdef VBOX_WITH_AHCI
74# undef LOG_GROUP
75# include "../Storage/DevAHCI.cpp"
76#endif
77#ifdef VBOX_WITH_E1000
78# undef LOG_GROUP
79# include "../Network/DevE1000.cpp"
80#endif
81#ifdef VBOX_WITH_VIRTIO
82# undef LOG_GROUP
83# include "../Network/DevVirtioNet.cpp"
84#endif
85#ifdef VBOX_WITH_BUSLOGIC
86# undef LOG_GROUP
87# include "../Storage/DevBusLogic.cpp"
88#endif
89#ifdef VBOX_WITH_LSILOGIC
90# undef LOG_GROUP
91# include "../Storage/DevLsiLogicSCSI.cpp"
92#endif
93#undef LOG_GROUP
94#include "../PC/DevHPET.cpp"
95
96/* we don't use iprt here because we're pretending to be in GC! */
97#include <stdio.h>
98
99#define GEN_CHECK_SIZE(s) printf(" CHECK_SIZE(%s, %d);\n", #s, (int)sizeof(s))
100#define GEN_CHECK_OFF(s, m) printf(" CHECK_OFF(%s, %d, %s);\n", #s, (int)RT_OFFSETOF(s, m), #m)
101#define GEN_CHECK_PADDING(s, m, a) printf(" CHECK_PADDING(%s, %s, %u);\n", #s, #m, (a))
102
103int main()
104{
105 /* misc */
106 GEN_CHECK_SIZE(PDMDEVINS);
107 GEN_CHECK_OFF(PDMDEVINS, Internal);
108 GEN_CHECK_OFF(PDMDEVINS, pReg);
109 GEN_CHECK_OFF(PDMDEVINS, pCfg);
110 GEN_CHECK_OFF(PDMDEVINS, iInstance);
111 GEN_CHECK_OFF(PDMDEVINS, IBase);
112 GEN_CHECK_OFF(PDMDEVINS, pHlpR3);
113 GEN_CHECK_OFF(PDMDEVINS, pHlpR0);
114 GEN_CHECK_OFF(PDMDEVINS, pHlpRC);
115 GEN_CHECK_OFF(PDMDEVINS, pvInstanceDataR3);
116 GEN_CHECK_OFF(PDMDEVINS, pvInstanceDataR0);
117 GEN_CHECK_OFF(PDMDEVINS, pvInstanceDataRC);
118 GEN_CHECK_OFF(PDMDEVINS, achInstanceData);
119
120 /* DevPCI.cpp */
121 GEN_CHECK_SIZE(PCIDEVICE);
122 GEN_CHECK_SIZE(PCIDEVICEINT);
123 GEN_CHECK_SIZE(PCIIOREGION);
124 GEN_CHECK_OFF(PCIDEVICE, config);
125 GEN_CHECK_OFF(PCIDEVICE, devfn);
126 GEN_CHECK_OFF(PCIDEVICE, name);
127 GEN_CHECK_OFF(PCIDEVICE, pDevIns);
128 GEN_CHECK_OFF(PCIDEVICE, Int);
129 GEN_CHECK_OFF(PCIDEVICE, Int.s.aIORegions);
130 GEN_CHECK_OFF(PCIDEVICE, Int.s.aIORegions[1]);
131 GEN_CHECK_OFF(PCIDEVICE, Int.s.aIORegions[PCI_NUM_REGIONS - 1]);
132 GEN_CHECK_OFF(PCIDEVICE, Int.s.aIORegions[0].addr);
133 GEN_CHECK_OFF(PCIDEVICE, Int.s.aIORegions[0].size);
134 GEN_CHECK_OFF(PCIDEVICE, Int.s.aIORegions[0].type);
135 GEN_CHECK_OFF(PCIDEVICE, Int.s.aIORegions[0].padding);
136 GEN_CHECK_OFF(PCIDEVICE, Int.s.pBusR3);
137 GEN_CHECK_OFF(PCIDEVICE, Int.s.pBusR0);
138 GEN_CHECK_OFF(PCIDEVICE, Int.s.pBusRC);
139 GEN_CHECK_OFF(PCIDEVICE, Int.s.pfnConfigRead);
140 GEN_CHECK_OFF(PCIDEVICE, Int.s.pfnConfigWrite);
141 GEN_CHECK_OFF(PCIDEVICE, Int.s.fFlags);
142 GEN_CHECK_OFF(PCIDEVICE, Int.s.uIrqPinState);
143 GEN_CHECK_OFF(PCIDEVICE, Int.s.pfnBridgeConfigRead);
144 GEN_CHECK_OFF(PCIDEVICE, Int.s.pfnBridgeConfigWrite);
145 GEN_CHECK_PADDING(PCIDEVICE, Int, 8);
146 GEN_CHECK_SIZE(PIIX3State);
147 GEN_CHECK_SIZE(PCIBUS);
148 GEN_CHECK_OFF(PCIBUS, iBus);
149 GEN_CHECK_OFF(PCIBUS, iDevSearch);
150 GEN_CHECK_OFF(PCIBUS, cBridges);
151 GEN_CHECK_OFF(PCIBUS, devices);
152 GEN_CHECK_OFF(PCIBUS, devices[1]);
153 GEN_CHECK_OFF(PCIBUS, pDevInsR3);
154 GEN_CHECK_OFF(PCIBUS, pPciHlpR3);
155 GEN_CHECK_OFF(PCIBUS, papBridgesR3);
156 GEN_CHECK_OFF(PCIBUS, pDevInsR0);
157 GEN_CHECK_OFF(PCIBUS, pPciHlpR0);
158 GEN_CHECK_OFF(PCIBUS, pDevInsRC);
159 GEN_CHECK_OFF(PCIBUS, pPciHlpRC);
160 GEN_CHECK_OFF(PCIBUS, PciDev);
161 GEN_CHECK_SIZE(PCIGLOBALS);
162 GEN_CHECK_OFF(PCIGLOBALS, pci_bios_io_addr);
163 GEN_CHECK_OFF(PCIGLOBALS, pci_bios_mem_addr);
164 GEN_CHECK_OFF(PCIGLOBALS, pci_irq_levels);
165 GEN_CHECK_OFF(PCIGLOBALS, pci_irq_levels[1]);
166 GEN_CHECK_OFF(PCIGLOBALS, fUseIoApic);
167 GEN_CHECK_OFF(PCIGLOBALS, pci_apic_irq_levels);
168 GEN_CHECK_OFF(PCIGLOBALS, pci_apic_irq_levels[1]);
169 GEN_CHECK_OFF(PCIGLOBALS, acpi_irq_level);
170 GEN_CHECK_OFF(PCIGLOBALS, acpi_irq);
171 GEN_CHECK_OFF(PCIGLOBALS, uConfigReg);
172 GEN_CHECK_OFF(PCIGLOBALS, pDevInsR3);
173 GEN_CHECK_OFF(PCIGLOBALS, pDevInsR0);
174 GEN_CHECK_OFF(PCIGLOBALS, pDevInsRC);
175 GEN_CHECK_OFF(PCIGLOBALS, PIIX3State);
176 GEN_CHECK_OFF(PCIGLOBALS, PciBus);
177
178 /* DevPciIch9.cpp */
179 GEN_CHECK_SIZE(ICH9PCIBUS);
180 GEN_CHECK_OFF(ICH9PCIBUS, iBus);
181 GEN_CHECK_OFF(ICH9PCIBUS, cBridges);
182 GEN_CHECK_OFF(ICH9PCIBUS, apDevices);
183 GEN_CHECK_OFF(ICH9PCIBUS, apDevices[1]);
184 GEN_CHECK_OFF(ICH9PCIBUS, pDevInsR3);
185 GEN_CHECK_OFF(ICH9PCIBUS, pPciHlpR3);
186 GEN_CHECK_OFF(ICH9PCIBUS, papBridgesR3);
187 GEN_CHECK_OFF(ICH9PCIBUS, pDevInsR0);
188 GEN_CHECK_OFF(ICH9PCIBUS, pPciHlpR0);
189 GEN_CHECK_OFF(ICH9PCIBUS, pDevInsRC);
190 GEN_CHECK_OFF(ICH9PCIBUS, pPciHlpRC);
191 GEN_CHECK_OFF(ICH9PCIBUS, aPciDev);
192 GEN_CHECK_SIZE(ICH9PCIGLOBALS);
193 GEN_CHECK_OFF(ICH9PCIGLOBALS, pDevInsR3);
194 GEN_CHECK_OFF(ICH9PCIGLOBALS, pDevInsR0);
195 GEN_CHECK_OFF(ICH9PCIGLOBALS, pDevInsRC);
196 GEN_CHECK_OFF(ICH9PCIGLOBALS, uConfigReg);
197 GEN_CHECK_OFF(ICH9PCIGLOBALS, uaPciApicIrqLevels);
198 GEN_CHECK_OFF(ICH9PCIGLOBALS, uaPciApicIrqLevels[1]);
199 GEN_CHECK_OFF(ICH9PCIGLOBALS, uPciBiosIo);
200 GEN_CHECK_OFF(ICH9PCIGLOBALS, uPciBiosMmio);
201 GEN_CHECK_OFF(ICH9PCIGLOBALS, uBus);
202 GEN_CHECK_OFF(ICH9PCIGLOBALS, u64PciConfigMMioAddress);
203 GEN_CHECK_OFF(ICH9PCIGLOBALS, u64PciConfigMMioLength);
204 GEN_CHECK_OFF(ICH9PCIGLOBALS, aPciBus);
205
206 /* DevVGA.cpp */
207 GEN_CHECK_SIZE(VGASTATE);
208 GEN_CHECK_OFF(VGASTATE, vram_ptrR3);
209 GEN_CHECK_OFF(VGASTATE, vram_size);
210 GEN_CHECK_OFF(VGASTATE, latch);
211 GEN_CHECK_OFF(VGASTATE, sr_index);
212 GEN_CHECK_OFF(VGASTATE, sr);
213 GEN_CHECK_OFF(VGASTATE, sr[1]);
214 GEN_CHECK_OFF(VGASTATE, gr_index);
215 GEN_CHECK_OFF(VGASTATE, gr);
216 GEN_CHECK_OFF(VGASTATE, gr[1]);
217 GEN_CHECK_OFF(VGASTATE, ar_index);
218 GEN_CHECK_OFF(VGASTATE, ar);
219 GEN_CHECK_OFF(VGASTATE, ar[1]);
220 GEN_CHECK_OFF(VGASTATE, ar_flip_flop);
221 GEN_CHECK_OFF(VGASTATE, cr_index);
222 GEN_CHECK_OFF(VGASTATE, cr);
223 GEN_CHECK_OFF(VGASTATE, cr[1]);
224 GEN_CHECK_OFF(VGASTATE, msr);
225 GEN_CHECK_OFF(VGASTATE, msr);
226 GEN_CHECK_OFF(VGASTATE, fcr);
227 GEN_CHECK_OFF(VGASTATE, st00);
228 GEN_CHECK_OFF(VGASTATE, st01);
229 GEN_CHECK_OFF(VGASTATE, dac_state);
230 GEN_CHECK_OFF(VGASTATE, dac_sub_index);
231 GEN_CHECK_OFF(VGASTATE, dac_read_index);
232 GEN_CHECK_OFF(VGASTATE, dac_write_index);
233 GEN_CHECK_OFF(VGASTATE, dac_cache);
234 GEN_CHECK_OFF(VGASTATE, dac_cache[1]);
235 GEN_CHECK_OFF(VGASTATE, palette);
236 GEN_CHECK_OFF(VGASTATE, palette[1]);
237 GEN_CHECK_OFF(VGASTATE, bank_offset);
238 GEN_CHECK_OFF(VGASTATE, get_bpp);
239 GEN_CHECK_OFF(VGASTATE, get_offsets);
240 GEN_CHECK_OFF(VGASTATE, get_resolution);
241#ifdef CONFIG_BOCHS_VBE
242 GEN_CHECK_OFF(VGASTATE, vbe_index);
243 GEN_CHECK_OFF(VGASTATE, vbe_regs);
244 GEN_CHECK_OFF(VGASTATE, vbe_regs[1]);
245 GEN_CHECK_OFF(VGASTATE, vbe_regs[VBE_DISPI_INDEX_NB - 1]);
246 GEN_CHECK_OFF(VGASTATE, vbe_start_addr);
247 GEN_CHECK_OFF(VGASTATE, vbe_line_offset);
248 GEN_CHECK_OFF(VGASTATE, vbe_bank_max);
249#endif
250 GEN_CHECK_OFF(VGASTATE, font_offsets);
251 GEN_CHECK_OFF(VGASTATE, font_offsets[1]);
252 GEN_CHECK_OFF(VGASTATE, graphic_mode);
253 GEN_CHECK_OFF(VGASTATE, shift_control);
254 GEN_CHECK_OFF(VGASTATE, double_scan);
255 GEN_CHECK_OFF(VGASTATE, line_offset);
256 GEN_CHECK_OFF(VGASTATE, line_compare);
257 GEN_CHECK_OFF(VGASTATE, start_addr);
258 GEN_CHECK_OFF(VGASTATE, plane_updated);
259 GEN_CHECK_OFF(VGASTATE, last_cw);
260 GEN_CHECK_OFF(VGASTATE, last_ch);
261 GEN_CHECK_OFF(VGASTATE, last_width);
262 GEN_CHECK_OFF(VGASTATE, last_height);
263 GEN_CHECK_OFF(VGASTATE, last_scr_width);
264 GEN_CHECK_OFF(VGASTATE, last_scr_height);
265 GEN_CHECK_OFF(VGASTATE, last_bpp);
266 GEN_CHECK_OFF(VGASTATE, cursor_start);
267 GEN_CHECK_OFF(VGASTATE, cursor_end);
268 GEN_CHECK_OFF(VGASTATE, cursor_offset);
269 GEN_CHECK_OFF(VGASTATE, rgb_to_pixel);
270 GEN_CHECK_OFF(VGASTATE, invalidated_y_table);
271 GEN_CHECK_OFF(VGASTATE, invalidated_y_table[1]);
272 GEN_CHECK_OFF(VGASTATE, invalidated_y_table[(VGA_MAX_HEIGHT / 32) - 1]);
273 GEN_CHECK_OFF(VGASTATE, cursor_invalidate);
274 GEN_CHECK_OFF(VGASTATE, cursor_draw_line);
275 GEN_CHECK_OFF(VGASTATE, last_palette);
276 GEN_CHECK_OFF(VGASTATE, last_palette[1]);
277 GEN_CHECK_OFF(VGASTATE, last_ch_attr);
278 GEN_CHECK_OFF(VGASTATE, last_ch_attr[CH_ATTR_SIZE - 1]);
279 GEN_CHECK_OFF(VGASTATE, u32Marker);
280 GEN_CHECK_OFF(VGASTATE, GCPhysVRAM);
281 GEN_CHECK_OFF(VGASTATE, vram_ptrR0);
282 GEN_CHECK_OFF(VGASTATE, vram_ptrRC);
283 GEN_CHECK_OFF(VGASTATE, fLFBUpdated);
284 GEN_CHECK_OFF(VGASTATE, fGCEnabled);
285 GEN_CHECK_OFF(VGASTATE, fR0Enabled);
286 GEN_CHECK_OFF(VGASTATE, fHasDirtyBits);
287 GEN_CHECK_OFF(VGASTATE, fRemappedVGA);
288 GEN_CHECK_OFF(VGASTATE, fRenderVRAM);
289#ifdef VBOX_WITH_HGSMI
290 GEN_CHECK_OFF(VGASTATE, pHGSMI);
291#endif
292#ifdef VBOX_WITH_VDMA
293 GEN_CHECK_OFF(VGASTATE, pVdma);
294#endif
295 GEN_CHECK_OFF(VGASTATE, cMonitors);
296 GEN_CHECK_OFF(VGASTATE, cMilliesRefreshInterval);
297 GEN_CHECK_OFF(VGASTATE, RefreshTimer);
298 GEN_CHECK_OFF(VGASTATE, au32DirtyBitmap);
299 GEN_CHECK_OFF(VGASTATE, au32DirtyBitmap[1]);
300 GEN_CHECK_OFF(VGASTATE, au32DirtyBitmap[(VGA_VRAM_MAX / PAGE_SIZE / 32) - 1]);
301 GEN_CHECK_OFF(VGASTATE, RCPtrLFBHandler);
302 GEN_CHECK_OFF(VGASTATE, pDevInsRC);
303 GEN_CHECK_OFF(VGASTATE, pDevInsR3);
304 GEN_CHECK_OFF(VGASTATE, pDevInsR0);
305 GEN_CHECK_OFF(VGASTATE, lock);
306 GEN_CHECK_OFF(VGASTATE, IBase);
307 GEN_CHECK_OFF(VGASTATE, IPort);
308#if defined(VBOX_WITH_HGSMI) && defined(VBOX_WITH_VIDEOHWACCEL)
309 GEN_CHECK_OFF(VGASTATE, IVBVACallbacks);
310#endif
311 GEN_CHECK_OFF(VGASTATE, pDrvBase);
312 GEN_CHECK_OFF(VGASTATE, pDrv);
313 GEN_CHECK_OFF(VGASTATE, Dev);
314 GEN_CHECK_OFF(VGASTATE, StatRZMemoryRead);
315 GEN_CHECK_OFF(VGASTATE, StatR3MemoryRead);
316 GEN_CHECK_OFF(VGASTATE, StatRZMemoryWrite);
317 GEN_CHECK_OFF(VGASTATE, StatR3MemoryWrite);
318#ifdef VBE_BYTEWISE_IO
319 GEN_CHECK_OFF(VGASTATE, fReadVBEData);
320 GEN_CHECK_OFF(VGASTATE, fWriteVBEData);
321 GEN_CHECK_OFF(VGASTATE, fReadVBEIndex);
322 GEN_CHECK_OFF(VGASTATE, fWriteVBEIndex);
323 GEN_CHECK_OFF(VGASTATE, cbWriteVBEData);
324 GEN_CHECK_OFF(VGASTATE, cbWriteVBEIndex);
325# ifdef VBE_NEW_DYN_LIST
326 GEN_CHECK_OFF(VGASTATE, cbWriteVBEExtraAddress);
327# endif
328#endif
329#ifdef VBE_NEW_DYN_LIST
330 GEN_CHECK_OFF(VGASTATE, cbVBEExtraData);
331 GEN_CHECK_OFF(VGASTATE, pu8VBEExtraData);
332 GEN_CHECK_OFF(VGASTATE, u16VBEExtraAddress);
333#endif
334#ifdef VBOX_WITH_HGSMI
335 GEN_CHECK_OFF(VGASTATE, IOPortBase);
336#endif
337#ifdef VBOX_WITH_WDDM
338 GEN_CHECK_OFF(VGASTATE, fGuestCaps);
339#endif
340
341 /* Input/pckbd.c */
342 GEN_CHECK_SIZE(KBDQueue);
343 GEN_CHECK_OFF(KBDQueue, data);
344 GEN_CHECK_OFF(KBDQueue, rptr);
345 GEN_CHECK_OFF(KBDQueue, wptr);
346 GEN_CHECK_OFF(KBDQueue, count);
347 GEN_CHECK_SIZE(MouseCmdQueue);
348 GEN_CHECK_OFF(MouseCmdQueue, data);
349 GEN_CHECK_OFF(MouseCmdQueue, rptr);
350 GEN_CHECK_OFF(MouseCmdQueue, wptr);
351 GEN_CHECK_OFF(MouseCmdQueue, count);
352 GEN_CHECK_SIZE(MouseEventQueue);
353 GEN_CHECK_OFF(MouseEventQueue, data);
354 GEN_CHECK_OFF(MouseEventQueue, rptr);
355 GEN_CHECK_OFF(MouseEventQueue, wptr);
356 GEN_CHECK_OFF(MouseEventQueue, count);
357 GEN_CHECK_SIZE(KBDState);
358 GEN_CHECK_OFF(KBDState, queue);
359 GEN_CHECK_OFF(KBDState, mouse_command_queue);
360 GEN_CHECK_OFF(KBDState, mouse_event_queue);
361 GEN_CHECK_OFF(KBDState, write_cmd);
362 GEN_CHECK_OFF(KBDState, status);
363 GEN_CHECK_OFF(KBDState, mode);
364 GEN_CHECK_OFF(KBDState, kbd_write_cmd);
365 GEN_CHECK_OFF(KBDState, scan_enabled);
366 GEN_CHECK_OFF(KBDState, mouse_write_cmd);
367 GEN_CHECK_OFF(KBDState, mouse_status);
368 GEN_CHECK_OFF(KBDState, mouse_resolution);
369 GEN_CHECK_OFF(KBDState, mouse_sample_rate);
370 GEN_CHECK_OFF(KBDState, mouse_wrap);
371 GEN_CHECK_OFF(KBDState, mouse_type);
372 GEN_CHECK_OFF(KBDState, mouse_detect_state);
373 GEN_CHECK_OFF(KBDState, mouse_dx);
374 GEN_CHECK_OFF(KBDState, mouse_dy);
375 GEN_CHECK_OFF(KBDState, mouse_dz);
376 GEN_CHECK_OFF(KBDState, mouse_dw);
377 GEN_CHECK_OFF(KBDState, mouse_buttons);
378 GEN_CHECK_OFF(KBDState, pDevInsR3);
379 GEN_CHECK_OFF(KBDState, pDevInsR0);
380 GEN_CHECK_OFF(KBDState, pDevInsRC);
381 GEN_CHECK_OFF(KBDState, Keyboard.IBase);
382 GEN_CHECK_OFF(KBDState, Keyboard.IPort);
383 GEN_CHECK_OFF(KBDState, Keyboard.pDrvBase);
384 GEN_CHECK_OFF(KBDState, Keyboard.pDrv);
385 GEN_CHECK_OFF(KBDState, Mouse.IBase);
386 GEN_CHECK_OFF(KBDState, Mouse.IPort);
387 GEN_CHECK_OFF(KBDState, Mouse.pDrvBase);
388 GEN_CHECK_OFF(KBDState, Mouse.pDrv);
389
390 /* Network/DevPCNet.cpp */
391 GEN_CHECK_SIZE(PCNetState);
392 GEN_CHECK_OFF(PCNetState, PciDev);
393#ifndef PCNET_NO_POLLING
394 GEN_CHECK_OFF(PCNetState, pTimerPollR3);
395 GEN_CHECK_OFF(PCNetState, pTimerPollR0);
396 GEN_CHECK_OFF(PCNetState, pTimerPollRC);
397#endif
398 GEN_CHECK_OFF(PCNetState, pTimerSoftIntR3);
399 GEN_CHECK_OFF(PCNetState, pTimerSoftIntR0);
400 GEN_CHECK_OFF(PCNetState, pTimerSoftIntRC);
401 GEN_CHECK_OFF(PCNetState, u32RAP);
402 GEN_CHECK_OFF(PCNetState, iISR);
403 GEN_CHECK_OFF(PCNetState, u32Lnkst);
404 GEN_CHECK_OFF(PCNetState, GCRDRA);
405 GEN_CHECK_OFF(PCNetState, GCTDRA);
406 GEN_CHECK_OFF(PCNetState, aPROM);
407 GEN_CHECK_OFF(PCNetState, aPROM[1]);
408 GEN_CHECK_OFF(PCNetState, aCSR);
409 GEN_CHECK_OFF(PCNetState, aCSR[1]);
410 GEN_CHECK_OFF(PCNetState, aCSR[CSR_MAX_REG - 1]);
411 GEN_CHECK_OFF(PCNetState, aBCR);
412 GEN_CHECK_OFF(PCNetState, aBCR[1]);
413 GEN_CHECK_OFF(PCNetState, aBCR[BCR_MAX_RAP - 1]);
414 GEN_CHECK_OFF(PCNetState, aMII);
415 GEN_CHECK_OFF(PCNetState, aMII[1]);
416 GEN_CHECK_OFF(PCNetState, aMII[MII_MAX_REG - 1]);
417 GEN_CHECK_OFF(PCNetState, u16CSR0LastSeenByGuest);
418 GEN_CHECK_OFF(PCNetState, u64LastPoll);
419 GEN_CHECK_OFF(PCNetState, abLoopBuf);
420 GEN_CHECK_OFF(PCNetState, abRecvBuf);
421 GEN_CHECK_OFF(PCNetState, iLog2DescSize);
422 GEN_CHECK_OFF(PCNetState, GCUpperPhys);
423 GEN_CHECK_OFF(PCNetState, pXmitQueueR3);
424 GEN_CHECK_OFF(PCNetState, pXmitQueueR0);
425 GEN_CHECK_OFF(PCNetState, pXmitQueueRC);
426 GEN_CHECK_OFF(PCNetState, pCanRxQueueR3);
427 GEN_CHECK_OFF(PCNetState, pCanRxQueueR0);
428 GEN_CHECK_OFF(PCNetState, pCanRxQueueRC);
429 GEN_CHECK_OFF(PCNetState, pTimerRestore);
430 GEN_CHECK_OFF(PCNetState, pDevInsR3);
431 GEN_CHECK_OFF(PCNetState, pDevInsR0);
432 GEN_CHECK_OFF(PCNetState, pDevInsRC);
433 GEN_CHECK_OFF(PCNetState, pDrvR3);
434 GEN_CHECK_OFF(PCNetState, pDrvBase);
435 GEN_CHECK_OFF(PCNetState, IBase);
436 GEN_CHECK_OFF(PCNetState, INetworkDown);
437 GEN_CHECK_OFF(PCNetState, INetworkConfig);
438 GEN_CHECK_OFF(PCNetState, MMIOBase);
439 GEN_CHECK_OFF(PCNetState, IOPortBase);
440 GEN_CHECK_OFF(PCNetState, fLinkUp);
441 GEN_CHECK_OFF(PCNetState, fLinkTempDown);
442 GEN_CHECK_OFF(PCNetState, cLinkDownReported);
443 GEN_CHECK_OFF(PCNetState, MacConfigured);
444 GEN_CHECK_OFF(PCNetState, Led);
445 GEN_CHECK_OFF(PCNetState, ILeds);
446 GEN_CHECK_OFF(PCNetState, pLedsConnector);
447 GEN_CHECK_OFF(PCNetState, CritSect);
448#ifdef PCNET_NO_POLLING
449 GEN_CHECK_OFF(PCNetState, TDRAPhysOld);
450 GEN_CHECK_OFF(PCNetState, cbTDRAOld);
451 GEN_CHECK_OFF(PCNetState, RDRAPhysOld);
452 GEN_CHECK_OFF(PCNetState, cbRDRAOld);
453 GEN_CHECK_OFF(PCNetState, pfnEMInterpretInstructionGC
454 GEN_CHECK_OFF(PCNetState, pfnEMInterpretInstructionR0
455#endif
456 GEN_CHECK_OFF(PCNetState, pSharedMMIOR3);
457 GEN_CHECK_OFF(PCNetState, pSharedMMIOR0);
458 GEN_CHECK_OFF(PCNetState, pSharedMMIORC);
459 GEN_CHECK_OFF(PCNetState, fPrivIfEnabled);
460 GEN_CHECK_OFF(PCNetState, fGCEnabled);
461 GEN_CHECK_OFF(PCNetState, fR0Enabled);
462 GEN_CHECK_OFF(PCNetState, fAm79C973);
463 GEN_CHECK_OFF(PCNetState, u32LinkSpeed);
464 GEN_CHECK_OFF(PCNetState, StatReceiveBytes);
465 GEN_CHECK_OFF(PCNetState, StatTransmitBytes);
466#ifdef VBOX_WITH_STATISTICS
467 GEN_CHECK_OFF(PCNetState, StatMMIOReadR3);
468 GEN_CHECK_OFF(PCNetState, StatMMIOReadRZ);
469 GEN_CHECK_OFF(PCNetState, StatMIIReads);
470# ifdef PCNET_NO_POLLING
471 GEN_CHECK_OFF(PCNetState, StatRCVRingWrite);
472 GEN_CHECK_OFF(PCNetState, StatRingWriteOutsideRangeR3);
473# endif
474#endif
475
476 /* PC/DevACPI.cpp */
477 GEN_CHECK_SIZE(ACPIState);
478 GEN_CHECK_OFF(ACPIState, dev);
479 GEN_CHECK_OFF(ACPIState, pm1a_en);
480 GEN_CHECK_OFF(ACPIState, pm1a_sts);
481 GEN_CHECK_OFF(ACPIState, pm1a_ctl);
482 GEN_CHECK_OFF(ACPIState, pm_timer_initial);
483 GEN_CHECK_OFF(ACPIState, tsR3);
484 GEN_CHECK_OFF(ACPIState, tsR0);
485 GEN_CHECK_OFF(ACPIState, tsRC);
486 GEN_CHECK_OFF(ACPIState, gpe0_en);
487 GEN_CHECK_OFF(ACPIState, gpe0_sts);
488 GEN_CHECK_OFF(ACPIState, uBatteryIndex);
489 GEN_CHECK_OFF(ACPIState, au8BatteryInfo);
490 GEN_CHECK_OFF(ACPIState, uSystemInfoIndex);
491 GEN_CHECK_OFF(ACPIState, u64RamSize);
492 GEN_CHECK_OFF(ACPIState, uSleepState);
493 GEN_CHECK_OFF(ACPIState, au8RSDPPage);
494 GEN_CHECK_OFF(ACPIState, u8IndexShift);
495 GEN_CHECK_OFF(ACPIState, u8UseIOApic);
496 GEN_CHECK_OFF(ACPIState, fUseFdc);
497 GEN_CHECK_OFF(ACPIState, fUseHpet);
498 GEN_CHECK_OFF(ACPIState, fUseSmc);
499 GEN_CHECK_OFF(ACPIState, CpuSetAttached);
500 GEN_CHECK_OFF(ACPIState, idCpuLockCheck);
501 GEN_CHECK_OFF(ACPIState, CpuSetLocked);
502 GEN_CHECK_OFF(ACPIState, u32CpuEventType);
503 GEN_CHECK_OFF(ACPIState, u32CpuEvent);
504 GEN_CHECK_OFF(ACPIState, fCpuHotPlug);
505 GEN_CHECK_OFF(ACPIState, IBase);
506 GEN_CHECK_OFF(ACPIState, IACPIPort);
507 GEN_CHECK_OFF(ACPIState, pDevIns);
508 GEN_CHECK_OFF(ACPIState, pDrvBase);
509 GEN_CHECK_OFF(ACPIState, pDrv);
510
511 /* PC/DevPIC.cpp */
512 GEN_CHECK_SIZE(PicState);
513 GEN_CHECK_OFF(PicState, last_irr);
514 GEN_CHECK_OFF(PicState, irr);
515 GEN_CHECK_OFF(PicState, imr);
516 GEN_CHECK_OFF(PicState, isr);
517 GEN_CHECK_OFF(PicState, priority_add);
518 GEN_CHECK_OFF(PicState, irq_base);
519 GEN_CHECK_OFF(PicState, read_reg_select);
520 GEN_CHECK_OFF(PicState, poll);
521 GEN_CHECK_OFF(PicState, special_mask);
522 GEN_CHECK_OFF(PicState, init_state);
523 GEN_CHECK_OFF(PicState, auto_eoi);
524 GEN_CHECK_OFF(PicState, rotate_on_auto_eoi);
525 GEN_CHECK_OFF(PicState, special_fully_nested_mode);
526 GEN_CHECK_OFF(PicState, init4);
527 GEN_CHECK_OFF(PicState, elcr);
528 GEN_CHECK_OFF(PicState, elcr_mask);
529 GEN_CHECK_OFF(PicState, pDevInsR3);
530 GEN_CHECK_OFF(PicState, pDevInsR0);
531 GEN_CHECK_OFF(PicState, pDevInsRC);
532
533 GEN_CHECK_SIZE(DEVPIC);
534 GEN_CHECK_OFF(DEVPIC, aPics);
535 GEN_CHECK_OFF(DEVPIC, aPics[1]);
536 GEN_CHECK_OFF(DEVPIC, pDevInsR3);
537 GEN_CHECK_OFF(DEVPIC, pDevInsR0);
538 GEN_CHECK_OFF(DEVPIC, pDevInsRC);
539 GEN_CHECK_OFF(DEVPIC, pPicHlpR3);
540 GEN_CHECK_OFF(DEVPIC, pPicHlpR0);
541 GEN_CHECK_OFF(DEVPIC, pPicHlpRC);
542#ifdef VBOX_WITH_STATISTICS
543 GEN_CHECK_OFF(DEVPIC, StatSetIrqGC);
544 GEN_CHECK_OFF(DEVPIC, StatClearedActiveSlaveIRQ);
545#endif
546
547 /* PC/DevPit-i8254.cpp */
548 GEN_CHECK_SIZE(PITChannelState);
549 GEN_CHECK_OFF(PITChannelState, pPitR3);
550 GEN_CHECK_OFF(PITChannelState, pTimerR3);
551 GEN_CHECK_OFF(PITChannelState, pPitR0);
552 GEN_CHECK_OFF(PITChannelState, pTimerR0);
553 GEN_CHECK_OFF(PITChannelState, pPitRC);
554 GEN_CHECK_OFF(PITChannelState, pTimerRC);
555 GEN_CHECK_OFF(PITChannelState, u64ReloadTS);
556 GEN_CHECK_OFF(PITChannelState, u64NextTS);
557 GEN_CHECK_OFF(PITChannelState, count_load_time);
558 GEN_CHECK_OFF(PITChannelState, next_transition_time);
559 GEN_CHECK_OFF(PITChannelState, irq);
560 GEN_CHECK_OFF(PITChannelState, cRelLogEntries);
561 GEN_CHECK_OFF(PITChannelState, count);
562 GEN_CHECK_OFF(PITChannelState, latched_count);
563 GEN_CHECK_OFF(PITChannelState, count_latched);
564 GEN_CHECK_OFF(PITChannelState, status_latched);
565 GEN_CHECK_OFF(PITChannelState, status);
566 GEN_CHECK_OFF(PITChannelState, read_state);
567 GEN_CHECK_OFF(PITChannelState, write_state);
568 GEN_CHECK_OFF(PITChannelState, write_latch);
569 GEN_CHECK_OFF(PITChannelState, rw_mode);
570 GEN_CHECK_OFF(PITChannelState, mode);
571 GEN_CHECK_OFF(PITChannelState, bcd);
572 GEN_CHECK_OFF(PITChannelState, gate);
573 GEN_CHECK_SIZE(PITState);
574 GEN_CHECK_OFF(PITState, channels);
575 GEN_CHECK_OFF(PITState, channels[1]);
576 GEN_CHECK_OFF(PITState, speaker_data_on);
577// GEN_CHECK_OFF(PITState, dummy_refresh_clock);
578 GEN_CHECK_OFF(PITState, IOPortBaseCfg);
579 GEN_CHECK_OFF(PITState, fSpeakerCfg);
580 GEN_CHECK_OFF(PITState, pDevIns);
581 GEN_CHECK_OFF(PITState, StatPITIrq);
582 GEN_CHECK_OFF(PITState, StatPITHandler);
583
584 /* PC/DevRTC.cpp */
585 GEN_CHECK_SIZE(RTCState);
586 GEN_CHECK_OFF(RTCState, cmos_data);
587 GEN_CHECK_OFF(RTCState, cmos_data[1]);
588 GEN_CHECK_OFF(RTCState, cmos_index);
589 GEN_CHECK_OFF(RTCState, current_tm);
590 GEN_CHECK_OFF(RTCState, current_tm.tm_sec);
591 GEN_CHECK_OFF(RTCState, current_tm.tm_min);
592 GEN_CHECK_OFF(RTCState, current_tm.tm_hour);
593 GEN_CHECK_OFF(RTCState, current_tm.tm_mday);
594 GEN_CHECK_OFF(RTCState, current_tm.tm_mon);
595 GEN_CHECK_OFF(RTCState, current_tm.tm_year);
596 GEN_CHECK_OFF(RTCState, current_tm.tm_wday);
597 GEN_CHECK_OFF(RTCState, current_tm.tm_yday);
598 GEN_CHECK_OFF(RTCState, irq);
599 GEN_CHECK_OFF(RTCState, fUTC);
600 GEN_CHECK_OFF(RTCState, IOPortBase);
601 GEN_CHECK_OFF(RTCState, pPeriodicTimerR0);
602 GEN_CHECK_OFF(RTCState, pPeriodicTimerR3);
603 GEN_CHECK_OFF(RTCState, pPeriodicTimerRC);
604 GEN_CHECK_OFF(RTCState, next_periodic_time);
605 GEN_CHECK_OFF(RTCState, next_second_time);
606 GEN_CHECK_OFF(RTCState, pSecondTimerR0);
607 GEN_CHECK_OFF(RTCState, pSecondTimerR3);
608 GEN_CHECK_OFF(RTCState, pSecondTimerRC);
609 GEN_CHECK_OFF(RTCState, pSecondTimer2R0);
610 GEN_CHECK_OFF(RTCState, pSecondTimer2R3);
611 GEN_CHECK_OFF(RTCState, pSecondTimer2RC);
612 GEN_CHECK_OFF(RTCState, pDevInsR0);
613 GEN_CHECK_OFF(RTCState, pDevInsR3);
614 GEN_CHECK_OFF(RTCState, pDevInsRC);
615 GEN_CHECK_OFF(RTCState, RtcReg);
616 GEN_CHECK_OFF(RTCState, pRtcHlpR3);
617 GEN_CHECK_OFF(RTCState, cRelLogEntries);
618 GEN_CHECK_OFF(RTCState, CurLogPeriod);
619 GEN_CHECK_OFF(RTCState, CurHintPeriod);
620
621 /* PC/apic.c */
622 GEN_CHECK_SIZE(APICState);
623 GEN_CHECK_OFF(APICState, apicbase);
624 GEN_CHECK_OFF(APICState, id);
625 GEN_CHECK_OFF(APICState, arb_id);
626 GEN_CHECK_OFF(APICState, tpr);
627 GEN_CHECK_OFF(APICState, spurious_vec);
628 GEN_CHECK_OFF(APICState, log_dest);
629 GEN_CHECK_OFF(APICState, dest_mode);
630 GEN_CHECK_OFF(APICState, isr);
631 GEN_CHECK_OFF(APICState, isr[1]);
632 GEN_CHECK_OFF(APICState, tmr);
633 GEN_CHECK_OFF(APICState, tmr[1]);
634 GEN_CHECK_OFF(APICState, irr);
635 GEN_CHECK_OFF(APICState, irr[1]);
636 GEN_CHECK_OFF(APICState, lvt);
637 GEN_CHECK_OFF(APICState, lvt[1]);
638 GEN_CHECK_OFF(APICState, lvt[APIC_LVT_NB - 1]);
639 GEN_CHECK_OFF(APICState, esr);
640 GEN_CHECK_OFF(APICState, icr);
641 GEN_CHECK_OFF(APICState, icr[1]);
642 GEN_CHECK_OFF(APICState, divide_conf);
643 GEN_CHECK_OFF(APICState, count_shift);
644 GEN_CHECK_OFF(APICState, initial_count);
645 GEN_CHECK_OFF(APICState, initial_count_load_time);
646 GEN_CHECK_OFF(APICState, next_time);
647 GEN_CHECK_OFF(APICState, pTimerR3);
648 GEN_CHECK_OFF(APICState, pTimerR0);
649 GEN_CHECK_OFF(APICState, pTimerRC);
650 GEN_CHECK_OFF(APICState, fTimerArmed);
651 GEN_CHECK_OFF(APICState, uHintedInitialCount);
652 GEN_CHECK_OFF(APICState, uHintedCountShift);
653 GEN_CHECK_OFF(APICState, pszDesc);
654#ifdef VBOX_WITH_STATISTICS
655 GEN_CHECK_OFF(APICState, StatTimerSetInitialCount);
656 GEN_CHECK_OFF(APICState, StatTimerSetLvtNoRelevantChange);
657#endif
658
659 GEN_CHECK_SIZE(APICDeviceInfo);
660 GEN_CHECK_OFF(APICDeviceInfo, pDevInsR3);
661 GEN_CHECK_OFF(APICDeviceInfo, pApicHlpR3);
662 GEN_CHECK_OFF(APICDeviceInfo, paLapicsR3);
663 GEN_CHECK_OFF(APICDeviceInfo, pCritSectR3);
664 GEN_CHECK_OFF(APICDeviceInfo, pDevInsR0);
665 GEN_CHECK_OFF(APICDeviceInfo, pApicHlpR0);
666 GEN_CHECK_OFF(APICDeviceInfo, paLapicsR0);
667 GEN_CHECK_OFF(APICDeviceInfo, pCritSectR0);
668 GEN_CHECK_OFF(APICDeviceInfo, pDevInsRC);
669 GEN_CHECK_OFF(APICDeviceInfo, pApicHlpRC);
670 GEN_CHECK_OFF(APICDeviceInfo, paLapicsRC);
671 GEN_CHECK_OFF(APICDeviceInfo, pCritSectRC);
672 GEN_CHECK_OFF(APICDeviceInfo, enmVersion);
673 GEN_CHECK_OFF(APICDeviceInfo, cTPRPatchAttempts);
674 GEN_CHECK_OFF(APICDeviceInfo, cCpus);
675#ifdef VBOX_WITH_STATISTICS
676 GEN_CHECK_OFF(APICDeviceInfo, StatMMIOReadGC);
677 GEN_CHECK_OFF(APICDeviceInfo, StatMMIOWriteHC);
678#endif
679
680 GEN_CHECK_SIZE(IOAPICState);
681 GEN_CHECK_OFF(IOAPICState, id);
682 GEN_CHECK_OFF(IOAPICState, ioregsel);
683 GEN_CHECK_OFF(IOAPICState, irr);
684 GEN_CHECK_OFF(IOAPICState, ioredtbl);
685 GEN_CHECK_OFF(IOAPICState, ioredtbl[1]);
686 GEN_CHECK_OFF(IOAPICState, ioredtbl[IOAPIC_NUM_PINS - 1]);
687 GEN_CHECK_OFF(IOAPICState, pDevInsR3);
688 GEN_CHECK_OFF(IOAPICState, pIoApicHlpR3);
689 GEN_CHECK_OFF(IOAPICState, pDevInsR0);
690 GEN_CHECK_OFF(IOAPICState, pIoApicHlpR0);
691 GEN_CHECK_OFF(IOAPICState, pDevInsRC);
692 GEN_CHECK_OFF(IOAPICState, pIoApicHlpRC);
693#ifdef VBOX_WITH_STATISTICS
694 GEN_CHECK_OFF(IOAPICState, StatMMIOReadGC);
695 GEN_CHECK_OFF(IOAPICState, StatSetIrqHC);
696#endif
697
698 /* Storage/DevATA.cpp */
699 GEN_CHECK_SIZE(BMDMAState);
700 GEN_CHECK_OFF(BMDMAState, u8Cmd);
701 GEN_CHECK_OFF(BMDMAState, u8Status);
702 GEN_CHECK_OFF(BMDMAState, pvAddr);
703 GEN_CHECK_SIZE(BMDMADesc);
704 GEN_CHECK_OFF(BMDMADesc, pBuffer);
705 GEN_CHECK_OFF(BMDMADesc, cbBuffer);
706 GEN_CHECK_SIZE(ATADevState);
707 GEN_CHECK_OFF(ATADevState, fLBA48);
708 GEN_CHECK_OFF(ATADevState, fATAPI);
709 GEN_CHECK_OFF(ATADevState, fIrqPending);
710 GEN_CHECK_OFF(ATADevState, cMultSectors);
711 GEN_CHECK_OFF(ATADevState, PCHSGeometry.cCylinders);
712 GEN_CHECK_OFF(ATADevState, PCHSGeometry.cHeads);
713 GEN_CHECK_OFF(ATADevState, PCHSGeometry.cSectors);
714 GEN_CHECK_OFF(ATADevState, cSectorsPerIRQ);
715 GEN_CHECK_OFF(ATADevState, cTotalSectors);
716 GEN_CHECK_OFF(ATADevState, uATARegFeature);
717 GEN_CHECK_OFF(ATADevState, uATARegFeatureHOB);
718 GEN_CHECK_OFF(ATADevState, uATARegError);
719 GEN_CHECK_OFF(ATADevState, uATARegNSector);
720 GEN_CHECK_OFF(ATADevState, uATARegNSectorHOB);
721 GEN_CHECK_OFF(ATADevState, uATARegSector);
722 GEN_CHECK_OFF(ATADevState, uATARegSectorHOB);
723 GEN_CHECK_OFF(ATADevState, uATARegLCyl);
724 GEN_CHECK_OFF(ATADevState, uATARegLCylHOB);
725 GEN_CHECK_OFF(ATADevState, uATARegHCyl);
726 GEN_CHECK_OFF(ATADevState, uATARegHCylHOB);
727 GEN_CHECK_OFF(ATADevState, uATARegSelect);
728 GEN_CHECK_OFF(ATADevState, uATARegStatus);
729 GEN_CHECK_OFF(ATADevState, uATARegCommand);
730 GEN_CHECK_OFF(ATADevState, uATARegDevCtl);
731 GEN_CHECK_OFF(ATADevState, uATATransferMode);
732 GEN_CHECK_OFF(ATADevState, uTxDir);
733 GEN_CHECK_OFF(ATADevState, iBeginTransfer);
734 GEN_CHECK_OFF(ATADevState, iSourceSink);
735 GEN_CHECK_OFF(ATADevState, fDMA);
736 GEN_CHECK_OFF(ATADevState, fATAPITransfer);
737 GEN_CHECK_OFF(ATADevState, cbTotalTransfer);
738 GEN_CHECK_OFF(ATADevState, cbElementaryTransfer);
739 GEN_CHECK_OFF(ATADevState, iIOBufferCur);
740 GEN_CHECK_OFF(ATADevState, iIOBufferEnd);
741 GEN_CHECK_OFF(ATADevState, iIOBufferPIODataStart);
742 GEN_CHECK_OFF(ATADevState, iIOBufferPIODataEnd);
743 GEN_CHECK_OFF(ATADevState, iATAPILBA);
744 GEN_CHECK_OFF(ATADevState, cbATAPISector);
745 GEN_CHECK_OFF(ATADevState, aATAPICmd);
746 GEN_CHECK_OFF(ATADevState, aATAPICmd[ATAPI_PACKET_SIZE - 1]);
747 GEN_CHECK_OFF(ATADevState, abATAPISense);
748 GEN_CHECK_OFF(ATADevState, abATAPISense[ATAPI_SENSE_SIZE - 1]);
749 GEN_CHECK_OFF(ATADevState, cNotifiedMediaChange);
750 GEN_CHECK_OFF(ATADevState, MediaEventStatus);
751 GEN_CHECK_OFF(ATADevState, MediaTrackType);
752 GEN_CHECK_OFF(ATADevState, Led);
753 GEN_CHECK_OFF(ATADevState, cbIOBuffer);
754 GEN_CHECK_OFF(ATADevState, pbIOBufferR3);
755 GEN_CHECK_OFF(ATADevState, pbIOBufferR0);
756 GEN_CHECK_OFF(ATADevState, pbIOBufferRC);
757 GEN_CHECK_OFF(ATADevState, StatATADMA);
758 GEN_CHECK_OFF(ATADevState, StatATAPIO);
759 GEN_CHECK_OFF(ATADevState, StatATAPIDMA);
760 GEN_CHECK_OFF(ATADevState, StatATAPIPIO);
761 GEN_CHECK_OFF(ATADevState, StatReads);
762 GEN_CHECK_OFF(ATADevState, StatBytesRead);
763 GEN_CHECK_OFF(ATADevState, StatWrites);
764 GEN_CHECK_OFF(ATADevState, StatBytesWritten);
765 GEN_CHECK_OFF(ATADevState, StatFlushes);
766 GEN_CHECK_OFF(ATADevState, fATAPIPassthrough);
767 GEN_CHECK_OFF(ATADevState, cErrors);
768 GEN_CHECK_OFF(ATADevState, pDrvBase);
769 GEN_CHECK_OFF(ATADevState, pDrvBlock);
770 GEN_CHECK_OFF(ATADevState, pDrvBlockBios);
771 GEN_CHECK_OFF(ATADevState, pDrvMount);
772 GEN_CHECK_OFF(ATADevState, IBase);
773 GEN_CHECK_OFF(ATADevState, IPort);
774 GEN_CHECK_OFF(ATADevState, IMountNotify);
775 GEN_CHECK_OFF(ATADevState, iLUN);
776 GEN_CHECK_OFF(ATADevState, pDevInsR3);
777 GEN_CHECK_OFF(ATADevState, pDevInsR0);
778 GEN_CHECK_OFF(ATADevState, pDevInsRC);
779 GEN_CHECK_OFF(ATADevState, pControllerR3);
780 GEN_CHECK_OFF(ATADevState, pControllerR0);
781 GEN_CHECK_OFF(ATADevState, pControllerRC);
782 GEN_CHECK_OFF(ATADevState, szSerialNumber);
783 GEN_CHECK_OFF(ATADevState, szSerialNumber[ATA_SERIAL_NUMBER_LENGTH]);
784 GEN_CHECK_OFF(ATADevState, szFirmwareRevision);
785 GEN_CHECK_OFF(ATADevState, szFirmwareRevision[ATA_FIRMWARE_REVISION_LENGTH]);
786 GEN_CHECK_OFF(ATADevState, szModelNumber);
787 GEN_CHECK_OFF(ATADevState, szModelNumber[ATA_MODEL_NUMBER_LENGTH]);
788 GEN_CHECK_OFF(ATADevState, szInquiryVendorId);
789 GEN_CHECK_OFF(ATADevState, szInquiryVendorId[ATAPI_INQUIRY_VENDOR_ID_LENGTH]);
790 GEN_CHECK_OFF(ATADevState, szInquiryProductId);
791 GEN_CHECK_OFF(ATADevState, szInquiryProductId[ATAPI_INQUIRY_PRODUCT_ID_LENGTH]);
792 GEN_CHECK_OFF(ATADevState, szInquiryRevision);
793 GEN_CHECK_OFF(ATADevState, szInquiryRevision[ATAPI_INQUIRY_REVISION_LENGTH]);
794 GEN_CHECK_SIZE(ATATransferRequest);
795 GEN_CHECK_OFF(ATATransferRequest, iIf);
796 GEN_CHECK_OFF(ATATransferRequest, iBeginTransfer);
797 GEN_CHECK_OFF(ATATransferRequest, iSourceSink);
798 GEN_CHECK_OFF(ATATransferRequest, cbTotalTransfer);
799 GEN_CHECK_OFF(ATATransferRequest, uTxDir);
800 GEN_CHECK_SIZE(ATAAbortRequest);
801 GEN_CHECK_OFF(ATAAbortRequest, iIf);
802 GEN_CHECK_OFF(ATAAbortRequest, fResetDrive);
803 GEN_CHECK_SIZE(ATARequest);
804 GEN_CHECK_OFF(ATARequest, ReqType);
805 GEN_CHECK_OFF(ATARequest, u);
806 GEN_CHECK_OFF(ATARequest, u.t);
807 GEN_CHECK_OFF(ATARequest, u.a);
808 GEN_CHECK_SIZE(ATACONTROLLER);
809 GEN_CHECK_OFF(ATACONTROLLER, IOPortBase1);
810 GEN_CHECK_OFF(ATACONTROLLER, IOPortBase2);
811 GEN_CHECK_OFF(ATACONTROLLER, irq);
812 GEN_CHECK_OFF(ATACONTROLLER, lock);
813 GEN_CHECK_OFF(ATACONTROLLER, iSelectedIf);
814 GEN_CHECK_OFF(ATACONTROLLER, iAIOIf);
815 GEN_CHECK_OFF(ATACONTROLLER, uAsyncIOState);
816 GEN_CHECK_OFF(ATACONTROLLER, fChainedTransfer);
817 GEN_CHECK_OFF(ATACONTROLLER, fReset);
818 GEN_CHECK_OFF(ATACONTROLLER, fRedo);
819 GEN_CHECK_OFF(ATACONTROLLER, fRedoIdle);
820 GEN_CHECK_OFF(ATACONTROLLER, fRedoDMALastDesc);
821 GEN_CHECK_OFF(ATACONTROLLER, BmDma);
822 GEN_CHECK_OFF(ATACONTROLLER, pFirstDMADesc);
823 GEN_CHECK_OFF(ATACONTROLLER, pLastDMADesc);
824 GEN_CHECK_OFF(ATACONTROLLER, pRedoDMABuffer);
825 GEN_CHECK_OFF(ATACONTROLLER, cbRedoDMABuffer);
826 GEN_CHECK_OFF(ATACONTROLLER, aIfs);
827 GEN_CHECK_OFF(ATACONTROLLER, aIfs[1]);
828 GEN_CHECK_OFF(ATACONTROLLER, pDevInsR3);
829 GEN_CHECK_OFF(ATACONTROLLER, pDevInsR0);
830 GEN_CHECK_OFF(ATACONTROLLER, pDevInsRC);
831 GEN_CHECK_OFF(ATACONTROLLER, fShutdown);
832 GEN_CHECK_OFF(ATACONTROLLER, AsyncIOThread);
833 GEN_CHECK_OFF(ATACONTROLLER, AsyncIOSem);
834 GEN_CHECK_OFF(ATACONTROLLER, aAsyncIORequests[4]);
835 GEN_CHECK_OFF(ATACONTROLLER, AsyncIOReqHead);
836 GEN_CHECK_OFF(ATACONTROLLER, AsyncIOReqTail);
837 GEN_CHECK_OFF(ATACONTROLLER, AsyncIORequestMutex);
838 GEN_CHECK_OFF(ATACONTROLLER, SuspendIOSem);
839 GEN_CHECK_OFF(ATACONTROLLER, fSignalIdle);
840 GEN_CHECK_OFF(ATACONTROLLER, DelayIRQMillies);
841 GEN_CHECK_OFF(ATACONTROLLER, u64ResetTime);
842 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncOps);
843 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncMinWait);
844 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncMaxWait);
845 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncTimeUS);
846 GEN_CHECK_OFF(ATACONTROLLER, StatAsyncTime);
847 GEN_CHECK_OFF(ATACONTROLLER, StatLockWait);
848 GEN_CHECK_SIZE(PCIATAState);
849 GEN_CHECK_OFF(PCIATAState, dev);
850 GEN_CHECK_OFF(PCIATAState, aCts);
851 GEN_CHECK_OFF(PCIATAState, aCts[1]);
852 GEN_CHECK_OFF(PCIATAState, pDevIns);
853 GEN_CHECK_OFF(PCIATAState, IBase);
854 GEN_CHECK_OFF(PCIATAState, ILeds);
855 GEN_CHECK_OFF(PCIATAState, pLedsConnector);
856 GEN_CHECK_OFF(PCIATAState, fGCEnabled);
857 GEN_CHECK_OFF(PCIATAState, fR0Enabled);
858
859#ifdef VBOX_WITH_USB
860 /* USB/DevOHCI.cpp */
861 GEN_CHECK_SIZE(OHCIHUBPORT);
862 GEN_CHECK_OFF(OHCIHUBPORT, fReg);
863 GEN_CHECK_OFF(OHCIHUBPORT, pDev);
864
865 GEN_CHECK_SIZE(OHCIROOTHUB);
866 GEN_CHECK_OFF(OHCIROOTHUB, pIBase);
867 GEN_CHECK_OFF(OHCIROOTHUB, pIRhConn);
868 GEN_CHECK_OFF(OHCIROOTHUB, pIDev);
869 GEN_CHECK_OFF(OHCIROOTHUB, IBase);
870 GEN_CHECK_OFF(OHCIROOTHUB, IRhPort);
871 GEN_CHECK_OFF(OHCIROOTHUB, status);
872 GEN_CHECK_OFF(OHCIROOTHUB, desc_a);
873 GEN_CHECK_OFF(OHCIROOTHUB, desc_b);
874 GEN_CHECK_OFF(OHCIROOTHUB, aPorts);
875 GEN_CHECK_OFF(OHCIROOTHUB, aPorts[1]);
876 GEN_CHECK_OFF(OHCIROOTHUB, aPorts[OHCI_NDP - 1]);
877 GEN_CHECK_OFF(OHCIROOTHUB, pOhci);
878
879 GEN_CHECK_SIZE(OHCI);
880 GEN_CHECK_OFF(OHCI, PciDev);
881 GEN_CHECK_OFF(OHCI, MMIOBase);
882 GEN_CHECK_OFF(OHCI, pEndOfFrameTimerR3);
883 GEN_CHECK_OFF(OHCI, pEndOfFrameTimerR0);
884 GEN_CHECK_OFF(OHCI, pEndOfFrameTimerRC);
885 GEN_CHECK_OFF(OHCI, pDevInsR3);
886 GEN_CHECK_OFF(OHCI, pDevInsR0);
887 GEN_CHECK_OFF(OHCI, pDevInsRC);
888 GEN_CHECK_OFF(OHCI, SofTime);
889 //GEN_CHECK_OFF(OHCI, dqic:3);
890 //GEN_CHECK_OFF(OHCI, fno:1);
891 GEN_CHECK_OFF(OHCI, RootHub);
892 GEN_CHECK_OFF(OHCI, ctl);
893 GEN_CHECK_OFF(OHCI, status);
894 GEN_CHECK_OFF(OHCI, intr_status);
895 GEN_CHECK_OFF(OHCI, intr);
896 GEN_CHECK_OFF(OHCI, hcca);
897 GEN_CHECK_OFF(OHCI, per_cur);
898 GEN_CHECK_OFF(OHCI, ctrl_cur);
899 GEN_CHECK_OFF(OHCI, ctrl_head);
900 GEN_CHECK_OFF(OHCI, bulk_cur);
901 GEN_CHECK_OFF(OHCI, bulk_head);
902 GEN_CHECK_OFF(OHCI, done);
903 //GEN_CHECK_OFF(OHCI, fsmps:15);
904 //GEN_CHECK_OFF(OHCI, fit:1);
905 //GEN_CHECK_OFF(OHCI, fi:14);
906 //GEN_CHECK_OFF(OHCI, frt:1);
907 GEN_CHECK_OFF(OHCI, HcFmNumber);
908 GEN_CHECK_OFF(OHCI, pstart);
909 GEN_CHECK_OFF(OHCI, cTicksPerFrame);
910 GEN_CHECK_OFF(OHCI, cTicksPerUsbTick);
911 GEN_CHECK_OFF(OHCI, cInFlight);
912 GEN_CHECK_OFF(OHCI, aInFlight);
913 GEN_CHECK_OFF(OHCI, aInFlight[0].GCPhysTD);
914 GEN_CHECK_OFF(OHCI, aInFlight[0].pUrb);
915 GEN_CHECK_OFF(OHCI, aInFlight[1]);
916 GEN_CHECK_OFF(OHCI, cInDoneQueue);
917 GEN_CHECK_OFF(OHCI, aInDoneQueue);
918 GEN_CHECK_OFF(OHCI, aInDoneQueue[0].GCPhysTD);
919 GEN_CHECK_OFF(OHCI, aInDoneQueue[1]);
920 GEN_CHECK_OFF(OHCI, u32FmDoneQueueTail);
921 GEN_CHECK_OFF(OHCI, pLoad);
922# ifdef VBOX_WITH_STATISTICS
923 GEN_CHECK_OFF(OHCI, StatCanceledIsocUrbs);
924 GEN_CHECK_OFF(OHCI, StatCanceledGenUrbs);
925 GEN_CHECK_OFF(OHCI, StatDroppedUrbs);
926 GEN_CHECK_OFF(OHCI, StatTimer);
927# endif
928# ifdef VBOX_WITH_EHCI
929 /* USB/DevEHCI.cpp */
930 GEN_CHECK_SIZE(EHCIHUBPORT);
931 GEN_CHECK_OFF(EHCIHUBPORT, fReg);
932 GEN_CHECK_OFF(EHCIHUBPORT, pDev);
933
934 GEN_CHECK_SIZE(EHCIROOTHUB);
935 GEN_CHECK_OFF(EHCIROOTHUB, pIBase);
936 GEN_CHECK_OFF(EHCIROOTHUB, pIRhConn);
937 GEN_CHECK_OFF(EHCIROOTHUB, pIDev);
938 GEN_CHECK_OFF(EHCIROOTHUB, IBase);
939 GEN_CHECK_OFF(EHCIROOTHUB, IRhPort);
940 GEN_CHECK_OFF(EHCIROOTHUB, status);
941 GEN_CHECK_OFF(EHCIROOTHUB, desc_a);
942 GEN_CHECK_OFF(EHCIROOTHUB, desc_b);
943 GEN_CHECK_OFF(EHCIROOTHUB, aPorts);
944 GEN_CHECK_OFF(EHCIROOTHUB, aPorts[1]);
945 GEN_CHECK_OFF(EHCIROOTHUB, aPorts[EHCI_NDP - 1]);
946 GEN_CHECK_OFF(EHCIROOTHUB, pEhci);
947
948 GEN_CHECK_SIZE(EHCI);
949 GEN_CHECK_OFF(EHCI, PciDev);
950 GEN_CHECK_OFF(EHCI, MMIOBase);
951 GEN_CHECK_OFF(EHCI, pEndOfFrameTimerR3);
952 GEN_CHECK_OFF(EHCI, pEndOfFrameTimerR0);
953 GEN_CHECK_OFF(EHCI, pEndOfFrameTimerRC);
954 GEN_CHECK_OFF(EHCI, pDevInsR3);
955 GEN_CHECK_OFF(EHCI, pDevInsR0);
956 GEN_CHECK_OFF(EHCI, pDevInsRC);
957 GEN_CHECK_OFF(EHCI, SofTime);
958 GEN_CHECK_OFF(EHCI, RootHub);
959 GEN_CHECK_OFF(EHCI, intr_status);
960 GEN_CHECK_OFF(EHCI, intr);
961 GEN_CHECK_OFF(EHCI, HcFmNumber);
962 GEN_CHECK_OFF(EHCI, cTicksPerFrame);
963 GEN_CHECK_OFF(EHCI, cTicksPerUsbTick);
964 GEN_CHECK_OFF(EHCI, cInFlight);
965 GEN_CHECK_OFF(EHCI, aInFlight);
966 GEN_CHECK_OFF(EHCI, aInFlight[0].GCPhysTD);
967 GEN_CHECK_OFF(EHCI, aInFlight[0].pUrb);
968 GEN_CHECK_OFF(EHCI, aInFlight[1]);
969 GEN_CHECK_OFF(EHCI, pLoad);
970 GEN_CHECK_OFF(EHCI, fAsyncTraversalTimerActive);
971# ifdef VBOX_WITH_STATISTICS
972 GEN_CHECK_OFF(EHCI, StatCanceledIsocUrbs);
973 GEN_CHECK_OFF(EHCI, StatCanceledGenUrbs);
974 GEN_CHECK_OFF(EHCI, StatDroppedUrbs);
975 GEN_CHECK_OFF(EHCI, StatTimer);
976# endif
977# endif /* VBOX_WITH_EHCI */
978#endif /* VBOX_WITH_USB */
979
980 /* VMMDev/VBoxDev.cpp */
981
982 /* Parallel/DevParallel.cpp */
983 GEN_CHECK_SIZE(ParallelState);
984 GEN_CHECK_OFF(ParallelState, pDevInsR3);
985 GEN_CHECK_OFF(ParallelState, pDevInsR0);
986 GEN_CHECK_OFF(ParallelState, pDevInsRC);
987 GEN_CHECK_OFF(ParallelState, IBase);
988 GEN_CHECK_OFF(ParallelState, IHostParallelPort);
989 GEN_CHECK_OFF(ParallelState, pDrvHostParallelConnector);
990 GEN_CHECK_OFF(ParallelState, ReceiveSem);
991 GEN_CHECK_OFF(ParallelState, reg_data);
992 GEN_CHECK_OFF(ParallelState, reg_status);
993 GEN_CHECK_OFF(ParallelState, reg_control);
994 GEN_CHECK_OFF(ParallelState, reg_epp_addr);
995 GEN_CHECK_OFF(ParallelState, reg_epp_data);
996 GEN_CHECK_OFF(ParallelState, reg_ecp_ecr);
997 GEN_CHECK_OFF(ParallelState, reg_ecp_base_plus_400h);
998 GEN_CHECK_OFF(ParallelState, reg_ecp_config_b);
999 GEN_CHECK_OFF(ParallelState, ecp_fifo);
1000 GEN_CHECK_OFF(ParallelState, ecp_fifo[1]);
1001 GEN_CHECK_OFF(ParallelState, act_fifo_pos_write);
1002 GEN_CHECK_OFF(ParallelState, act_fifo_pos_read);
1003 GEN_CHECK_OFF(ParallelState, irq);
1004 GEN_CHECK_OFF(ParallelState, epp_timeout);
1005 GEN_CHECK_OFF(ParallelState, fGCEnabled);
1006 GEN_CHECK_OFF(ParallelState, fR0Enabled);
1007 GEN_CHECK_OFF(ParallelState, base);
1008
1009 /* Serial/DevSerial.cpp */
1010 GEN_CHECK_SIZE(SerialState);
1011 GEN_CHECK_OFF(SerialState, CritSect);
1012 GEN_CHECK_OFF(SerialState, pDevInsR3);
1013 GEN_CHECK_OFF(SerialState, pDevInsR0);
1014 GEN_CHECK_OFF(SerialState, pDevInsRC);
1015 GEN_CHECK_OFF(SerialState, IBase);
1016 GEN_CHECK_OFF(SerialState, ICharPort);
1017 GEN_CHECK_OFF(SerialState, pDrvBase);
1018 GEN_CHECK_OFF(SerialState, pDrvChar);
1019 GEN_CHECK_OFF(SerialState, ReceiveSem);
1020 GEN_CHECK_OFF(SerialState, base);
1021 GEN_CHECK_OFF(SerialState, divider);
1022 GEN_CHECK_OFF(SerialState, recv_fifo);
1023 GEN_CHECK_OFF(SerialState, xmit_fifo);
1024 GEN_CHECK_OFF(SerialState, rbr);
1025 GEN_CHECK_OFF(SerialState, thr);
1026 GEN_CHECK_OFF(SerialState, tsr);
1027 GEN_CHECK_OFF(SerialState, ier);
1028 GEN_CHECK_OFF(SerialState, iir);
1029 GEN_CHECK_OFF(SerialState, lcr);
1030 GEN_CHECK_OFF(SerialState, mcr);
1031 GEN_CHECK_OFF(SerialState, lsr);
1032 GEN_CHECK_OFF(SerialState, msr);
1033 GEN_CHECK_OFF(SerialState, scr);
1034 GEN_CHECK_OFF(SerialState, fcr);
1035 GEN_CHECK_OFF(SerialState, fcr_vmstate);
1036 GEN_CHECK_OFF(SerialState, thr_ipending);
1037 GEN_CHECK_OFF(SerialState, timeout_ipending);
1038 GEN_CHECK_OFF(SerialState, irq);
1039 GEN_CHECK_OFF(SerialState, last_break_enable);
1040 GEN_CHECK_OFF(SerialState, tsr_retry);
1041 GEN_CHECK_OFF(SerialState, msr_changed);
1042 GEN_CHECK_OFF(SerialState, fGCEnabled);
1043 GEN_CHECK_OFF(SerialState, fR0Enabled);
1044 GEN_CHECK_OFF(SerialState, fYieldOnLSRRead);
1045 GEN_CHECK_OFF(SerialState, char_transmit_time);
1046
1047#ifdef VBOX_WITH_AHCI
1048 /* Storage/ATAController.h */
1049 GEN_CHECK_SIZE(AHCIATADevState);
1050 GEN_CHECK_OFF(AHCIATADevState, fLBA48);
1051 GEN_CHECK_OFF(AHCIATADevState, fATAPI);
1052 GEN_CHECK_OFF(AHCIATADevState, fIrqPending);
1053 GEN_CHECK_OFF(AHCIATADevState, cMultSectors);
1054 GEN_CHECK_OFF(AHCIATADevState, PCHSGeometry.cCylinders);
1055 GEN_CHECK_OFF(AHCIATADevState, PCHSGeometry.cHeads);
1056 GEN_CHECK_OFF(AHCIATADevState, PCHSGeometry.cSectors);
1057 GEN_CHECK_OFF(AHCIATADevState, cSectorsPerIRQ);
1058 GEN_CHECK_OFF(AHCIATADevState, cTotalSectors);
1059 GEN_CHECK_OFF(AHCIATADevState, uATARegFeature);
1060 GEN_CHECK_OFF(AHCIATADevState, uATARegFeatureHOB);
1061 GEN_CHECK_OFF(AHCIATADevState, uATARegError);
1062 GEN_CHECK_OFF(AHCIATADevState, uATARegNSector);
1063 GEN_CHECK_OFF(AHCIATADevState, uATARegNSectorHOB);
1064 GEN_CHECK_OFF(AHCIATADevState, uATARegSector);
1065 GEN_CHECK_OFF(AHCIATADevState, uATARegSectorHOB);
1066 GEN_CHECK_OFF(AHCIATADevState, uATARegLCyl);
1067 GEN_CHECK_OFF(AHCIATADevState, uATARegLCylHOB);
1068 GEN_CHECK_OFF(AHCIATADevState, uATARegHCyl);
1069 GEN_CHECK_OFF(AHCIATADevState, uATARegHCylHOB);
1070 GEN_CHECK_OFF(AHCIATADevState, uATARegSelect);
1071 GEN_CHECK_OFF(AHCIATADevState, uATARegStatus);
1072 GEN_CHECK_OFF(AHCIATADevState, uATARegCommand);
1073 GEN_CHECK_OFF(AHCIATADevState, uATARegDevCtl);
1074 GEN_CHECK_OFF(AHCIATADevState, uATATransferMode);
1075 GEN_CHECK_OFF(AHCIATADevState, uTxDir);
1076 GEN_CHECK_OFF(AHCIATADevState, iBeginTransfer);
1077 GEN_CHECK_OFF(AHCIATADevState, iSourceSink);
1078 GEN_CHECK_OFF(AHCIATADevState, fDMA);
1079 GEN_CHECK_OFF(AHCIATADevState, fATAPITransfer);
1080 GEN_CHECK_OFF(AHCIATADevState, cbTotalTransfer);
1081 GEN_CHECK_OFF(AHCIATADevState, cbElementaryTransfer);
1082 GEN_CHECK_OFF(AHCIATADevState, iIOBufferCur);
1083 GEN_CHECK_OFF(AHCIATADevState, iIOBufferEnd);
1084 GEN_CHECK_OFF(AHCIATADevState, iIOBufferPIODataStart);
1085 GEN_CHECK_OFF(AHCIATADevState, iIOBufferPIODataEnd);
1086 GEN_CHECK_OFF(AHCIATADevState, iATAPILBA);
1087 GEN_CHECK_OFF(AHCIATADevState, cbATAPISector);
1088 GEN_CHECK_OFF(AHCIATADevState, aATAPICmd);
1089 GEN_CHECK_OFF(AHCIATADevState, aATAPICmd[ATAPI_PACKET_SIZE - 1]);
1090 GEN_CHECK_OFF(AHCIATADevState, abATAPISense);
1091 GEN_CHECK_OFF(AHCIATADevState, abATAPISense[ATAPI_SENSE_SIZE - 1]);
1092 GEN_CHECK_OFF(AHCIATADevState, cNotifiedMediaChange);
1093 GEN_CHECK_OFF(AHCIATADevState, MediaEventStatus);
1094 GEN_CHECK_OFF(AHCIATADevState, pLed);
1095 GEN_CHECK_OFF(AHCIATADevState, cbIOBuffer);
1096 GEN_CHECK_OFF(AHCIATADevState, pbIOBufferR3);
1097 GEN_CHECK_OFF(AHCIATADevState, pbIOBufferR0);
1098 GEN_CHECK_OFF(AHCIATADevState, pbIOBufferRC);
1099 GEN_CHECK_OFF(AHCIATADevState, StatATADMA);
1100 GEN_CHECK_OFF(AHCIATADevState, StatATAPIO);
1101 GEN_CHECK_OFF(AHCIATADevState, StatATAPIDMA);
1102 GEN_CHECK_OFF(AHCIATADevState, StatATAPIPIO);
1103 GEN_CHECK_OFF(AHCIATADevState, StatReads);
1104 GEN_CHECK_OFF(AHCIATADevState, pStatBytesRead);
1105 GEN_CHECK_OFF(AHCIATADevState, StatWrites);
1106 GEN_CHECK_OFF(AHCIATADevState, pStatBytesWritten);
1107 GEN_CHECK_OFF(AHCIATADevState, StatFlushes);
1108 GEN_CHECK_OFF(AHCIATADevState, fATAPIPassthrough);
1109 GEN_CHECK_OFF(AHCIATADevState, cErrors);
1110 GEN_CHECK_OFF(AHCIATADevState, pDrvBase);
1111 GEN_CHECK_OFF(AHCIATADevState, pDrvBlock);
1112 GEN_CHECK_OFF(AHCIATADevState, pDrvBlockBios);
1113 GEN_CHECK_OFF(AHCIATADevState, pDrvMount);
1114 GEN_CHECK_OFF(AHCIATADevState, IBase);
1115 GEN_CHECK_OFF(AHCIATADevState, IPort);
1116 GEN_CHECK_OFF(AHCIATADevState, IMountNotify);
1117 GEN_CHECK_OFF(AHCIATADevState, iLUN);
1118 GEN_CHECK_OFF(AHCIATADevState, pDevInsR3);
1119 GEN_CHECK_OFF(AHCIATADevState, pDevInsR0);
1120 GEN_CHECK_OFF(AHCIATADevState, pDevInsRC);
1121 GEN_CHECK_OFF(AHCIATADevState, pControllerR3);
1122 GEN_CHECK_OFF(AHCIATADevState, pControllerR0);
1123 GEN_CHECK_OFF(AHCIATADevState, pControllerRC);
1124 GEN_CHECK_SIZE(AHCIATATransferRequest);
1125 GEN_CHECK_OFF(AHCIATATransferRequest, iIf);
1126 GEN_CHECK_OFF(AHCIATATransferRequest, iBeginTransfer);
1127 GEN_CHECK_OFF(AHCIATATransferRequest, iSourceSink);
1128 GEN_CHECK_OFF(AHCIATATransferRequest, cbTotalTransfer);
1129 GEN_CHECK_OFF(AHCIATATransferRequest, uTxDir);
1130 GEN_CHECK_SIZE(AHCIATAAbortRequest);
1131 GEN_CHECK_OFF(AHCIATAAbortRequest, iIf);
1132 GEN_CHECK_OFF(AHCIATAAbortRequest, fResetDrive);
1133 GEN_CHECK_SIZE(AHCIATARequest);
1134 GEN_CHECK_OFF(AHCIATARequest, ReqType);
1135 GEN_CHECK_OFF(AHCIATARequest, u);
1136 GEN_CHECK_OFF(AHCIATARequest, u.t);
1137 GEN_CHECK_OFF(AHCIATARequest, u.a);
1138 GEN_CHECK_SIZE(AHCIATACONTROLLER);
1139 GEN_CHECK_OFF(AHCIATACONTROLLER, IOPortBase1);
1140 GEN_CHECK_OFF(AHCIATACONTROLLER, IOPortBase2);
1141 GEN_CHECK_OFF(AHCIATACONTROLLER, irq);
1142 GEN_CHECK_OFF(AHCIATACONTROLLER, lock);
1143 GEN_CHECK_OFF(AHCIATACONTROLLER, iSelectedIf);
1144 GEN_CHECK_OFF(AHCIATACONTROLLER, iAIOIf);
1145 GEN_CHECK_OFF(AHCIATACONTROLLER, uAsyncIOState);
1146 GEN_CHECK_OFF(AHCIATACONTROLLER, fChainedTransfer);
1147 GEN_CHECK_OFF(AHCIATACONTROLLER, fReset);
1148 GEN_CHECK_OFF(AHCIATACONTROLLER, fRedo);
1149 GEN_CHECK_OFF(AHCIATACONTROLLER, fRedoIdle);
1150 GEN_CHECK_OFF(AHCIATACONTROLLER, fRedoDMALastDesc);
1151 GEN_CHECK_OFF(AHCIATACONTROLLER, BmDma);
1152 GEN_CHECK_OFF(AHCIATACONTROLLER, pFirstDMADesc);
1153 GEN_CHECK_OFF(AHCIATACONTROLLER, pLastDMADesc);
1154 GEN_CHECK_OFF(AHCIATACONTROLLER, pRedoDMABuffer);
1155 GEN_CHECK_OFF(AHCIATACONTROLLER, cbRedoDMABuffer);
1156 GEN_CHECK_OFF(AHCIATACONTROLLER, aIfs);
1157 GEN_CHECK_OFF(AHCIATACONTROLLER, aIfs[1]);
1158 GEN_CHECK_OFF(AHCIATACONTROLLER, pDevInsR3);
1159 GEN_CHECK_OFF(AHCIATACONTROLLER, pDevInsR0);
1160 GEN_CHECK_OFF(AHCIATACONTROLLER, pDevInsRC);
1161 GEN_CHECK_OFF(AHCIATACONTROLLER, fShutdown);
1162 GEN_CHECK_OFF(AHCIATACONTROLLER, AsyncIOThread);
1163 GEN_CHECK_OFF(AHCIATACONTROLLER, AsyncIOSem);
1164 GEN_CHECK_OFF(AHCIATACONTROLLER, aAsyncIORequests[4]);
1165 GEN_CHECK_OFF(AHCIATACONTROLLER, AsyncIOReqHead);
1166 GEN_CHECK_OFF(AHCIATACONTROLLER, AsyncIOReqTail);
1167 GEN_CHECK_OFF(AHCIATACONTROLLER, AsyncIORequestMutex);
1168 GEN_CHECK_OFF(AHCIATACONTROLLER, SuspendIOSem);
1169 GEN_CHECK_OFF(AHCIATACONTROLLER, DelayIRQMillies);
1170 GEN_CHECK_OFF(AHCIATACONTROLLER, fSignalIdle);
1171 GEN_CHECK_OFF(AHCIATACONTROLLER, StatAsyncOps);
1172 GEN_CHECK_OFF(AHCIATACONTROLLER, StatAsyncMinWait);
1173 GEN_CHECK_OFF(AHCIATACONTROLLER, StatAsyncMaxWait);
1174 GEN_CHECK_OFF(AHCIATACONTROLLER, StatAsyncTimeUS);
1175 GEN_CHECK_OFF(AHCIATACONTROLLER, StatAsyncTime);
1176 GEN_CHECK_OFF(AHCIATACONTROLLER, StatLockWait);
1177
1178 /* Storage/DevAHCI.cpp */
1179
1180 GEN_CHECK_SIZE(AHCIPort);
1181 GEN_CHECK_OFF(AHCIPort, pDevInsR3);
1182 GEN_CHECK_OFF(AHCIPort, pDevInsR0);
1183 GEN_CHECK_OFF(AHCIPort, pDevInsRC);
1184 GEN_CHECK_OFF(AHCIPort, pAhciR3);
1185 GEN_CHECK_OFF(AHCIPort, pAhciR0);
1186 GEN_CHECK_OFF(AHCIPort, pAhciRC);
1187 GEN_CHECK_OFF(AHCIPort, regCLB);
1188 GEN_CHECK_OFF(AHCIPort, regCLBU);
1189 GEN_CHECK_OFF(AHCIPort, regFB);
1190 GEN_CHECK_OFF(AHCIPort, regFBU);
1191 GEN_CHECK_OFF(AHCIPort, regIS);
1192 GEN_CHECK_OFF(AHCIPort, regIE);
1193 GEN_CHECK_OFF(AHCIPort, regCMD);
1194 GEN_CHECK_OFF(AHCIPort, regTFD);
1195 GEN_CHECK_OFF(AHCIPort, regSIG);
1196 GEN_CHECK_OFF(AHCIPort, regSSTS);
1197 GEN_CHECK_OFF(AHCIPort, regSCTL);
1198 GEN_CHECK_OFF(AHCIPort, regSERR);
1199 GEN_CHECK_OFF(AHCIPort, regSACT);
1200 GEN_CHECK_OFF(AHCIPort, regCI);
1201 GEN_CHECK_OFF(AHCIPort, GCPhysAddrClb);
1202 GEN_CHECK_OFF(AHCIPort, GCPhysAddrFb);
1203 GEN_CHECK_OFF(AHCIPort, cTasksActive);
1204 GEN_CHECK_OFF(AHCIPort, fPoweredOn);
1205 GEN_CHECK_OFF(AHCIPort, fSpunUp);
1206 GEN_CHECK_OFF(AHCIPort, fFirstD2HFisSend);
1207 GEN_CHECK_OFF(AHCIPort, fATAPI);
1208 GEN_CHECK_OFF(AHCIPort, fATAPIPassthrough);
1209 GEN_CHECK_OFF(AHCIPort, fPortReset);
1210 GEN_CHECK_OFF(AHCIPort, fAsyncInterface);
1211 GEN_CHECK_OFF(AHCIPort, fResetDevice);
1212 GEN_CHECK_OFF(AHCIPort, fAsyncIOThreadIdle);
1213 GEN_CHECK_OFF(AHCIPort, fRedo);
1214 GEN_CHECK_OFF(AHCIPort, cTotalSectors);
1215 GEN_CHECK_OFF(AHCIPort, cMultSectors);
1216 GEN_CHECK_OFF(AHCIPort, uATATransferMode);
1217 GEN_CHECK_OFF(AHCIPort, abATAPISense);
1218 GEN_CHECK_OFF(AHCIPort, cNotifiedMediaChange);
1219 GEN_CHECK_OFF(AHCIPort, MediaEventStatus);
1220 GEN_CHECK_OFF(AHCIPort, MediaTrackType);
1221 GEN_CHECK_OFF(AHCIPort, iLUN);
1222 GEN_CHECK_OFF(AHCIPort, u32TasksFinished);
1223 GEN_CHECK_OFF(AHCIPort, u32QueuedTasksFinished);
1224 GEN_CHECK_OFF(AHCIPort, u32TasksNew);
1225 GEN_CHECK_OFF(AHCIPort, u32CurrentCommandSlot);
1226 GEN_CHECK_OFF(AHCIPort, pDrvBase);
1227 GEN_CHECK_OFF(AHCIPort, pDrvBlock);
1228 GEN_CHECK_OFF(AHCIPort, pDrvBlockAsync);
1229 GEN_CHECK_OFF(AHCIPort, pDrvBlockBios);
1230 GEN_CHECK_OFF(AHCIPort, pDrvMount);
1231 GEN_CHECK_OFF(AHCIPort, IBase);
1232 GEN_CHECK_OFF(AHCIPort, IPort);
1233 GEN_CHECK_OFF(AHCIPort, IPortAsync);
1234 GEN_CHECK_OFF(AHCIPort, IMountNotify);
1235 GEN_CHECK_OFF(AHCIPort, PCHSGeometry);
1236 GEN_CHECK_OFF(AHCIPort, Led);
1237 GEN_CHECK_OFF(AHCIPort, pAsyncIOThread);
1238 GEN_CHECK_OFF(AHCIPort, AsyncIORequestSem);
1239
1240 GEN_CHECK_OFF(AHCIPort, aCachedTasks);
1241 GEN_CHECK_OFF(AHCIPort, pTaskErr);
1242 GEN_CHECK_OFF(AHCIPort, StatDMA);
1243 GEN_CHECK_OFF(AHCIPort, StatBytesWritten);
1244 GEN_CHECK_OFF(AHCIPort, StatBytesRead);
1245 GEN_CHECK_OFF(AHCIPort, StatIORequestsPerSecond);
1246#ifdef VBOX_WITH_STATISTICS
1247 GEN_CHECK_OFF(AHCIPort, StatProfileProcessTime);
1248 GEN_CHECK_OFF(AHCIPort, StatProfileMapIntoR3);
1249 GEN_CHECK_OFF(AHCIPort, StatProfileReadWrite);
1250 GEN_CHECK_OFF(AHCIPort, StatProfileDestroyScatterGatherList);
1251#endif
1252 GEN_CHECK_OFF(AHCIPort, fAsyncIOThreadIdle);
1253 GEN_CHECK_OFF(AHCIPort, szSerialNumber);
1254 GEN_CHECK_OFF(AHCIPort, szSerialNumber[AHCI_SERIAL_NUMBER_LENGTH]); /* One additional byte for the termination.*/
1255 GEN_CHECK_OFF(AHCIPort, szFirmwareRevision);
1256 GEN_CHECK_OFF(AHCIPort, szFirmwareRevision[AHCI_FIRMWARE_REVISION_LENGTH]); /* One additional byte for the termination.*/
1257 GEN_CHECK_OFF(AHCIPort, szModelNumber);
1258 GEN_CHECK_OFF(AHCIPort, szModelNumber[AHCI_MODEL_NUMBER_LENGTH]); /* One additional byte for the termination.*/
1259 GEN_CHECK_OFF(AHCIPort, szInquiryVendorId[AHCI_ATAPI_INQUIRY_VENDOR_ID_LENGTH]);
1260 GEN_CHECK_OFF(AHCIPort, szInquiryProductId);
1261 GEN_CHECK_OFF(AHCIPort, szInquiryProductId[AHCI_ATAPI_INQUIRY_PRODUCT_ID_LENGTH]);
1262 GEN_CHECK_OFF(AHCIPort, szInquiryRevision);
1263 GEN_CHECK_OFF(AHCIPort, szInquiryRevision[AHCI_ATAPI_INQUIRY_REVISION_LENGTH]);
1264 GEN_CHECK_OFF(AHCIPort, cErrors);
1265 GEN_CHECK_OFF(AHCIPort, fRedo);
1266
1267 GEN_CHECK_SIZE(AHCI);
1268 GEN_CHECK_OFF(AHCI, dev);
1269 GEN_CHECK_OFF(AHCI, pDevInsR3);
1270 GEN_CHECK_OFF(AHCI, pDevInsR0);
1271 GEN_CHECK_OFF(AHCI, pDevInsRC);
1272 GEN_CHECK_OFF(AHCI, IBase);
1273 GEN_CHECK_OFF(AHCI, ILeds);
1274 GEN_CHECK_OFF(AHCI, pLedsConnector);
1275 GEN_CHECK_OFF(AHCI, MMIOBase);
1276 GEN_CHECK_OFF(AHCI, regHbaCap);
1277 GEN_CHECK_OFF(AHCI, regHbaCtrl);
1278 GEN_CHECK_OFF(AHCI, regHbaIs);
1279 GEN_CHECK_OFF(AHCI, regHbaPi);
1280 GEN_CHECK_OFF(AHCI, regHbaVs);
1281 GEN_CHECK_OFF(AHCI, regHbaCccCtl);
1282 GEN_CHECK_OFF(AHCI, regHbaCccPorts);
1283 GEN_CHECK_OFF(AHCI, regIdx);
1284 GEN_CHECK_OFF(AHCI, pHbaCccTimerR3);
1285 GEN_CHECK_OFF(AHCI, pHbaCccTimerR0);
1286 GEN_CHECK_OFF(AHCI, pHbaCccTimerRC);
1287 GEN_CHECK_OFF(AHCI, pNotifierQueueR3);
1288 GEN_CHECK_OFF(AHCI, pNotifierQueueR0);
1289 GEN_CHECK_OFF(AHCI, pNotifierQueueRC);
1290 GEN_CHECK_OFF(AHCI, uCccPortNr);
1291 GEN_CHECK_OFF(AHCI, uCccTimeout);
1292 GEN_CHECK_OFF(AHCI, uCccNr);
1293 GEN_CHECK_OFF(AHCI, uCccCurrentNr);
1294 GEN_CHECK_OFF(AHCI, ahciPort);
1295 GEN_CHECK_OFF(AHCI, ahciPort[AHCI_MAX_NR_PORTS_IMPL-1]);
1296 GEN_CHECK_OFF(AHCI, aCts);
1297 GEN_CHECK_OFF(AHCI, aCts[1]);
1298 GEN_CHECK_OFF(AHCI, lock);
1299 GEN_CHECK_OFF(AHCI, u32PortsInterrupted);
1300 GEN_CHECK_OFF(AHCI, fReset);
1301 GEN_CHECK_OFF(AHCI, f64BitAddr);
1302 GEN_CHECK_OFF(AHCI, fGCEnabled);
1303 GEN_CHECK_OFF(AHCI, fR0Enabled);
1304 GEN_CHECK_OFF(AHCI, fSignalIdle);
1305 GEN_CHECK_OFF(AHCI, fBootable);
1306 GEN_CHECK_OFF(AHCI, cPortsImpl);
1307 GEN_CHECK_OFF(AHCI, cCmdSlotsAvail);
1308 GEN_CHECK_OFF(AHCI, f8ByteMMIO4BytesWrittenSuccessfully);
1309#endif /* VBOX_WITH_AHCI */
1310
1311#ifdef VBOX_WITH_E1000
1312 GEN_CHECK_SIZE(EEPROM93C46);
1313 GEN_CHECK_OFF(EEPROM93C46, m_eState);
1314 GEN_CHECK_OFF(EEPROM93C46, m_au16Data);
1315 GEN_CHECK_OFF(EEPROM93C46, m_fWriteEnabled);
1316 GEN_CHECK_OFF(EEPROM93C46, m_u16Word);
1317 GEN_CHECK_OFF(EEPROM93C46, m_u16Mask);
1318 GEN_CHECK_OFF(EEPROM93C46, m_u16Addr);
1319 GEN_CHECK_OFF(EEPROM93C46, m_u32InternalWires);
1320 GEN_CHECK_OFF(EEPROM93C46, m_eOp);
1321
1322 GEN_CHECK_SIZE(E1KSTATE);
1323 GEN_CHECK_OFF(E1KSTATE, IBase);
1324 GEN_CHECK_OFF(E1KSTATE, INetworkDown);
1325 GEN_CHECK_OFF(E1KSTATE, INetworkConfig);
1326 GEN_CHECK_OFF(E1KSTATE, ILeds);
1327 GEN_CHECK_OFF(E1KSTATE, pDrvBase);
1328 GEN_CHECK_OFF(E1KSTATE, pDrvR3);
1329 GEN_CHECK_OFF(E1KSTATE, pDrvR0);
1330 GEN_CHECK_OFF(E1KSTATE, pDrvRC);
1331 GEN_CHECK_OFF(E1KSTATE, pLedsConnector);
1332 GEN_CHECK_OFF(E1KSTATE, pDevInsR3);
1333 GEN_CHECK_OFF(E1KSTATE, pDevInsR0);
1334 GEN_CHECK_OFF(E1KSTATE, pDevInsRC);
1335 GEN_CHECK_OFF(E1KSTATE, pTxQueueR3);
1336 GEN_CHECK_OFF(E1KSTATE, pTxQueueR0);
1337 GEN_CHECK_OFF(E1KSTATE, pTxQueueRC);
1338 GEN_CHECK_OFF(E1KSTATE, pCanRxQueueR3);
1339 GEN_CHECK_OFF(E1KSTATE, pCanRxQueueR0);
1340 GEN_CHECK_OFF(E1KSTATE, pCanRxQueueRC);
1341 GEN_CHECK_OFF(E1KSTATE, pRIDTimerR3);
1342 GEN_CHECK_OFF(E1KSTATE, pRIDTimerR0);
1343 GEN_CHECK_OFF(E1KSTATE, pRIDTimerRC);
1344 GEN_CHECK_OFF(E1KSTATE, pRADTimerR3);
1345 GEN_CHECK_OFF(E1KSTATE, pRADTimerR0);
1346 GEN_CHECK_OFF(E1KSTATE, pRADTimerRC);
1347 GEN_CHECK_OFF(E1KSTATE, pTIDTimerR3);
1348 GEN_CHECK_OFF(E1KSTATE, pTIDTimerR0);
1349 GEN_CHECK_OFF(E1KSTATE, pTIDTimerRC);
1350 GEN_CHECK_OFF(E1KSTATE, pTADTimerR3);
1351 GEN_CHECK_OFF(E1KSTATE, pTADTimerR0);
1352 GEN_CHECK_OFF(E1KSTATE, pTADTimerRC);
1353 GEN_CHECK_OFF(E1KSTATE, pIntTimerR3);
1354 GEN_CHECK_OFF(E1KSTATE, pIntTimerR0);
1355 GEN_CHECK_OFF(E1KSTATE, pIntTimerRC);
1356 GEN_CHECK_OFF(E1KSTATE, pLUTimerR3);
1357 GEN_CHECK_OFF(E1KSTATE, pLUTimerR0);
1358 GEN_CHECK_OFF(E1KSTATE, pLUTimerRC);
1359 GEN_CHECK_OFF(E1KSTATE, cs);
1360# ifndef E1K_GLOBAL_MUTEX
1361 GEN_CHECK_OFF(E1KSTATE, csRx);
1362# endif
1363 GEN_CHECK_OFF(E1KSTATE, addrMMReg);
1364 GEN_CHECK_OFF(E1KSTATE, macConfigured);
1365 GEN_CHECK_OFF(E1KSTATE, addrIOPort);
1366 GEN_CHECK_OFF(E1KSTATE, pciDevice);
1367 GEN_CHECK_OFF(E1KSTATE, u64AckedAt);
1368 GEN_CHECK_OFF(E1KSTATE, fIntRaised);
1369 GEN_CHECK_OFF(E1KSTATE, fCableConnected);
1370 GEN_CHECK_OFF(E1KSTATE, fR0Enabled);
1371 GEN_CHECK_OFF(E1KSTATE, fGCEnabled);
1372 GEN_CHECK_OFF(E1KSTATE, auRegs[E1K_NUM_OF_32BIT_REGS]);
1373 GEN_CHECK_OFF(E1KSTATE, led);
1374 GEN_CHECK_OFF(E1KSTATE, u32PktNo);
1375 GEN_CHECK_OFF(E1KSTATE, uSelectedReg);
1376 GEN_CHECK_OFF(E1KSTATE, auMTA[128]);
1377 GEN_CHECK_OFF(E1KSTATE, aRecAddr);
1378 GEN_CHECK_OFF(E1KSTATE, auVFTA[128]);
1379 GEN_CHECK_OFF(E1KSTATE, u16RxBSize);
1380 GEN_CHECK_OFF(E1KSTATE, fLocked);
1381 GEN_CHECK_OFF(E1KSTATE, fDelayInts);
1382 GEN_CHECK_OFF(E1KSTATE, fIntMaskUsed);
1383 GEN_CHECK_OFF(E1KSTATE, fMaybeOutOfSpace);
1384 GEN_CHECK_OFF(E1KSTATE, hEventMoreRxDescAvail);
1385 GEN_CHECK_OFF(E1KSTATE, contextTSE);
1386 GEN_CHECK_OFF(E1KSTATE, contextNormal);
1387 GEN_CHECK_OFF(E1KSTATE, aTxPacketFallback[E1K_MAX_TX_PKT_SIZE]);
1388 GEN_CHECK_OFF(E1KSTATE, u16TxPktLen);
1389 GEN_CHECK_OFF(E1KSTATE, fIPcsum);
1390 GEN_CHECK_OFF(E1KSTATE, fTCPcsum);
1391 GEN_CHECK_OFF(E1KSTATE, u32PayRemain);
1392 GEN_CHECK_OFF(E1KSTATE, u16HdrRemain);
1393 GEN_CHECK_OFF(E1KSTATE, u16SavedFlags);
1394 GEN_CHECK_OFF(E1KSTATE, u32SavedCsum);
1395 GEN_CHECK_OFF(E1KSTATE, eeprom);
1396 GEN_CHECK_OFF(E1KSTATE, phy);
1397 GEN_CHECK_OFF(E1KSTATE, StatReceiveBytes);
1398#endif /* VBOX_WITH_E1000 */
1399
1400#ifdef VBOX_WITH_VIRTIO
1401 GEN_CHECK_OFF(VPCISTATE, cs);
1402 GEN_CHECK_OFF(VPCISTATE, szInstance);
1403 GEN_CHECK_OFF(VPCISTATE, IBase);
1404 GEN_CHECK_OFF(VPCISTATE, ILeds);
1405 GEN_CHECK_OFF(VPCISTATE, pLedsConnector);
1406 GEN_CHECK_OFF(VPCISTATE, pDevInsR3);
1407 GEN_CHECK_OFF(VPCISTATE, pDevInsR0);
1408 GEN_CHECK_OFF(VPCISTATE, pDevInsRC);
1409 GEN_CHECK_OFF(VPCISTATE, pciDevice);
1410 GEN_CHECK_OFF(VPCISTATE, addrIOPort);
1411 GEN_CHECK_OFF(VPCISTATE, led);
1412 GEN_CHECK_OFF(VPCISTATE, uGuestFeatures);
1413 GEN_CHECK_OFF(VPCISTATE, uQueueSelector);
1414 GEN_CHECK_OFF(VPCISTATE, uStatus);
1415 GEN_CHECK_OFF(VPCISTATE, uISR);
1416 GEN_CHECK_OFF(VPCISTATE, Queues);
1417 GEN_CHECK_OFF(VPCISTATE, Queues[VIRTIO_MAX_NQUEUES]);
1418 GEN_CHECK_OFF(VNETSTATE, VPCI);
1419 GEN_CHECK_OFF(VNETSTATE, INetworkDown);
1420 GEN_CHECK_OFF(VNETSTATE, INetworkConfig);
1421 GEN_CHECK_OFF(VNETSTATE, pDrvBase);
1422 GEN_CHECK_OFF(VNETSTATE, pCanRxQueueR3);
1423 GEN_CHECK_OFF(VNETSTATE, pCanRxQueueR0);
1424 GEN_CHECK_OFF(VNETSTATE, pCanRxQueueRC);
1425 GEN_CHECK_OFF(VNETSTATE, pLinkUpTimer);
1426# ifdef VNET_TX_DELAY
1427 GEN_CHECK_OFF(VNETSTATE, pTxTimerR3);
1428 GEN_CHECK_OFF(VNETSTATE, pTxTimerR0);
1429 GEN_CHECK_OFF(VNETSTATE, pTxTimerRC);
1430# endif /* VNET_TX_DELAY */
1431 GEN_CHECK_OFF(VNETSTATE, config);
1432 GEN_CHECK_OFF(VNETSTATE, macConfigured);
1433 GEN_CHECK_OFF(VNETSTATE, fCableConnected);
1434 GEN_CHECK_OFF(VNETSTATE, u32PktNo);
1435 GEN_CHECK_OFF(VNETSTATE, fPromiscuous);
1436 GEN_CHECK_OFF(VNETSTATE, fAllMulti);
1437 GEN_CHECK_OFF(VNETSTATE, pRxQueue);
1438 GEN_CHECK_OFF(VNETSTATE, pTxQueue);
1439 GEN_CHECK_OFF(VNETSTATE, pCtlQueue);
1440 GEN_CHECK_OFF(VNETSTATE, fMaybeOutOfSpace);
1441 GEN_CHECK_OFF(VNETSTATE, hEventMoreRxDescAvail);
1442#endif /* VBOX_WITH_VIRTIO */
1443
1444#ifdef VBOX_WITH_SCSI
1445 GEN_CHECK_SIZE(VBOXSCSI);
1446 GEN_CHECK_OFF(VBOXSCSI, regIdentify);
1447 GEN_CHECK_OFF(VBOXSCSI, uTargetDevice);
1448 GEN_CHECK_OFF(VBOXSCSI, uTxDir);
1449 GEN_CHECK_OFF(VBOXSCSI, cbCDB);
1450 GEN_CHECK_OFF(VBOXSCSI, aCDB);
1451 GEN_CHECK_OFF(VBOXSCSI, aCDB[11]);
1452 GEN_CHECK_OFF(VBOXSCSI, iCDB);
1453 GEN_CHECK_OFF(VBOXSCSI, pBuf);
1454 GEN_CHECK_OFF(VBOXSCSI, cbBuf);
1455 GEN_CHECK_OFF(VBOXSCSI, iBuf);
1456 GEN_CHECK_OFF(VBOXSCSI, fBusy);
1457 GEN_CHECK_OFF(VBOXSCSI, enmState);
1458#endif
1459
1460 /* VMMDev*.cpp/h */
1461 GEN_CHECK_SIZE(VMMDevState);
1462 GEN_CHECK_OFF(VMMDevState, dev);
1463 GEN_CHECK_OFF(VMMDevState, CritSect);
1464 GEN_CHECK_OFF(VMMDevState, hypervisorSize);
1465 GEN_CHECK_OFF(VMMDevState, mouseCapabilities);
1466 GEN_CHECK_OFF(VMMDevState, mouseXAbs);
1467 GEN_CHECK_OFF(VMMDevState, mouseYAbs);
1468 GEN_CHECK_OFF(VMMDevState, fHostCursorRequested);
1469 GEN_CHECK_OFF(VMMDevState, pDevIns);
1470 GEN_CHECK_OFF(VMMDevState, IBase);
1471 GEN_CHECK_OFF(VMMDevState, IPort);
1472#ifdef VBOX_WITH_HGCM
1473 GEN_CHECK_OFF(VMMDevState, IHGCMPort);
1474#endif
1475 GEN_CHECK_OFF(VMMDevState, pDrvBase);
1476 GEN_CHECK_OFF(VMMDevState, pDrv);
1477#ifdef VBOX_WITH_HGCM
1478 GEN_CHECK_OFF(VMMDevState, pHGCMDrv);
1479#endif
1480 GEN_CHECK_OFF(VMMDevState, szMsg);
1481 GEN_CHECK_OFF(VMMDevState, iMsg);
1482 GEN_CHECK_OFF(VMMDevState, PortBase);
1483 GEN_CHECK_OFF(VMMDevState, irq);
1484 GEN_CHECK_OFF(VMMDevState, u32HostEventFlags);
1485 GEN_CHECK_OFF(VMMDevState, u32GuestFilterMask);
1486 GEN_CHECK_OFF(VMMDevState, u32NewGuestFilterMask);
1487 GEN_CHECK_OFF(VMMDevState, fNewGuestFilterMask);
1488 GEN_CHECK_OFF(VMMDevState, GCPhysVMMDevRAM);
1489 GEN_CHECK_OFF(VMMDevState, pVMMDevRAMR3);
1490 GEN_CHECK_OFF(VMMDevState, pVMMDevHeapR3);
1491 GEN_CHECK_OFF(VMMDevState, GCPhysVMMDevHeap);
1492 GEN_CHECK_OFF(VMMDevState, guestInfo);
1493 GEN_CHECK_OFF(VMMDevState, guestCaps);
1494 GEN_CHECK_OFF(VMMDevState, fu32AdditionsOk);
1495 GEN_CHECK_OFF(VMMDevState, u32VideoAccelEnabled);
1496 GEN_CHECK_OFF(VMMDevState, displayChangeData);
1497 GEN_CHECK_OFF(VMMDevState, pCredentials);
1498 GEN_CHECK_OFF(VMMDevState, u32MemoryBalloonSize);
1499 GEN_CHECK_OFF(VMMDevState, u32LastMemoryBalloonSize);
1500 GEN_CHECK_OFF(VMMDevState, cbGuestRAM);
1501 GEN_CHECK_OFF(VMMDevState, idSession);
1502 GEN_CHECK_OFF(VMMDevState, u32StatIntervalSize);
1503 GEN_CHECK_OFF(VMMDevState, u32LastStatIntervalSize);
1504 GEN_CHECK_OFF(VMMDevState, fLastSeamlessEnabled),
1505 GEN_CHECK_OFF(VMMDevState, fSeamlessEnabled);
1506 GEN_CHECK_OFF(VMMDevState, fVRDPEnabled);
1507 GEN_CHECK_OFF(VMMDevState, u32VRDPExperienceLevel);
1508#ifdef TIMESYNC_BACKDOOR
1509 GEN_CHECK_OFF(VMMDevState, hostTime);
1510 GEN_CHECK_OFF(VMMDevState, fTimesyncBackdoorLo);
1511#endif
1512 GEN_CHECK_OFF(VMMDevState, fGetHostTimeDisabled);
1513 GEN_CHECK_OFF(VMMDevState, fBackdoorLogDisabled);
1514 GEN_CHECK_OFF(VMMDevState, fKeepCredentials);
1515 GEN_CHECK_OFF(VMMDevState, fHeapEnabled);
1516#ifdef VBOX_WITH_HGCM
1517 GEN_CHECK_OFF(VMMDevState, pHGCMCmdList);
1518 GEN_CHECK_OFF(VMMDevState, critsectHGCMCmdList);
1519 GEN_CHECK_OFF(VMMDevState, u32HGCMEnabled);
1520#endif
1521 GEN_CHECK_OFF(VMMDevState, SharedFolders);
1522 GEN_CHECK_OFF(VMMDevState, SharedFolders.Led);
1523 GEN_CHECK_OFF(VMMDevState, SharedFolders.ILeds);
1524 GEN_CHECK_OFF(VMMDevState, SharedFolders.pLedsConnector);
1525 GEN_CHECK_OFF(VMMDevState, fCpuHotPlugEventsEnabled);
1526 GEN_CHECK_OFF(VMMDevState, enmCpuHotPlugEvent);
1527 GEN_CHECK_OFF(VMMDevState, idCpuCore);
1528 GEN_CHECK_OFF(VMMDevState, idCpuPackage);
1529 GEN_CHECK_OFF(VMMDevState, StatMemBalloonChunks);
1530 GEN_CHECK_OFF(VMMDevState, fRZEnabled);
1531 GEN_CHECK_OFF(VMMDevState, fTestingEnabled);
1532 GEN_CHECK_OFF(VMMDevState, u32TestingHighTimestamp);
1533 GEN_CHECK_OFF(VMMDevState, u32TestingCmd);
1534 GEN_CHECK_OFF(VMMDevState, offTestingData);
1535 GEN_CHECK_OFF(VMMDevState, TestingData);
1536 GEN_CHECK_OFF(VMMDevState, TestingData.Value.u64Value);
1537 GEN_CHECK_OFF(VMMDevState, TestingData.Value.u32Unit);
1538 GEN_CHECK_OFF(VMMDevState, TestingData.Value.szName);
1539
1540#ifdef VBOX_WITH_BUSLOGIC
1541 GEN_CHECK_SIZE(BUSLOGICDEVICE);
1542 GEN_CHECK_OFF(BUSLOGICDEVICE, pBusLogicR3);
1543 GEN_CHECK_OFF(BUSLOGICDEVICE, pBusLogicR0);
1544 GEN_CHECK_OFF(BUSLOGICDEVICE, pBusLogicRC);
1545 GEN_CHECK_OFF(BUSLOGICDEVICE, fPresent);
1546 GEN_CHECK_OFF(BUSLOGICDEVICE, iLUN);
1547 GEN_CHECK_OFF(BUSLOGICDEVICE, IBase);
1548 GEN_CHECK_OFF(BUSLOGICDEVICE, ISCSIPort);
1549 GEN_CHECK_OFF(BUSLOGICDEVICE, ILed);
1550 GEN_CHECK_OFF(BUSLOGICDEVICE, pDrvBase);
1551 GEN_CHECK_OFF(BUSLOGICDEVICE, pDrvSCSIConnector);
1552 GEN_CHECK_OFF(BUSLOGICDEVICE, Led);
1553 GEN_CHECK_OFF(BUSLOGICDEVICE, cOutstandingRequests);
1554
1555 GEN_CHECK_SIZE(BUSLOGIC);
1556 GEN_CHECK_OFF(BUSLOGIC, dev);
1557 GEN_CHECK_OFF(BUSLOGIC, pDevInsR3);
1558 GEN_CHECK_OFF(BUSLOGIC, pDevInsR0);
1559 GEN_CHECK_OFF(BUSLOGIC, pDevInsRC);
1560 GEN_CHECK_OFF(BUSLOGIC, IOPortBase);
1561 GEN_CHECK_OFF(BUSLOGIC, MMIOBase);
1562 GEN_CHECK_OFF(BUSLOGIC, regStatus);
1563 GEN_CHECK_OFF(BUSLOGIC, regInterrupt);
1564 GEN_CHECK_OFF(BUSLOGIC, regGeometry);
1565 GEN_CHECK_OFF(BUSLOGIC, LocalRam);
1566 GEN_CHECK_OFF(BUSLOGIC, uOperationCode);
1567 GEN_CHECK_OFF(BUSLOGIC, aCommandBuffer);
1568 GEN_CHECK_OFF(BUSLOGIC, aCommandBuffer[BUSLOGIC_COMMAND_SIZE_MAX]);
1569 GEN_CHECK_OFF(BUSLOGIC, iParameter);
1570 GEN_CHECK_OFF(BUSLOGIC, cbCommandParametersLeft);
1571 GEN_CHECK_OFF(BUSLOGIC, fUseLocalRam);
1572 GEN_CHECK_OFF(BUSLOGIC, aReplyBuffer);
1573 GEN_CHECK_OFF(BUSLOGIC, aReplyBuffer[BUSLOGIC_REPLY_SIZE_MAX]);
1574 GEN_CHECK_OFF(BUSLOGIC, iReply);
1575 GEN_CHECK_OFF(BUSLOGIC, cbReplyParametersLeft);
1576 GEN_CHECK_OFF(BUSLOGIC, fIRQEnabled);
1577 GEN_CHECK_OFF(BUSLOGIC, cMailbox);
1578 GEN_CHECK_OFF(BUSLOGIC, GCPhysAddrMailboxOutgoingBase);
1579 GEN_CHECK_OFF(BUSLOGIC, uMailboxOutgoingPositionCurrent);
1580 GEN_CHECK_OFF(BUSLOGIC, cMailboxesReady);
1581 GEN_CHECK_OFF(BUSLOGIC, fNotificationSend);
1582 GEN_CHECK_OFF(BUSLOGIC, GCPhysAddrMailboxIncomingBase);
1583 GEN_CHECK_OFF(BUSLOGIC, uMailboxIncomingPositionCurrent);
1584 GEN_CHECK_OFF(BUSLOGIC, fStrictRoundRobinMode);
1585 GEN_CHECK_OFF(BUSLOGIC, fExtendedLunCCBFormat);
1586 GEN_CHECK_OFF(BUSLOGIC, pNotifierQueueR3);
1587 GEN_CHECK_OFF(BUSLOGIC, pNotifierQueueR0);
1588 GEN_CHECK_OFF(BUSLOGIC, pNotifierQueueRC);
1589 GEN_CHECK_OFF(BUSLOGIC, CritSectIntr);
1590 GEN_CHECK_OFF(BUSLOGIC, hTaskCache);
1591 GEN_CHECK_OFF(BUSLOGIC, VBoxSCSI);
1592 GEN_CHECK_OFF(BUSLOGIC, aDeviceStates);
1593 GEN_CHECK_OFF(BUSLOGIC, aDeviceStates[BUSLOGIC_MAX_DEVICES-1]);
1594 GEN_CHECK_OFF(BUSLOGIC, IBase);
1595 GEN_CHECK_OFF(BUSLOGIC, ILeds);
1596 GEN_CHECK_OFF(BUSLOGIC, pLedsConnector);
1597 GEN_CHECK_OFF(BUSLOGIC, fSignalIdle);
1598 GEN_CHECK_OFF(BUSLOGIC, fRedo);
1599 GEN_CHECK_OFF(BUSLOGIC, pTasksRedoHead);
1600#endif /* VBOX_WITH_BUSLOGIC */
1601
1602#ifdef VBOX_WITH_LSILOGIC
1603 GEN_CHECK_SIZE(LSILOGICSCSI);
1604 GEN_CHECK_OFF(LSILOGICSCSI, PciDev);
1605 GEN_CHECK_OFF(LSILOGICSCSI, pDevInsR3);
1606 GEN_CHECK_OFF(LSILOGICSCSI, pDevInsR0);
1607 GEN_CHECK_OFF(LSILOGICSCSI, pDevInsRC);
1608 GEN_CHECK_OFF(LSILOGICSCSI, fGCEnabled);
1609 GEN_CHECK_OFF(LSILOGICSCSI, fR0Enabled);
1610 GEN_CHECK_OFF(LSILOGICSCSI, enmState);
1611 GEN_CHECK_OFF(LSILOGICSCSI, enmWhoInit);
1612 GEN_CHECK_OFF(LSILOGICSCSI, fDoorbellInProgress);
1613 GEN_CHECK_OFF(LSILOGICSCSI, fDiagnosticEnabled);
1614 GEN_CHECK_OFF(LSILOGICSCSI, fNotificationSend);
1615 GEN_CHECK_OFF(LSILOGICSCSI, fEventNotificationEnabled);
1616 GEN_CHECK_OFF(LSILOGICSCSI, pNotificationQueueR3);
1617 GEN_CHECK_OFF(LSILOGICSCSI, pNotificationQueueR0);
1618 GEN_CHECK_OFF(LSILOGICSCSI, pNotificationQueueRC);
1619 GEN_CHECK_OFF(LSILOGICSCSI, cDeviceStates);
1620 GEN_CHECK_OFF(LSILOGICSCSI, paDeviceStates);
1621 GEN_CHECK_OFF(LSILOGICSCSI, GCPhysMMIOBase);
1622 GEN_CHECK_OFF(LSILOGICSCSI, IOPortBase);
1623 GEN_CHECK_OFF(LSILOGICSCSI, uInterruptMask);
1624 GEN_CHECK_OFF(LSILOGICSCSI, uInterruptStatus);
1625 GEN_CHECK_OFF(LSILOGICSCSI, aMessage);
1626 GEN_CHECK_OFF(LSILOGICSCSI, aMessage[sizeof(MptConfigurationRequest)-1]);
1627 GEN_CHECK_OFF(LSILOGICSCSI, iMessage);
1628 GEN_CHECK_OFF(LSILOGICSCSI, cMessage);
1629 GEN_CHECK_OFF(LSILOGICSCSI, ReplyBuffer);
1630 GEN_CHECK_OFF(LSILOGICSCSI, uNextReplyEntryRead);
1631 GEN_CHECK_OFF(LSILOGICSCSI, cReplySize);
1632 GEN_CHECK_OFF(LSILOGICSCSI, u16IOCFaultCode);
1633 GEN_CHECK_OFF(LSILOGICSCSI, u32HostMFAHighAddr);
1634 GEN_CHECK_OFF(LSILOGICSCSI, u32SenseBufferHighAddr);
1635 GEN_CHECK_OFF(LSILOGICSCSI, cMaxDevices);
1636 GEN_CHECK_OFF(LSILOGICSCSI, cMaxBuses);
1637 GEN_CHECK_OFF(LSILOGICSCSI, cbReplyFrame);
1638 GEN_CHECK_OFF(LSILOGICSCSI, iDiagnosticAccess);
1639 GEN_CHECK_OFF(LSILOGICSCSI, cReplyQueueEntries);
1640 GEN_CHECK_OFF(LSILOGICSCSI, cRequestQueueEntries);
1641 GEN_CHECK_OFF(LSILOGICSCSI, ReplyPostQueueCritSect);
1642 GEN_CHECK_OFF(LSILOGICSCSI, ReplyFreeQueueCritSect);
1643 GEN_CHECK_OFF(LSILOGICSCSI, pReplyFreeQueueBaseR3);
1644 GEN_CHECK_OFF(LSILOGICSCSI, pReplyPostQueueBaseR3);
1645 GEN_CHECK_OFF(LSILOGICSCSI, pRequestQueueBaseR3);
1646 GEN_CHECK_OFF(LSILOGICSCSI, pReplyFreeQueueBaseR0);
1647 GEN_CHECK_OFF(LSILOGICSCSI, pReplyPostQueueBaseR0);
1648 GEN_CHECK_OFF(LSILOGICSCSI, pRequestQueueBaseR0);
1649 GEN_CHECK_OFF(LSILOGICSCSI, pReplyFreeQueueBaseRC);
1650 GEN_CHECK_OFF(LSILOGICSCSI, pReplyPostQueueBaseRC);
1651 GEN_CHECK_OFF(LSILOGICSCSI, pRequestQueueBaseRC);
1652 GEN_CHECK_OFF(LSILOGICSCSI, uReplyFreeQueueNextEntryFreeWrite);
1653 GEN_CHECK_OFF(LSILOGICSCSI, uReplyFreeQueueNextAddressRead);
1654 GEN_CHECK_OFF(LSILOGICSCSI, uReplyPostQueueNextEntryFreeWrite);
1655 GEN_CHECK_OFF(LSILOGICSCSI, uReplyPostQueueNextAddressRead);
1656 GEN_CHECK_OFF(LSILOGICSCSI, uRequestQueueNextEntryFreeWrite);
1657 GEN_CHECK_OFF(LSILOGICSCSI, uRequestQueueNextAddressRead);
1658 GEN_CHECK_OFF(LSILOGICSCSI, u16NextHandle);
1659 GEN_CHECK_OFF(LSILOGICSCSI, enmCtrlType);
1660 GEN_CHECK_OFF(LSILOGICSCSI, VBoxSCSI);
1661 GEN_CHECK_OFF(LSILOGICSCSI, hTaskCache);
1662 GEN_CHECK_OFF(LSILOGICSCSI, IBase);
1663 GEN_CHECK_OFF(LSILOGICSCSI, ILeds);
1664 GEN_CHECK_OFF(LSILOGICSCSI, pLedsConnector);
1665 GEN_CHECK_OFF(LSILOGICSCSI, pConfigurationPages);
1666 GEN_CHECK_OFF(LSILOGICSCSI, fSignalIdle);
1667 GEN_CHECK_OFF(LSILOGICSCSI, fRedo);
1668 GEN_CHECK_OFF(LSILOGICSCSI, pTasksRedoHead);
1669#endif /* VBOX_WITH_LSILOGIC */
1670
1671 GEN_CHECK_SIZE(HpetState);
1672 GEN_CHECK_OFF(HpetState, pDevInsR3);
1673 GEN_CHECK_OFF(HpetState, pDevInsR0);
1674 GEN_CHECK_OFF(HpetState, pDevInsRC);
1675 GEN_CHECK_OFF(HpetState, u64HpetOffset);
1676 GEN_CHECK_OFF(HpetState, u64Capabilities);
1677 GEN_CHECK_OFF(HpetState, u64HpetConfig);
1678 GEN_CHECK_OFF(HpetState, u64Isr);
1679 GEN_CHECK_OFF(HpetState, u64HpetCounter);
1680 GEN_CHECK_OFF(HpetState, csLock);
1681 GEN_CHECK_OFF(HpetState, fIch9);
1682
1683 GEN_CHECK_SIZE(HpetTimer);
1684 GEN_CHECK_OFF(HpetTimer, pTimerR3);
1685 GEN_CHECK_OFF(HpetTimer, pHpetR3);
1686 GEN_CHECK_OFF(HpetTimer, pTimerR0);
1687 GEN_CHECK_OFF(HpetTimer, pHpetR0);
1688 GEN_CHECK_OFF(HpetTimer, pTimerRC);
1689 GEN_CHECK_OFF(HpetTimer, pHpetRC);
1690 GEN_CHECK_OFF(HpetTimer, u8TimerNumber);
1691 GEN_CHECK_OFF(HpetTimer, u64Config);
1692 GEN_CHECK_OFF(HpetTimer, u64Cmp);
1693 GEN_CHECK_OFF(HpetTimer, u64Fsb);
1694 GEN_CHECK_OFF(HpetTimer, u64Period);
1695 GEN_CHECK_OFF(HpetTimer, u8Wrap);
1696
1697 return (0);
1698}
Note: See TracBrowser for help on using the repository browser.

© 2023 Oracle
ContactPrivacy policyTerms of Use