VirtualBox

source: vbox/trunk/src/VBox/Devices/testcase/tstDeviceInternal.h@ 84124

Last change on this file since 84124 was 83296, checked in by vboxsync, 5 years ago

Devices/tstDevice: Copy over and modify PDMThread* API so we can fuzz saved states of device s which delegate some parts of the saved state loading to workers

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 16.0 KB
Line 
1/** @file
2 * tstDevice: Shared definitions between the framework and the shim library.
3 */
4
5/*
6 * Copyright (C) 2017-2020 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 */
16
17#ifndef VBOX_INCLUDED_SRC_testcase_tstDeviceInternal_h
18#define VBOX_INCLUDED_SRC_testcase_tstDeviceInternal_h
19#ifndef RT_WITHOUT_PRAGMA_ONCE
20# pragma once
21#endif
22
23#include <VBox/param.h>
24#include <VBox/types.h>
25#include <iprt/assert.h>
26#include <iprt/list.h>
27#include <iprt/semaphore.h>
28#include <iprt/critsect.h>
29
30#include "tstDeviceCfg.h"
31#include "tstDevicePlugin.h"
32
33RT_C_DECLS_BEGIN
34
35
36/** Converts PDM device instance to the device under test structure. */
37#define TSTDEV_PDMDEVINS_2_DUT(a_pDevIns) ((a_pDevIns)->Internal.s.pDut)
38
39/** Forward declaration of internal test device instance data. */
40typedef struct TSTDEVDUTINT *PTSTDEVDUTINT;
41
42
43/**
44 * CFGM node structure.
45 */
46typedef struct CFGMNODE
47{
48 /** Device under test this CFGM node is for. */
49 PTSTDEVDUTINT pDut;
50 /** @todo: */
51} CFGMNODE;
52
53
54/**
55 * Private device instance data.
56 */
57typedef struct PDMDEVINSINTR3
58{
59 /** Pointer to the device under test the PDM device instance is for. */
60 PTSTDEVDUTINT pDut;
61} PDMDEVINSINTR3;
62AssertCompile(sizeof(PDMDEVINSINTR3) <= (HC_ARCH_BITS == 32 ? 72 : 112 + 0x28));
63
64/**
65 * Private device instance data.
66 */
67typedef struct PDMDEVINSINTR0
68{
69 /** Pointer to the device under test the PDM device instance is for. */
70 PTSTDEVDUTINT pDut;
71} PDMDEVINSINTR0;
72AssertCompile(sizeof(PDMDEVINSINTR0) <= (HC_ARCH_BITS == 32 ? 72 : 112 + 0x28));
73
74/**
75 * Private device instance data.
76 */
77typedef struct PDMDEVINSINTRC
78{
79 /** Pointer to the device under test the PDM device instance is for. */
80 PTSTDEVDUTINT pDut;
81} PDMDEVINSINTRC;
82AssertCompile(sizeof(PDMDEVINSINTRC) <= (HC_ARCH_BITS == 32 ? 72 : 112 + 0x28));
83
84typedef struct PDMPCIDEVINT
85{
86 bool fRegistered;
87} PDMPCIDEVINT;
88
89
90/**
91 * Internal PDM critical section structure.
92 */
93typedef struct PDMCRITSECTINT
94{
95 /** The actual critical section used for emulation. */
96 RTCRITSECT CritSect;
97} PDMCRITSECTINT;
98AssertCompile(sizeof(PDMCRITSECTINT) <= (HC_ARCH_BITS == 32 ? 0x80 : 0xc0));
99
100
101/**
102 * SSM handle state.
103 */
104typedef struct SSMHANDLE
105{
106 /** Pointer to the device under test the handle is for. */
107 PTSTDEVDUTINT pDut;
108 /** The saved state data buffer. */
109 uint8_t *pbSavedState;
110 /** Size of the saved state. */
111 size_t cbSavedState;
112 /** Current offset into the data buffer. */
113 uint32_t offDataBuffer;
114 /** Current unit version. */
115 uint32_t uCurUnitVer;
116 /** Status code. */
117 int rc;
118} SSMHANDLE;
119
120
121/**
122 * MM Heap allocation.
123 */
124typedef struct TSTDEVMMHEAPALLOC
125{
126 /** Node for the list of allocations. */
127 RTLISTNODE NdMmHeap;
128 /** Pointer to the device under test the allocation was made for. */
129 PTSTDEVDUTINT pDut;
130 /** Size of the allocation. */
131 size_t cbAlloc;
132 /** Start of the real allocation. */
133 uint8_t abAlloc[RT_FLEXIBLE_ARRAY];
134} TSTDEVMMHEAPALLOC;
135/** Pointer to a MM Heap allocation. */
136typedef TSTDEVMMHEAPALLOC *PTSTDEVMMHEAPALLOC;
137/** Pointer to a const MM Heap allocation. */
138typedef const TSTDEVMMHEAPALLOC *PCTSTDEVMMHEAPALLOC;
139
140AssertCompileMemberAlignment(TSTDEVMMHEAPALLOC, abAlloc, HC_ARCH_BITS == 64 ? 16 : 8);
141
142
143/**
144 * The usual device/driver/internal/external stuff.
145 */
146typedef enum
147{
148 /** The usual invalid entry. */
149 PDMTHREADTYPE_INVALID = 0,
150 /** Device type. */
151 PDMTHREADTYPE_DEVICE,
152 /** USB Device type. */
153 PDMTHREADTYPE_USB,
154 /** Driver type. */
155 PDMTHREADTYPE_DRIVER,
156 /** Internal type. */
157 PDMTHREADTYPE_INTERNAL,
158 /** External type. */
159 PDMTHREADTYPE_EXTERNAL,
160 /** The usual 32-bit hack. */
161 PDMTHREADTYPE_32BIT_HACK = 0x7fffffff
162} PDMTHREADTYPE;
163
164
165/**
166 * The internal structure for the thread.
167 */
168typedef struct PDMTHREADINT
169{
170 /** Node for the list of threads. */
171 RTLISTNODE NdPdmThrds;
172 /** Pointer to the device under test the allocation was made for. */
173 PTSTDEVDUTINT pDut;
174 /** The event semaphore the thread blocks on when not running. */
175 RTSEMEVENTMULTI BlockEvent;
176 /** The event semaphore the thread sleeps on while running. */
177 RTSEMEVENTMULTI SleepEvent;
178 /** The thread type. */
179 PDMTHREADTYPE enmType;
180} PDMTHREADINT;
181
182
183#define PDMTHREADINT_DECLARED
184#define PDMCRITSECTINT_DECLARED
185#define PDMDEVINSINT_DECLARED
186#define PDMPCIDEVINT_DECLARED
187#define VMM_INCLUDED_SRC_include_VMInternal_h
188#define VMM_INCLUDED_SRC_include_VMMInternal_h
189RT_C_DECLS_END
190#include <VBox/vmm/pdmcritsect.h>
191#include <VBox/vmm/pdmthread.h>
192#include <VBox/vmm/pdmdev.h>
193#include <VBox/vmm/pdmpci.h>
194#include <VBox/vmm/pdmdrv.h>
195#include <VBox/vmm/tm.h>
196RT_C_DECLS_BEGIN
197
198
199/**
200 * TM timer structure.
201 */
202typedef struct TMTIMER
203{
204 /** List of timers created by the device. */
205 RTLISTNODE NdDevTimers;
206 /** Clock this timer belongs to. */
207 TMCLOCK enmClock;
208 /** Callback to call when the timer expires. */
209 PFNTMTIMERDEV pfnCallbackDev;
210 /** Opaque user data to pass to the callback. */
211 void *pvUser;
212 /** Flags. */
213 uint32_t fFlags;
214 /** Assigned critical section. */
215 PPDMCRITSECT pCritSect;
216 /** @todo: */
217} TMTIMER;
218
219
220/**
221 * PDM module descriptor type.
222 */
223typedef enum TSTDEVPDMMODTYPE
224{
225 /** Invalid module type. */
226 TSTDEVPDMMODTYPE_INVALID = 0,
227 /** Ring 3 module. */
228 TSTDEVPDMMODTYPE_R3,
229 /** Ring 0 module. */
230 TSTDEVPDMMODTYPE_R0,
231 /** Raw context module. */
232 TSTDEVPDMMODTYPE_RC,
233 /** 32bit hack. */
234 TSTDEVPDMMODTYPE_32BIT_HACK = 0x7fffffff
235} TSTDEVPDMMODTYPE;
236
237/**
238 * Registered I/O port access handler.
239 */
240typedef struct RTDEVDUTIOPORT
241{
242 /** Node for the list of registered handlers. */
243 RTLISTNODE NdIoPorts;
244 /** Start I/O port the handler is for. */
245 RTIOPORT PortStart;
246 /** Number of ports handled. */
247 RTIOPORT cPorts;
248 /** Opaque user data - R3. */
249 void *pvUserR3;
250 /** Out handler - R3. */
251 PFNIOMIOPORTNEWOUT pfnOutR3;
252 /** In handler - R3. */
253 PFNIOMIOPORTNEWIN pfnInR3;
254 /** Out string handler - R3. */
255 PFNIOMIOPORTNEWOUTSTRING pfnOutStrR3;
256 /** In string handler - R3. */
257 PFNIOMIOPORTNEWINSTRING pfnInStrR3;
258
259 /** Opaque user data - R0. */
260 void *pvUserR0;
261 /** Out handler - R0. */
262 PFNIOMIOPORTNEWOUT pfnOutR0;
263 /** In handler - R0. */
264 PFNIOMIOPORTNEWIN pfnInR0;
265 /** Out string handler - R0. */
266 PFNIOMIOPORTNEWOUTSTRING pfnOutStrR0;
267 /** In string handler - R0. */
268 PFNIOMIOPORTNEWINSTRING pfnInStrR0;
269
270#ifdef TSTDEV_SUPPORTS_RC
271 /** Opaque user data - RC. */
272 void *pvUserRC;
273 /** Out handler - RC. */
274 PFNIOMIOPORTNEWOUT pfnOutRC;
275 /** In handler - RC. */
276 PFNIOMIOPORTNEWIN pfnInRC;
277 /** Out string handler - RC. */
278 PFNIOMIOPORTNEWOUTSTRING pfnOutStrRC;
279 /** In string handler - RC. */
280 PFNIOMIOPORTNEWINSTRING pfnInStrRC;
281#endif
282} RTDEVDUTIOPORT;
283/** Pointer to a registered I/O port handler. */
284typedef RTDEVDUTIOPORT *PRTDEVDUTIOPORT;
285/** Pointer to a const I/O port handler. */
286typedef const RTDEVDUTIOPORT *PCRTDEVDUTIOPORT;
287
288
289/**
290 * Registered SSM handlers.
291 */
292typedef struct TSTDEVDUTSSM
293{
294 /** Node for the list of registered SSM handlers. */
295 RTLISTNODE NdSsm;
296 /** Version */
297 uint32_t uVersion;
298 PFNSSMDEVLIVEPREP pfnLivePrep;
299 PFNSSMDEVLIVEEXEC pfnLiveExec;
300 PFNSSMDEVLIVEVOTE pfnLiveVote;
301 PFNSSMDEVSAVEPREP pfnSavePrep;
302 PFNSSMDEVSAVEEXEC pfnSaveExec;
303 PFNSSMDEVSAVEDONE pfnSaveDone;
304 PFNSSMDEVLOADPREP pfnLoadPrep;
305 PFNSSMDEVLOADEXEC pfnLoadExec;
306 PFNSSMDEVLOADDONE pfnLoadDone;
307} TSTDEVDUTSSM;
308/** Pointer to the registered SSM handlers. */
309typedef TSTDEVDUTSSM *PTSTDEVDUTSSM;
310/** Pointer to a const SSM handler. */
311typedef const TSTDEVDUTSSM *PCTSTDEVDUTSSM;
312
313
314/**
315 * The Support Driver session state.
316 */
317typedef struct TSTDEVSUPDRVSESSION
318{
319 /** Pointer to the owning device under test instance. */
320 PTSTDEVDUTINT pDut;
321 /** List of event semaphores. */
322 RTLISTANCHOR LstSupSem;
323} TSTDEVSUPDRVSESSION;
324/** Pointer to the Support Driver session state. */
325typedef TSTDEVSUPDRVSESSION *PTSTDEVSUPDRVSESSION;
326
327/** Converts a Support Driver session handle to the internal state. */
328#define TSTDEV_PSUPDRVSESSION_2_PTSTDEVSUPDRVSESSION(a_pSession) ((PTSTDEVSUPDRVSESSION)(a_pSession))
329/** Converts the internal session state to a Support Driver session handle. */
330#define TSTDEV_PTSTDEVSUPDRVSESSION_2_PSUPDRVSESSION(a_pSession) ((PSUPDRVSESSION)(a_pSession))
331
332/**
333 * Support driver event semaphore.
334 */
335typedef struct TSTDEVSUPSEMEVENT
336{
337 /** Node for the event semaphore list. */
338 RTLISTNODE NdSupSem;
339 /** Flag whether this is multi event semaphore. */
340 bool fMulti;
341 /** Event smeaphore handles depending on the flag above. */
342 union
343 {
344 RTSEMEVENT hSemEvt;
345 RTSEMEVENTMULTI hSemEvtMulti;
346 } u;
347} TSTDEVSUPSEMEVENT;
348/** Pointer to a support event semaphore state. */
349typedef TSTDEVSUPSEMEVENT *PTSTDEVSUPSEMEVENT;
350
351/** Converts a Support event semaphore handle to the internal state. */
352#define TSTDEV_SUPSEMEVENT_2_PTSTDEVSUPSEMEVENT(a_pSupSemEvt) ((PTSTDEVSUPSEMEVENT)(a_pSupSemEvt))
353/** Converts the internal session state to a Support event semaphore handle. */
354#define TSTDEV_PTSTDEVSUPSEMEVENT_2_SUPSEMEVENT(a_pSupSemEvt) ((SUPSEMEVENT)(a_pSupSemEvt))
355
356/**
357 * The contex the device under test is currently in.
358 */
359typedef enum TSTDEVDUTCTX
360{
361 /** Invalid context. */
362 TSTDEVDUTCTX_INVALID = 0,
363 /** R3 context. */
364 TSTDEVDUTCTX_R3,
365 /** R0 context. */
366 TSTDEVDUTCTX_R0,
367 /** RC context. */
368 TSTDEVDUTCTX_RC,
369 /** 32bit hack. */
370 TSTDEVDUTCTX_32BIT_HACK = 0x7fffffff
371} TSTDEVDUTCTX;
372
373/**
374 * PCI region descriptor.
375 */
376typedef struct TSTDEVDUTPCIREGION
377{
378 /** Size of the region. */
379 RTGCPHYS cbRegion;
380 /** Address space type. */
381 PCIADDRESSSPACE enmType;
382 /** Region mapping callback. */
383 PFNPCIIOREGIONMAP pfnRegionMap;
384} TSTDEVDUTPCIREGION;
385/** Pointer to a PCI region descriptor. */
386typedef TSTDEVDUTPCIREGION *PTSTDEVDUTPCIREGION;
387/** Pointer to a const PCI region descriptor. */
388typedef const TSTDEVDUTPCIREGION *PCTSTDEVDUTPCIREGION;
389
390/**
391 * Device under test instance data.
392 */
393typedef struct TSTDEVDUTINT
394{
395 /** Pointer to the test this device is running under. */
396 PCTSTDEVTEST pTest;
397 /** Pointer to the PDM device instance. */
398 PPDMDEVINS pDevIns;
399 /** CFGM root config node for the device. */
400 CFGMNODE Cfg;
401 /** Current device context. */
402 TSTDEVDUTCTX enmCtx;
403 /** Critical section protecting the lists below. */
404 RTCRITSECTRW CritSectLists;
405 /** List of registered I/O port handlers. */
406 RTLISTANCHOR LstIoPorts;
407 /** List of timers registered. */
408 RTLISTANCHOR LstTimers;
409 /** List of registered MMIO regions. */
410 RTLISTANCHOR LstMmio;
411 /** List of MM Heap allocations. */
412 RTLISTANCHOR LstMmHeap;
413 /** List of PDM threads. */
414 RTLISTANCHOR LstPdmThreads;
415 /** List of SSM handlers (just one normally). */
416 RTLISTANCHOR LstSsmHandlers;
417 /** The SUP session we emulate. */
418 TSTDEVSUPDRVSESSION SupSession;
419 /** The NOP critical section. */
420 PDMCRITSECT CritSectNop;
421 /** The VM state associated with this device. */
422 PVM pVm;
423 /** The registered PCI device instance if this is a PCI device. */
424 PPDMPCIDEV pPciDev;
425 /** PCI Region descriptors. */
426 TSTDEVDUTPCIREGION aPciRegions[VBOX_PCI_NUM_REGIONS];
427 /** The status port interface we implement. */
428 PDMIBASE IBaseSts;
429 /** */
430} TSTDEVDUTINT;
431
432
433extern const PDMDEVHLPR3 g_tstDevPdmDevHlpR3;
434
435
436DECLHIDDEN(int) tstDevPdmLdrGetSymbol(PTSTDEVDUTINT pThis, const char *pszMod, TSTDEVPDMMODTYPE enmModType,
437 const char *pszSymbol, PFNRT *ppfn);
438
439
440DECLINLINE(int) tstDevDutLockShared(PTSTDEVDUTINT pThis)
441{
442 return RTCritSectRwEnterShared(&pThis->CritSectLists);
443}
444
445DECLINLINE(int) tstDevDutUnlockShared(PTSTDEVDUTINT pThis)
446{
447 return RTCritSectRwLeaveShared(&pThis->CritSectLists);
448}
449
450DECLINLINE(int) tstDevDutLockExcl(PTSTDEVDUTINT pThis)
451{
452 return RTCritSectRwEnterExcl(&pThis->CritSectLists);
453}
454
455DECLINLINE(int) tstDevDutUnlockExcl(PTSTDEVDUTINT pThis)
456{
457 return RTCritSectRwLeaveExcl(&pThis->CritSectLists);
458}
459
460DECLHIDDEN(int) tstDevPdmR3ThreadCreateDevice(PTSTDEVDUTINT pDut, PPDMDEVINS pDevIns, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADDEV pfnThread,
461 PFNPDMTHREADWAKEUPDEV pfnWakeUp, size_t cbStack, RTTHREADTYPE enmType, const char *pszName);
462DECLHIDDEN(int) tstDevPdmR3ThreadCreateUsb(PTSTDEVDUTINT pDut, PPDMUSBINS pUsbIns, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADUSB pfnThread,
463 PFNPDMTHREADWAKEUPUSB pfnWakeUp, size_t cbStack, RTTHREADTYPE enmType, const char *pszName);
464DECLHIDDEN(int) tstDevPdmR3ThreadCreateDriver(PTSTDEVDUTINT pDut, PPDMDRVINS pDrvIns, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADDRV pfnThread,
465 PFNPDMTHREADWAKEUPDRV pfnWakeUp, size_t cbStack, RTTHREADTYPE enmType, const char *pszName);
466DECLHIDDEN(int) tstDevPdmR3ThreadCreate(PTSTDEVDUTINT pDut, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADINT pfnThread,
467 PFNPDMTHREADWAKEUPINT pfnWakeUp, size_t cbStack, RTTHREADTYPE enmType, const char *pszName);
468DECLHIDDEN(int) tstDevPdmR3ThreadCreateExternal(PTSTDEVDUTINT pDut, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADEXT pfnThread,
469 PFNPDMTHREADWAKEUPEXT pfnWakeUp, size_t cbStack, RTTHREADTYPE enmType, const char *pszName);
470DECLHIDDEN(int) tstDevPdmR3ThreadDestroy(PPDMTHREAD pThread, int *pRcThread);
471DECLHIDDEN(int) tstDevPdmR3ThreadDestroyDevice(PTSTDEVDUTINT pDut, PPDMDEVINS pDevIns);
472DECLHIDDEN(int) tstDevPdmR3ThreadDestroyUsb(PTSTDEVDUTINT pDut, PPDMUSBINS pUsbIns);
473DECLHIDDEN(int) tstDevPdmR3ThreadDestroyDriver(PTSTDEVDUTINT pDut, PPDMDRVINS pDrvIns);
474DECLHIDDEN(void) tstDevPdmR3ThreadDestroyAll(PTSTDEVDUTINT pDut);
475DECLHIDDEN(int) tstDevPdmR3ThreadIAmSuspending(PPDMTHREAD pThread);
476DECLHIDDEN(int) tstDevPdmR3ThreadIAmRunning(PPDMTHREAD pThread);
477DECLHIDDEN(int) tstDevPdmR3ThreadSleep(PPDMTHREAD pThread, RTMSINTERVAL cMillies);
478DECLHIDDEN(int) tstDevPdmR3ThreadSuspend(PPDMTHREAD pThread);
479DECLHIDDEN(int) tstDevPdmR3ThreadResume(PPDMTHREAD pThread);
480
481
482RT_C_DECLS_END
483
484#endif /* !VBOX_INCLUDED_SRC_testcase_tstDeviceInternal_h */
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