VirtualBox

source: vbox/trunk/src/VBox/VMM/PDMInternal.h@ 23724

Last change on this file since 23724 was 23584, checked in by vboxsync, 15 years ago

pdmR3Load: Relaxed device/instance ordering assumptions.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Id
File size: 40.7 KB
Line 
1/* $Id: PDMInternal.h 23584 2009-10-06 15:54:44Z vboxsync $ */
2/** @file
3 * PDM - Internal header file.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
18 * Clara, CA 95054 USA or visit http://www.sun.com if you need
19 * additional information or have any questions.
20 */
21
22#ifndef ___PDMInternal_h
23#define ___PDMInternal_h
24
25#include <VBox/cdefs.h>
26#include <VBox/types.h>
27#include <VBox/param.h>
28#include <VBox/cfgm.h>
29#include <VBox/stam.h>
30#include <VBox/vusb.h>
31#include <VBox/pdmasynccompletion.h>
32#include <iprt/assert.h>
33#include <iprt/critsect.h>
34#ifdef IN_RING3
35# include <iprt/thread.h>
36#endif
37
38RT_C_DECLS_BEGIN
39
40
41/** @defgroup grp_pdm_int Internal
42 * @ingroup grp_pdm
43 * @internal
44 * @{
45 */
46
47/** @def PDM_WITH_R3R0_CRIT_SECT
48 * Enables or disabled ring-3/ring-0 critical sections. */
49#if defined(DOXYGEN_RUNNING) || 1
50# define PDM_WITH_R3R0_CRIT_SECT
51#endif
52
53
54/*******************************************************************************
55* Structures and Typedefs *
56*******************************************************************************/
57
58/** Pointer to a PDM Device. */
59typedef struct PDMDEV *PPDMDEV;
60/** Pointer to a pointer to a PDM Device. */
61typedef PPDMDEV *PPPDMDEV;
62
63/** Pointer to a PDM USB Device. */
64typedef struct PDMUSB *PPDMUSB;
65/** Pointer to a pointer to a PDM USB Device. */
66typedef PPDMUSB *PPPDMUSB;
67
68/** Pointer to a PDM Driver. */
69typedef struct PDMDRV *PPDMDRV;
70/** Pointer to a pointer to a PDM Driver. */
71typedef PPDMDRV *PPPDMDRV;
72
73/** Pointer to a PDM Logical Unit. */
74typedef struct PDMLUN *PPDMLUN;
75/** Pointer to a pointer to a PDM Logical Unit. */
76typedef PPDMLUN *PPPDMLUN;
77
78/** Pointer to a PDM PCI Bus instance. */
79typedef struct PDMPCIBUS *PPDMPCIBUS;
80/** Pointer to a DMAC instance. */
81typedef struct PDMDMAC *PPDMDMAC;
82/** Pointer to a RTC instance. */
83typedef struct PDMRTC *PPDMRTC;
84
85/** Pointer to an USB HUB registration record. */
86typedef struct PDMUSBHUB *PPDMUSBHUB;
87
88/**
89 * Private device instance data.
90 */
91typedef struct PDMDEVINSINT
92{
93 /** Pointer to the next instance (HC Ptr).
94 * (Head is pointed to by PDM::pDevInstances.) */
95 R3PTRTYPE(PPDMDEVINS) pNextR3;
96 /** Pointer to the next per device instance (HC Ptr).
97 * (Head is pointed to by PDMDEV::pInstances.) */
98 R3PTRTYPE(PPDMDEVINS) pPerDeviceNextR3;
99 /** Pointer to device structure - HC Ptr. */
100 R3PTRTYPE(PPDMDEV) pDevR3;
101 /** Pointer to the list of logical units associated with the device. (FIFO) */
102 R3PTRTYPE(PPDMLUN) pLunsR3;
103 /** Configuration handle to the instance node. */
104 R3PTRTYPE(PCFGMNODE) pCfgHandle;
105
106 /** R3 pointer to the VM this instance was created for. */
107 PVMR3 pVMR3;
108 /** R3 pointer to associated PCI device structure. */
109 R3PTRTYPE(struct PCIDevice *) pPciDeviceR3;
110 /** R3 pointer to associated PCI bus structure. */
111 R3PTRTYPE(PPDMPCIBUS) pPciBusR3;
112
113 /** R0 pointer to the VM this instance was created for. */
114 PVMR0 pVMR0;
115 /** R0 pointer to associated PCI device structure. */
116 R0PTRTYPE(struct PCIDevice *) pPciDeviceR0;
117 /** R0 pointer to associated PCI bus structure. */
118 R0PTRTYPE(PPDMPCIBUS) pPciBusR0;
119 /** Alignment padding. */
120 RTR0PTR Alignment0;
121
122 /** RC pointer to the VM this instance was created for. */
123 PVMRC pVMRC;
124 /** RC pointer to associated PCI device structure. */
125 RCPTRTYPE(struct PCIDevice *) pPciDeviceRC;
126 /** RC pointer to associated PCI bus structure. */
127 RCPTRTYPE(PPDMPCIBUS) pPciBusRC;
128
129 /** Flags, see PDMDEVINSINT_FLAGS_XXX. */
130 uint32_t fIntFlags;
131} PDMDEVINSINT;
132
133/** @name PDMDEVINSINT::fIntFlags
134 * @{ */
135/** Used by pdmR3Load to mark device instances it found in the saved state. */
136#define PDMDEVINSINT_FLAGS_FOUND RT_BIT_32(0)
137/** @} */
138
139
140/**
141 * Private USB device instance data.
142 */
143typedef struct PDMUSBINSINT
144{
145 /** The UUID of this instance. */
146 RTUUID Uuid;
147 /** Pointer to the next instance.
148 * (Head is pointed to by PDM::pUsbInstances.) */
149 R3PTRTYPE(PPDMUSBINS) pNext;
150 /** Pointer to the next per USB device instance.
151 * (Head is pointed to by PDMUSB::pInstances.) */
152 R3PTRTYPE(PPDMUSBINS) pPerDeviceNext;
153
154 /** Pointer to device structure. */
155 R3PTRTYPE(PPDMUSB) pUsbDev;
156
157 /** Pointer to the VM this instance was created for. */
158 PVMR3 pVM;
159 /** Pointer to the list of logical units associated with the device. (FIFO) */
160 R3PTRTYPE(PPDMLUN) pLuns;
161 /** The per instance device configuration. */
162 R3PTRTYPE(PCFGMNODE) pCfg;
163 /** Same as pCfg if the configuration should be deleted when detaching the device. */
164 R3PTRTYPE(PCFGMNODE) pCfgDelete;
165 /** The global device configuration. */
166 R3PTRTYPE(PCFGMNODE) pCfgGlobal;
167
168 /** Pointer to the USB hub this device is attached to.
169 * This is NULL if the device isn't connected to any HUB. */
170 R3PTRTYPE(PPDMUSBHUB) pHub;
171 /** The port number that we're connected to. */
172 uint32_t iPort;
173#if HC_ARCH_BITS == 64
174 uint32_t Alignment0;
175#endif
176} PDMUSBINSINT;
177
178
179/**
180 * Private driver instance data.
181 */
182typedef struct PDMDRVINSINT
183{
184 /** Pointer to the driver instance above.
185 * This is NULL for the topmost drive. */
186 PPDMDRVINS pUp;
187 /** Pointer to the driver instance below.
188 * This is NULL for the bottommost driver. */
189 PPDMDRVINS pDown;
190 /** Pointer to the logical unit this driver chained on. */
191 PPDMLUN pLun;
192 /** Pointer to driver structure from which this was instantiated. */
193 PPDMDRV pDrv;
194 /** Pointer to the VM this instance was created for. */
195 PVM pVM;
196 /** Flag indicating that the driver is being detached and destroyed.
197 * (Helps detect potential recursive detaching.) */
198 bool fDetaching;
199 /** Configuration handle to the instance node. */
200 PCFGMNODE pCfgHandle;
201
202} PDMDRVINSINT;
203
204
205/**
206 * Private critical section data.
207 */
208typedef struct PDMCRITSECTINT
209{
210 /** The critical section core which is shared with IPRT. */
211 RTCRITSECT Core;
212 /** Pointer to the next critical section.
213 * This chain is used for relocating pVMRC and device cleanup. */
214 R3PTRTYPE(struct PDMCRITSECTINT *) pNext;
215 /** Owner identifier.
216 * This is pDevIns if the owner is a device. Similarily for a driver or service.
217 * PDMR3CritSectInit() sets this to point to the critsect itself. */
218 RTR3PTR pvKey;
219 /** Pointer to the VM - R3Ptr. */
220 PVMR3 pVMR3;
221 /** Pointer to the VM - R0Ptr. */
222 PVMR0 pVMR0;
223 /** Pointer to the VM - GCPtr. */
224 PVMRC pVMRC;
225 /** Alignment padding. */
226 uint32_t padding;
227 /** Event semaphore that is scheduled to be signaled upon leaving the
228 * critical section. This is Ring-3 only of course. */
229 RTSEMEVENT EventToSignal;
230 /** The lock name. */
231 R3PTRTYPE(const char *) pszName;
232 /** R0/RC lock contention. */
233 STAMCOUNTER StatContentionRZLock;
234 /** R0/RC unlock contention. */
235 STAMCOUNTER StatContentionRZUnlock;
236 /** R3 lock contention. */
237 STAMCOUNTER StatContentionR3;
238 /** Profiling the time the section is locked. */
239 STAMPROFILEADV StatLocked;
240} PDMCRITSECTINT;
241AssertCompileMemberAlignment(PDMCRITSECTINT, StatContentionRZLock, 8);
242/** Pointer to private critical section data. */
243typedef PDMCRITSECTINT *PPDMCRITSECTINT;
244
245/** Indicates that the critical section is queued for unlock.
246 * PDMCritSectIsOwner and PDMCritSectIsOwned optimizations. */
247#define PDMCRITSECT_FLAGS_PENDING_UNLOCK RT_BIT_32(17)
248
249
250/**
251 * The usual device/driver/internal/external stuff.
252 */
253typedef enum
254{
255 /** The usual invalid entry. */
256 PDMTHREADTYPE_INVALID = 0,
257 /** Device type. */
258 PDMTHREADTYPE_DEVICE,
259 /** USB Device type. */
260 PDMTHREADTYPE_USB,
261 /** Driver type. */
262 PDMTHREADTYPE_DRIVER,
263 /** Internal type. */
264 PDMTHREADTYPE_INTERNAL,
265 /** External type. */
266 PDMTHREADTYPE_EXTERNAL,
267 /** The usual 32-bit hack. */
268 PDMTHREADTYPE_32BIT_HACK = 0x7fffffff
269} PDMTHREADTYPE;
270
271
272/**
273 * The internal structure for the thread.
274 */
275typedef struct PDMTHREADINT
276{
277 /** The VM pointer. */
278 PVMR3 pVM;
279 /** The event semaphore the thread blocks on when not running. */
280 RTSEMEVENTMULTI BlockEvent;
281 /** The event semaphore the thread sleeps on while running. */
282 RTSEMEVENTMULTI SleepEvent;
283 /** Pointer to the next thread. */
284 R3PTRTYPE(struct PDMTHREAD *) pNext;
285 /** The thread type. */
286 PDMTHREADTYPE enmType;
287} PDMTHREADINT;
288
289
290
291/* Must be included after PDMDEVINSINT is defined. */
292#define PDMDEVINSINT_DECLARED
293#define PDMUSBINSINT_DECLARED
294#define PDMDRVINSINT_DECLARED
295#define PDMCRITSECTINT_DECLARED
296#define PDMTHREADINT_DECLARED
297#ifdef ___VBox_pdm_h
298# error "Invalid header PDM order. Include PDMInternal.h before VBox/pdm.h!"
299#endif
300RT_C_DECLS_END
301#include <VBox/pdm.h>
302RT_C_DECLS_BEGIN
303
304/**
305 * PDM Logical Unit.
306 *
307 * This typically the representation of a physical port on a
308 * device, like for instance the PS/2 keyboard port on the
309 * keyboard controller device. The LUNs are chained on the
310 * device the belong to (PDMDEVINSINT::pLunsR3).
311 */
312typedef struct PDMLUN
313{
314 /** The LUN - The Logical Unit Number. */
315 RTUINT iLun;
316 /** Pointer to the next LUN. */
317 PPDMLUN pNext;
318 /** Pointer to the top driver in the driver chain. */
319 PPDMDRVINS pTop;
320 /** Pointer to the bottom driver in the driver chain. */
321 PPDMDRVINS pBottom;
322 /** Pointer to the device instance which the LUN belongs to.
323 * Either this is set or pUsbIns is set. Both is never set at the same time. */
324 PPDMDEVINS pDevIns;
325 /** Pointer to the USB device instance which the LUN belongs to. */
326 PPDMUSBINS pUsbIns;
327 /** Pointer to the device base interface. */
328 PPDMIBASE pBase;
329 /** Description of this LUN. */
330 const char *pszDesc;
331} PDMLUN;
332
333
334/**
335 * PDM Device.
336 */
337typedef struct PDMDEV
338{
339 /** Pointer to the next device (R3 Ptr). */
340 R3PTRTYPE(PPDMDEV) pNext;
341 /** Device name length. (search optimization) */
342 RTUINT cchName;
343 /** Registration structure. */
344 R3PTRTYPE(const struct PDMDEVREG *) pDevReg;
345 /** Number of instances. */
346 RTUINT cInstances;
347 /** Pointer to chain of instances (R3 Ptr). */
348 PPDMDEVINSR3 pInstances;
349} PDMDEV;
350
351
352/**
353 * PDM USB Device.
354 */
355typedef struct PDMUSB
356{
357 /** Pointer to the next device (R3 Ptr). */
358 R3PTRTYPE(PPDMUSB) pNext;
359 /** Device name length. (search optimization) */
360 RTUINT cchName;
361 /** Registration structure. */
362 R3PTRTYPE(const struct PDMUSBREG *) pUsbReg;
363 /** Next instance number. */
364 RTUINT iNextInstance;
365 /** Pointer to chain of instances (R3 Ptr). */
366 R3PTRTYPE(PPDMUSBINS) pInstances;
367} PDMUSB;
368
369
370/**
371 * PDM Driver.
372 */
373typedef struct PDMDRV
374{
375 /** Pointer to the next device. */
376 PPDMDRV pNext;
377 /** Registration structure. */
378 const struct PDMDRVREG * pDrvReg;
379 /** Number of instances. */
380 RTUINT cInstances;
381} PDMDRV;
382
383
384/**
385 * PDM registered PIC device.
386 */
387typedef struct PDMPIC
388{
389 /** Pointer to the PIC device instance - R3. */
390 PPDMDEVINSR3 pDevInsR3;
391 /** @copydoc PDMPICREG::pfnSetIrqR3 */
392 DECLR3CALLBACKMEMBER(void, pfnSetIrqR3,(PPDMDEVINS pDevIns, int iIrq, int iLevel));
393 /** @copydoc PDMPICREG::pfnGetInterruptR3 */
394 DECLR3CALLBACKMEMBER(int, pfnGetInterruptR3,(PPDMDEVINS pDevIns));
395
396 /** Pointer to the PIC device instance - R0. */
397 PPDMDEVINSR0 pDevInsR0;
398 /** @copydoc PDMPICREG::pfnSetIrqR3 */
399 DECLR0CALLBACKMEMBER(void, pfnSetIrqR0,(PPDMDEVINS pDevIns, int iIrq, int iLevel));
400 /** @copydoc PDMPICREG::pfnGetInterruptR3 */
401 DECLR0CALLBACKMEMBER(int, pfnGetInterruptR0,(PPDMDEVINS pDevIns));
402
403 /** Pointer to the PIC device instance - RC. */
404 PPDMDEVINSRC pDevInsRC;
405 /** @copydoc PDMPICREG::pfnSetIrqR3 */
406 DECLRCCALLBACKMEMBER(void, pfnSetIrqRC,(PPDMDEVINS pDevIns, int iIrq, int iLevel));
407 /** @copydoc PDMPICREG::pfnGetInterruptR3 */
408 DECLRCCALLBACKMEMBER(int, pfnGetInterruptRC,(PPDMDEVINS pDevIns));
409 /** Alignment padding. */
410 RTRCPTR RCPtrPadding;
411} PDMPIC;
412
413
414/**
415 * PDM registered APIC device.
416 */
417typedef struct PDMAPIC
418{
419 /** Pointer to the APIC device instance - R3 Ptr. */
420 PPDMDEVINSR3 pDevInsR3;
421 /** @copydoc PDMAPICREG::pfnGetInterruptR3 */
422 DECLR3CALLBACKMEMBER(int, pfnGetInterruptR3,(PPDMDEVINS pDevIns));
423 /** @copydoc PDMAPICREG::pfnHasPendingIrqR3 */
424 DECLR3CALLBACKMEMBER(bool, pfnHasPendingIrqR3,(PPDMDEVINS pDevIns));
425 /** @copydoc PDMAPICREG::pfnSetBaseR3 */
426 DECLR3CALLBACKMEMBER(void, pfnSetBaseR3,(PPDMDEVINS pDevIns, uint64_t u64Base));
427 /** @copydoc PDMAPICREG::pfnGetBaseR3 */
428 DECLR3CALLBACKMEMBER(uint64_t, pfnGetBaseR3,(PPDMDEVINS pDevIns));
429 /** @copydoc PDMAPICREG::pfnSetTPRR3 */
430 DECLR3CALLBACKMEMBER(void, pfnSetTPRR3,(PPDMDEVINS pDevIns, VMCPUID idCpu, uint8_t u8TPR));
431 /** @copydoc PDMAPICREG::pfnGetTPRR3 */
432 DECLR3CALLBACKMEMBER(uint8_t, pfnGetTPRR3,(PPDMDEVINS pDevIns, VMCPUID idCpu));
433 /** @copydoc PDMAPICREG::pfnWriteMSRR3 */
434 DECLR3CALLBACKMEMBER(int, pfnWriteMSRR3, (PPDMDEVINS pDevIns, VMCPUID idCpu, uint32_t u32Reg, uint64_t u64Value));
435 /** @copydoc PDMAPICREG::pfnReadMSRR3 */
436 DECLR3CALLBACKMEMBER(int, pfnReadMSRR3, (PPDMDEVINS pDevIns, VMCPUID idCpu, uint32_t u32Reg, uint64_t *pu64Value));
437 /** @copydoc PDMAPICREG::pfnBusDeliverR3 */
438 DECLR3CALLBACKMEMBER(int, pfnBusDeliverR3,(PPDMDEVINS pDevIns, uint8_t u8Dest, uint8_t u8DestMode, uint8_t u8DeliveryMode,
439 uint8_t iVector, uint8_t u8Polarity, uint8_t u8TriggerMode));
440
441 /** Pointer to the APIC device instance - R0 Ptr. */
442 PPDMDEVINSR0 pDevInsR0;
443 /** @copydoc PDMAPICREG::pfnGetInterruptR3 */
444 DECLR0CALLBACKMEMBER(int, pfnGetInterruptR0,(PPDMDEVINS pDevIns));
445 /** @copydoc PDMAPICREG::pfnHasPendingIrqR3 */
446 DECLR0CALLBACKMEMBER(bool, pfnHasPendingIrqR0,(PPDMDEVINS pDevIns));
447 /** @copydoc PDMAPICREG::pfnSetBaseR3 */
448 DECLR0CALLBACKMEMBER(void, pfnSetBaseR0,(PPDMDEVINS pDevIns, uint64_t u64Base));
449 /** @copydoc PDMAPICREG::pfnGetBaseR3 */
450 DECLR0CALLBACKMEMBER(uint64_t, pfnGetBaseR0,(PPDMDEVINS pDevIns));
451 /** @copydoc PDMAPICREG::pfnSetTPRR3 */
452 DECLR0CALLBACKMEMBER(void, pfnSetTPRR0,(PPDMDEVINS pDevIns, VMCPUID idCpu, uint8_t u8TPR));
453 /** @copydoc PDMAPICREG::pfnGetTPRR3 */
454 DECLR0CALLBACKMEMBER(uint8_t, pfnGetTPRR0,(PPDMDEVINS pDevIns, VMCPUID idCpu));
455 /** @copydoc PDMAPICREG::pfnWriteMSRR3 */
456 DECLR0CALLBACKMEMBER(uint32_t, pfnWriteMSRR0, (PPDMDEVINS pDevIns, VMCPUID idCpu, uint32_t u32Reg, uint64_t u64Value));
457 /** @copydoc PDMAPICREG::pfnReadMSRR3 */
458 DECLR0CALLBACKMEMBER(uint32_t, pfnReadMSRR0, (PPDMDEVINS pDevIns, VMCPUID idCpu, uint32_t u32Reg, uint64_t *pu64Value));
459 /** @copydoc PDMAPICREG::pfnBusDeliverR3 */
460 DECLR0CALLBACKMEMBER(int, pfnBusDeliverR0,(PPDMDEVINS pDevIns, uint8_t u8Dest, uint8_t u8DestMode, uint8_t u8DeliveryMode,
461 uint8_t iVector, uint8_t u8Polarity, uint8_t u8TriggerMode));
462
463 /** Pointer to the APIC device instance - RC Ptr. */
464 PPDMDEVINSRC pDevInsRC;
465 /** @copydoc PDMAPICREG::pfnGetInterruptR3 */
466 DECLRCCALLBACKMEMBER(int, pfnGetInterruptRC,(PPDMDEVINS pDevIns));
467 /** @copydoc PDMAPICREG::pfnHasPendingIrqR3 */
468 DECLRCCALLBACKMEMBER(bool, pfnHasPendingIrqRC,(PPDMDEVINS pDevIns));
469 /** @copydoc PDMAPICREG::pfnSetBaseR3 */
470 DECLRCCALLBACKMEMBER(void, pfnSetBaseRC,(PPDMDEVINS pDevIns, uint64_t u64Base));
471 /** @copydoc PDMAPICREG::pfnGetBaseR3 */
472 DECLRCCALLBACKMEMBER(uint64_t, pfnGetBaseRC,(PPDMDEVINS pDevIns));
473 /** @copydoc PDMAPICREG::pfnSetTPRR3 */
474 DECLRCCALLBACKMEMBER(void, pfnSetTPRRC,(PPDMDEVINS pDevIns, VMCPUID idCpu, uint8_t u8TPR));
475 /** @copydoc PDMAPICREG::pfnGetTPRR3 */
476 DECLRCCALLBACKMEMBER(uint8_t, pfnGetTPRRC,(PPDMDEVINS pDevIns, VMCPUID idCpu));
477 /** @copydoc PDMAPICREG::pfnWriteMSRR3 */
478 DECLRCCALLBACKMEMBER(uint32_t, pfnWriteMSRRC, (PPDMDEVINS pDevIns, VMCPUID idCpu, uint32_t u32Reg, uint64_t u64Value));
479 /** @copydoc PDMAPICREG::pfnReadMSRR3 */
480 DECLRCCALLBACKMEMBER(uint32_t, pfnReadMSRRC, (PPDMDEVINS pDevIns, VMCPUID idCpu, uint32_t u32Reg, uint64_t *pu64Value));
481 /** @copydoc PDMAPICREG::pfnBusDeliverR3 */
482 DECLRCCALLBACKMEMBER(int, pfnBusDeliverRC,(PPDMDEVINS pDevIns, uint8_t u8Dest, uint8_t u8DestMode, uint8_t u8DeliveryMode,
483 uint8_t iVector, uint8_t u8Polarity, uint8_t u8TriggerMode));
484} PDMAPIC;
485
486
487/**
488 * PDM registered I/O APIC device.
489 */
490typedef struct PDMIOAPIC
491{
492 /** Pointer to the APIC device instance - R3 Ptr. */
493 PPDMDEVINSR3 pDevInsR3;
494 /** @copydoc PDMIOAPICREG::pfnSetIrqR3 */
495 DECLR3CALLBACKMEMBER(void, pfnSetIrqR3,(PPDMDEVINS pDevIns, int iIrq, int iLevel));
496
497 /** Pointer to the PIC device instance - R0. */
498 PPDMDEVINSR0 pDevInsR0;
499 /** @copydoc PDMIOAPICREG::pfnSetIrqR3 */
500 DECLR0CALLBACKMEMBER(void, pfnSetIrqR0,(PPDMDEVINS pDevIns, int iIrq, int iLevel));
501
502 /** Pointer to the APIC device instance - RC Ptr. */
503 PPDMDEVINSRC pDevInsRC;
504 /** @copydoc PDMIOAPICREG::pfnSetIrqR3 */
505 DECLRCCALLBACKMEMBER(void, pfnSetIrqRC,(PPDMDEVINS pDevIns, int iIrq, int iLevel));
506} PDMIOAPIC;
507
508/** Maximum number of PCI busses for a VM. */
509#define PDM_PCI_BUSSES_MAX 8
510
511/**
512 * PDM PCI Bus instance.
513 */
514typedef struct PDMPCIBUS
515{
516 /** PCI bus number. */
517 RTUINT iBus;
518 RTUINT uPadding0; /**< Alignment padding.*/
519
520 /** Pointer to PCI Bus device instance. */
521 PPDMDEVINSR3 pDevInsR3;
522 /** @copydoc PDMPCIBUSREG::pfnSetIrqR3 */
523 DECLR3CALLBACKMEMBER(void, pfnSetIrqR3,(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, int iIrq, int iLevel));
524 /** @copydoc PDMPCIBUSREG::pfnRegisterR3 */
525 DECLR3CALLBACKMEMBER(int, pfnRegisterR3,(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, const char *pszName, int iDev));
526 /** @copydoc PDMPCIBUSREG::pfnIORegionRegisterR3 */
527 DECLR3CALLBACKMEMBER(int, pfnIORegionRegisterR3,(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, int iRegion, uint32_t cbRegion,
528 PCIADDRESSSPACE enmType, PFNPCIIOREGIONMAP pfnCallback));
529 /** @copydoc PDMPCIBUSREG::pfnSetConfigCallbacksR3 */
530 DECLR3CALLBACKMEMBER(void, pfnSetConfigCallbacksR3,(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, PFNPCICONFIGREAD pfnRead,
531 PPFNPCICONFIGREAD ppfnReadOld, PFNPCICONFIGWRITE pfnWrite, PPFNPCICONFIGWRITE ppfnWriteOld));
532 /** @copydoc PDMPCIBUSREG::pfnSaveExecR3 */
533 DECLR3CALLBACKMEMBER(int, pfnSaveExecR3,(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, PSSMHANDLE pSSMHandle));
534 /** @copydoc PDMPCIBUSREG::pfnLoadExecR3 */
535 DECLR3CALLBACKMEMBER(int, pfnLoadExecR3,(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, PSSMHANDLE pSSMHandle));
536 /** @copydoc PDMPCIBUSREG::pfnFakePCIBIOSR3 */
537 DECLR3CALLBACKMEMBER(int, pfnFakePCIBIOSR3,(PPDMDEVINS pDevIns));
538
539 /** Pointer to the PIC device instance - R0. */
540 R0PTRTYPE(PPDMDEVINS) pDevInsR0;
541 /** @copydoc PDMPCIBUSREG::pfnSetIrqR3 */
542 DECLR0CALLBACKMEMBER(void, pfnSetIrqR0,(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, int iIrq, int iLevel));
543
544 /** Pointer to PCI Bus device instance. */
545 PPDMDEVINSRC pDevInsRC;
546 /** @copydoc PDMPCIBUSREG::pfnSetIrqR3 */
547 DECLRCCALLBACKMEMBER(void, pfnSetIrqRC,(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, int iIrq, int iLevel));
548} PDMPCIBUS;
549
550
551#ifdef IN_RING3
552/**
553 * PDM registered DMAC (DMA Controller) device.
554 */
555typedef struct PDMDMAC
556{
557 /** Pointer to the DMAC device instance. */
558 PPDMDEVINSR3 pDevIns;
559 /** Copy of the registration structure. */
560 PDMDMACREG Reg;
561} PDMDMAC;
562
563
564/**
565 * PDM registered RTC (Real Time Clock) device.
566 */
567typedef struct PDMRTC
568{
569 /** Pointer to the RTC device instance. */
570 PPDMDEVINSR3 pDevIns;
571 /** Copy of the registration structure. */
572 PDMRTCREG Reg;
573} PDMRTC;
574
575#endif /* IN_RING3 */
576
577/**
578 * Module type.
579 */
580typedef enum PDMMODTYPE
581{
582 /** Raw-mode (RC) context module. */
583 PDMMOD_TYPE_RC,
584 /** Ring-0 (host) context module. */
585 PDMMOD_TYPE_R0,
586 /** Ring-3 (host) context module. */
587 PDMMOD_TYPE_R3
588} PDMMODTYPE;
589
590
591/** The module name length including the terminator. */
592#define PDMMOD_NAME_LEN 32
593
594/**
595 * Loaded module instance.
596 */
597typedef struct PDMMOD
598{
599 /** Module name. This is used for refering to
600 * the module internally, sort of like a handle. */
601 char szName[PDMMOD_NAME_LEN];
602 /** Module type. */
603 PDMMODTYPE eType;
604 /** Loader module handle. Not used for R0 modules. */
605 RTLDRMOD hLdrMod;
606 /** Loaded address.
607 * This is the 'handle' for R0 modules. */
608 RTUINTPTR ImageBase;
609 /** Old loaded address.
610 * This is used during relocation of GC modules. Not used for R0 modules. */
611 RTUINTPTR OldImageBase;
612 /** Where the R3 HC bits are stored.
613 * This can be equal to ImageBase but doesn't have to. Not used for R0 modules. */
614 void *pvBits;
615
616 /** Pointer to next module. */
617 struct PDMMOD *pNext;
618 /** Module filename. */
619 char szFilename[1];
620} PDMMOD;
621/** Pointer to loaded module instance. */
622typedef PDMMOD *PPDMMOD;
623
624
625
626/** Extra space in the free array. */
627#define PDMQUEUE_FREE_SLACK 16
628
629/**
630 * Queue type.
631 */
632typedef enum PDMQUEUETYPE
633{
634 /** Device consumer. */
635 PDMQUEUETYPE_DEV = 1,
636 /** Driver consumer. */
637 PDMQUEUETYPE_DRV,
638 /** Internal consumer. */
639 PDMQUEUETYPE_INTERNAL,
640 /** External consumer. */
641 PDMQUEUETYPE_EXTERNAL
642} PDMQUEUETYPE;
643
644/** Pointer to a PDM Queue. */
645typedef struct PDMQUEUE *PPDMQUEUE;
646
647/**
648 * PDM Queue.
649 */
650typedef struct PDMQUEUE
651{
652 /** Pointer to the next queue in the list. */
653 R3PTRTYPE(PPDMQUEUE) pNext;
654 /** Type specific data. */
655 union
656 {
657 /** PDMQUEUETYPE_DEV */
658 struct
659 {
660 /** Pointer to consumer function. */
661 R3PTRTYPE(PFNPDMQUEUEDEV) pfnCallback;
662 /** Pointer to the device instance owning the queue. */
663 R3PTRTYPE(PPDMDEVINS) pDevIns;
664 } Dev;
665 /** PDMQUEUETYPE_DRV */
666 struct
667 {
668 /** Pointer to consumer function. */
669 R3PTRTYPE(PFNPDMQUEUEDRV) pfnCallback;
670 /** Pointer to the driver instance owning the queue. */
671 R3PTRTYPE(PPDMDRVINS) pDrvIns;
672 } Drv;
673 /** PDMQUEUETYPE_INTERNAL */
674 struct
675 {
676 /** Pointer to consumer function. */
677 R3PTRTYPE(PFNPDMQUEUEINT) pfnCallback;
678 } Int;
679 /** PDMQUEUETYPE_EXTERNAL */
680 struct
681 {
682 /** Pointer to consumer function. */
683 R3PTRTYPE(PFNPDMQUEUEEXT) pfnCallback;
684 /** Pointer to user argument. */
685 R3PTRTYPE(void *) pvUser;
686 } Ext;
687 } u;
688 /** Queue type. */
689 PDMQUEUETYPE enmType;
690 /** The interval between checking the queue for events.
691 * The realtime timer below is used to do the waiting.
692 * If 0, the queue will use the VM_FF_PDM_QUEUE forced action. */
693 uint32_t cMilliesInterval;
694 /** Interval timer. Only used if cMilliesInterval is non-zero. */
695 PTMTIMERR3 pTimer;
696 /** Pointer to the VM - R3. */
697 PVMR3 pVMR3;
698 /** LIFO of pending items - R3. */
699 R3PTRTYPE(PPDMQUEUEITEMCORE) volatile pPendingR3;
700 /** Pointer to the VM - R0. */
701 PVMR0 pVMR0;
702 /** LIFO of pending items - R0. */
703 R0PTRTYPE(PPDMQUEUEITEMCORE) volatile pPendingR0;
704 /** Pointer to the GC VM and indicator for GC enabled queue.
705 * If this is NULL, the queue cannot be used in GC.
706 */
707 PVMRC pVMRC;
708 /** LIFO of pending items - GC. */
709 RCPTRTYPE(PPDMQUEUEITEMCORE) volatile pPendingRC;
710
711 /** Item size (bytes). */
712 uint32_t cbItem;
713 /** Number of items in the queue. */
714 uint32_t cItems;
715 /** Index to the free head (where we insert). */
716 uint32_t volatile iFreeHead;
717 /** Index to the free tail (where we remove). */
718 uint32_t volatile iFreeTail;
719
720 /** Unqiue queue name. */
721 R3PTRTYPE(const char *) pszName;
722#if HC_ARCH_BITS == 32
723 RTR3PTR Alignment1;
724#endif
725 /** Stat: Times PDMQueueAlloc fails. */
726 STAMCOUNTER StatAllocFailures;
727 /** Stat: PDMQueueInsert calls. */
728 STAMCOUNTER StatInsert;
729 /** Stat: Queue flushes. */
730 STAMCOUNTER StatFlush;
731 /** Stat: Queue flushes with pending items left over. */
732 STAMCOUNTER StatFlushLeftovers;
733#ifdef VBOX_WITH_STATISTICS
734 /** State: Profiling the flushing. */
735 STAMPROFILE StatFlushPrf;
736 /** State: Pending items. */
737 uint32_t volatile cStatPending;
738 uint32_t volatile cAlignment;
739#endif
740
741 /** Array of pointers to free items. Variable size. */
742 struct PDMQUEUEFREEITEM
743 {
744 /** Pointer to the free item - HC Ptr. */
745 R3PTRTYPE(PPDMQUEUEITEMCORE) volatile pItemR3;
746 /** Pointer to the free item - HC Ptr. */
747 R0PTRTYPE(PPDMQUEUEITEMCORE) volatile pItemR0;
748 /** Pointer to the free item - GC Ptr. */
749 RCPTRTYPE(PPDMQUEUEITEMCORE) volatile pItemRC;
750#if HC_ARCH_BITS == 64
751 RTRCPTR Alignment0;
752#endif
753 } aFreeItems[1];
754} PDMQUEUE;
755
756/** @name PDM::fQueueFlushing
757 * @{ */
758/** Indicating that an queue insert has been performed. */
759#define PDM_QUEUE_FLUSH_FLAG_ACTIVE RT_BIT_32(PDM_QUEUE_FLUSH_FLAG_ACTIVE_BIT)
760/** The bit number for PDM_QUEUE_FLUSH_FLAG_ACTIVE_BIT. */
761#define PDM_QUEUE_FLUSH_FLAG_ACTIVE_BIT 0
762/** Indicating there are pending items.
763 * This is make sure we don't miss inserts happening during flushing. The FF
764 * cannot be used for this since it has to be cleared immediately to prevent
765 * other EMTs from spinning. */
766#define PDM_QUEUE_FLUSH_FLAG_PENDING RT_BIT_32(PDM_QUEUE_FLUSH_FLAG_PENDING_BIT)
767/** The bit number for PDM_QUEUE_FLUSH_FLAG_PENDING. */
768#define PDM_QUEUE_FLUSH_FLAG_PENDING_BIT 1
769/** }@ */
770
771
772/**
773 * Queue device helper task operation.
774 */
775typedef enum PDMDEVHLPTASKOP
776{
777 /** The usual invalid 0 entry. */
778 PDMDEVHLPTASKOP_INVALID = 0,
779 /** ISASetIrq */
780 PDMDEVHLPTASKOP_ISA_SET_IRQ,
781 /** PCISetIrq */
782 PDMDEVHLPTASKOP_PCI_SET_IRQ,
783 /** PCISetIrq */
784 PDMDEVHLPTASKOP_IOAPIC_SET_IRQ,
785 /** The usual 32-bit hack. */
786 PDMDEVHLPTASKOP_32BIT_HACK = 0x7fffffff
787} PDMDEVHLPTASKOP;
788
789/**
790 * Queued Device Helper Task.
791 */
792typedef struct PDMDEVHLPTASK
793{
794 /** The queue item core (don't touch). */
795 PDMQUEUEITEMCORE Core;
796 /** Pointer to the device instance (R3 Ptr). */
797 PPDMDEVINSR3 pDevInsR3;
798 /** This operation to perform. */
799 PDMDEVHLPTASKOP enmOp;
800#if HC_ARCH_BITS == 64
801 uint32_t Alignment0;
802#endif
803 /** Parameters to the operation. */
804 union PDMDEVHLPTASKPARAMS
805 {
806 /**
807 * PDMDEVHLPTASKOP_ISA_SET_IRQ and PDMDEVHLPTASKOP_PCI_SET_IRQ.
808 */
809 struct PDMDEVHLPTASKSETIRQ
810 {
811 /** The IRQ */
812 int iIrq;
813 /** The new level. */
814 int iLevel;
815 } SetIRQ;
816 } u;
817} PDMDEVHLPTASK;
818/** Pointer to a queued Device Helper Task. */
819typedef PDMDEVHLPTASK *PPDMDEVHLPTASK;
820/** Pointer to a const queued Device Helper Task. */
821typedef const PDMDEVHLPTASK *PCPDMDEVHLPTASK;
822
823
824
825/**
826 * An USB hub registration record.
827 */
828typedef struct PDMUSBHUB
829{
830 /** The USB versions this hub support.
831 * Note that 1.1 hubs can take on 2.0 devices. */
832 uint32_t fVersions;
833 /** The number of ports on the hub. */
834 uint32_t cPorts;
835 /** The number of available ports (0..cPorts). */
836 uint32_t cAvailablePorts;
837 /** The driver instance of the hub. */
838 PPDMDRVINS pDrvIns;
839 /** Copy of the to the registration structure. */
840 PDMUSBHUBREG Reg;
841
842 /** Pointer to the next hub in the list. */
843 struct PDMUSBHUB *pNext;
844} PDMUSBHUB;
845
846/** Pointer to a const USB HUB registration record. */
847typedef const PDMUSBHUB *PCPDMUSBHUB;
848
849/** Pointer to a PDM Async I/O template. */
850typedef struct PDMASYNCCOMPLETIONTEMPLATE *PPDMASYNCCOMPLETIONTEMPLATE;
851
852/** Pointer to the main PDM Async completion endpoint class. */
853typedef struct PDMASYNCCOMPLETIONEPCLASS *PPDMASYNCCOMPLETIONEPCLASS;
854
855
856/**
857 * PDM VMCPU Instance data.
858 * Changes to this must checked against the padding of the cfgm union in VMCPU!
859 */
860typedef struct PDMCPU
861{
862 /** The number of entries in the apQueuedCritSectsLeaves table that's currnetly in use. */
863 uint32_t cQueuedCritSectLeaves;
864 uint32_t uPadding0; /**< Alignment padding.*/
865 /** Critical sections queued in RC/R0 because of contention preventing leave to complete. (R3 Ptrs)
866 * We will return to Ring-3 ASAP, so this queue doesn't have to be very long. */
867 R3PTRTYPE(PPDMCRITSECT) apQueuedCritSectsLeaves[8];
868} PDMCPU;
869
870/**
871 * Converts a PDM pointer into a VM pointer.
872 * @returns Pointer to the VM structure the PDM is part of.
873 * @param pPDM Pointer to PDM instance data.
874 */
875#define PDM2VM(pPDM) ( (PVM)((char*)pPDM - pPDM->offVM) )
876
877
878/**
879 * PDM VM Instance data.
880 * Changes to this must checked against the padding of the cfgm union in VM!
881 */
882typedef struct PDM
883{
884 /** Offset to the VM structure.
885 * See PDM2VM(). */
886 RTUINT offVM;
887 RTUINT uPadding0; /**< Alignment padding.*/
888
889 /** List of registered devices. (FIFO) */
890 R3PTRTYPE(PPDMDEV) pDevs;
891 /** List of devices instances. (FIFO) */
892 R3PTRTYPE(PPDMDEVINS) pDevInstances;
893 /** List of registered USB devices. (FIFO) */
894 R3PTRTYPE(PPDMUSB) pUsbDevs;
895 /** List of USB devices instances. (FIFO) */
896 R3PTRTYPE(PPDMUSBINS) pUsbInstances;
897 /** List of registered drivers. (FIFO) */
898 R3PTRTYPE(PPDMDRV) pDrvs;
899 /** List of initialized critical sections. (LIFO) */
900 R3PTRTYPE(PPDMCRITSECTINT) pCritSects;
901 /** PCI Buses. */
902 PDMPCIBUS aPciBuses[PDM_PCI_BUSSES_MAX];
903 /** The register PIC device. */
904 PDMPIC Pic;
905 /** The registerd APIC device. */
906 PDMAPIC Apic;
907 /** The registerd I/O APIC device. */
908 PDMIOAPIC IoApic;
909 /** The registered DMAC device. */
910 R3PTRTYPE(PPDMDMAC) pDmac;
911 /** The registered RTC device. */
912 R3PTRTYPE(PPDMRTC) pRtc;
913 /** The registered USB HUBs. (FIFO) */
914 R3PTRTYPE(PPDMUSBHUB) pUsbHubs;
915
916 /** Queue in which devhlp tasks are queued for R3 execution - R3 Ptr. */
917 R3PTRTYPE(PPDMQUEUE) pDevHlpQueueR3;
918 /** Queue in which devhlp tasks are queued for R3 execution - R0 Ptr. */
919 R0PTRTYPE(PPDMQUEUE) pDevHlpQueueR0;
920 /** Queue in which devhlp tasks are queued for R3 execution - RC Ptr. */
921 RCPTRTYPE(PPDMQUEUE) pDevHlpQueueRC;
922 RTRCPTR uPadding1; /**< Alignment padding. */
923
924 /** Linked list of timer driven PDM queues. */
925 R3PTRTYPE(struct PDMQUEUE *) pQueuesTimer;
926 /** Linked list of force action driven PDM queues. */
927 R3PTRTYPE(struct PDMQUEUE *) pQueuesForced;
928 /** Pointer to the queue which should be manually flushed - R0 Ptr.
929 * Only touched by EMT. */
930 R0PTRTYPE(struct PDMQUEUE *) pQueueFlushR0;
931 /** Pointer to the queue which should be manually flushed - RC Ptr.
932 * Only touched by EMT. */
933 RCPTRTYPE(struct PDMQUEUE *) pQueueFlushRC;
934 /** Bitmask controlling the queue flushing.
935 * See PDM_QUEUE_FLUSH_FLAG_ACTIVE and PDM_QUEUE_FLUSH_FLAG_PENDING. */
936 uint32_t volatile fQueueFlushing;
937
938 /** Head of the PDM Thread list. (singly linked) */
939 R3PTRTYPE(PPDMTHREAD) pThreads;
940 /** Tail of the PDM Thread list. (singly linked) */
941 R3PTRTYPE(PPDMTHREAD) pThreadsTail;
942
943 /** @name PDM Async Completion
944 * @{ */
945 /** Pointer to the array of supported endpoint classes. */
946 R3PTRTYPE(PPDMASYNCCOMPLETIONEPCLASS *) papAsyncCompletionEndpointClass;
947 /** Head of the templates. (singly linked) */
948 R3PTRTYPE(PPDMASYNCCOMPLETIONTEMPLATE) pAsyncCompletionTemplates;
949 /** @} */
950
951 /** @name VMM device heap
952 * @{ */
953 /** Pointer to the heap base (MMIO2 ring-3 mapping). NULL if not registered. */
954 RTR3PTR pvVMMDevHeap;
955#if HC_ARCH_BITS == 32
956 /** Alignment padding. */
957 uint32_t u32Padding2;
958#endif
959 /** The heap size. */
960 RTUINT cbVMMDevHeap;
961 /** Free space. */
962 RTUINT cbVMMDevHeapLeft;
963 /** The current mapping. NIL_RTGCPHYS if not mapped or registered. */
964 RTGCPHYS GCPhysVMMDevHeap;
965 /** @} */
966
967 /** The PDM lock.
968 * This is used to protect everything that deals with interrupts, i.e.
969 * the PIC, APIC, IOAPIC and PCI devices pluss some PDM functions. */
970 PDMCRITSECT CritSect;
971 /** The PDM miscellancous lock.
972 * This is used to protect things like critsect init/delete that formerly was
973 * serialized by there only being one EMT.
974 */
975 RTCRITSECT MiscCritSect;
976
977 /** Number of times a critical section leave requesed needed to be queued for ring-3 execution. */
978 STAMCOUNTER StatQueuedCritSectLeaves;
979} PDM;
980AssertCompileMemberAlignment(PDM, GCPhysVMMDevHeap, sizeof(RTGCPHYS));
981AssertCompileMemberAlignment(PDM, CritSect, 8);
982AssertCompileMemberAlignment(PDM, StatQueuedCritSectLeaves, 8);
983/** Pointer to PDM VM instance data. */
984typedef PDM *PPDM;
985
986
987/**
988 * PDM data kept in the UVM.
989 */
990typedef struct PDMUSERPERVM
991{
992 /** Pointer to list of loaded modules. */
993 PPDMMOD pModules;
994 /** @todo move more stuff over here. */
995} PDMUSERPERVM;
996/** Pointer to the PDM data kept in the UVM. */
997typedef PDMUSERPERVM *PPDMUSERPERVM;
998
999
1000
1001/*******************************************************************************
1002* Global Variables *
1003*******************************************************************************/
1004#ifdef IN_RING3
1005extern const PDMDRVHLP g_pdmR3DrvHlp;
1006extern const PDMDEVHLPR3 g_pdmR3DevHlpTrusted;
1007extern const PDMDEVHLPR3 g_pdmR3DevHlpUnTrusted;
1008extern const PDMPICHLPR3 g_pdmR3DevPicHlp;
1009extern const PDMAPICHLPR3 g_pdmR3DevApicHlp;
1010extern const PDMIOAPICHLPR3 g_pdmR3DevIoApicHlp;
1011extern const PDMPCIHLPR3 g_pdmR3DevPciHlp;
1012extern const PDMDMACHLP g_pdmR3DevDmacHlp;
1013extern const PDMRTCHLP g_pdmR3DevRtcHlp;
1014#endif
1015
1016
1017/*******************************************************************************
1018* Defined Constants And Macros *
1019*******************************************************************************/
1020/** @def PDMDEV_ASSERT_DEVINS
1021 * Asserts the validity of the device instance.
1022 */
1023#ifdef VBOX_STRICT
1024# define PDMDEV_ASSERT_DEVINS(pDevIns) \
1025 do { \
1026 AssertPtr(pDevIns); \
1027 Assert(pDevIns->u32Version == PDM_DEVINS_VERSION); \
1028 Assert(pDevIns->CTX_SUFF(pvInstanceData) == (void *)&pDevIns->achInstanceData[0]); \
1029 } while (0)
1030#else
1031# define PDMDEV_ASSERT_DEVINS(pDevIns) do { } while (0)
1032#endif
1033
1034
1035/*******************************************************************************
1036* Internal Functions *
1037*******************************************************************************/
1038#ifdef IN_RING3
1039int pdmR3CritSectInit(PVM pVM);
1040int pdmR3CritSectTerm(PVM pVM);
1041void pdmR3CritSectRelocate(PVM pVM);
1042int pdmR3CritSectInitDevice(PVM pVM, PPDMDEVINS pDevIns, PPDMCRITSECT pCritSect, const char *pszName);
1043int pdmR3CritSectDeleteDevice(PVM pVM, PPDMDEVINS pDevIns);
1044
1045int pdmR3DevInit(PVM pVM);
1046PPDMDEV pdmR3DevLookup(PVM pVM, const char *pszName);
1047int pdmR3DevFindLun(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PPDMLUN *ppLun);
1048DECLCALLBACK(bool) pdmR3DevHlpQueueConsumer(PVM pVM, PPDMQUEUEITEMCORE pItem);
1049
1050int pdmR3UsbLoadModules(PVM pVM);
1051int pdmR3UsbInstantiateDevices(PVM pVM);
1052PPDMUSB pdmR3UsbLookup(PVM pVM, const char *pszName);
1053int pdmR3UsbFindLun(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PPDMLUN *ppLun);
1054int pdmR3UsbRegisterHub(PVM pVM, PPDMDRVINS pDrvIns, uint32_t fVersions, uint32_t cPorts, PCPDMUSBHUBREG pUsbHubReg, PPCPDMUSBHUBHLP ppUsbHubHlp);
1055int pdmR3UsbVMInitComplete(PVM pVM);
1056
1057int pdmR3DrvInit(PVM pVM);
1058int pdmR3DrvDetach(PPDMDRVINS pDrvIns, uint32_t fFlags);
1059void pdmR3DrvDestroyChain(PPDMDRVINS pDrvIns, uint32_t fFlags);
1060PPDMDRV pdmR3DrvLookup(PVM pVM, const char *pszName);
1061
1062int pdmR3LdrInitU(PUVM pUVM);
1063void pdmR3LdrTermU(PUVM pUVM);
1064char * pdmR3FileR3(const char *pszFile, bool fShared = false);
1065int pdmR3LoadR3U(PUVM pUVM, const char *pszFilename, const char *pszName);
1066
1067void pdmR3QueueRelocate(PVM pVM, RTGCINTPTR offDelta);
1068
1069int pdmR3ThreadCreateDevice(PVM pVM, PPDMDEVINS pDevIns, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADDEV pfnThread,
1070 PFNPDMTHREADWAKEUPDEV pfnWakeup, size_t cbStack, RTTHREADTYPE enmType, const char *pszName);
1071int pdmR3ThreadCreateUsb(PVM pVM, PPDMDRVINS pUsbIns, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADUSB pfnThread,
1072 PFNPDMTHREADWAKEUPUSB pfnWakeup, size_t cbStack, RTTHREADTYPE enmType, const char *pszName);
1073int pdmR3ThreadCreateDriver(PVM pVM, PPDMDRVINS pDrvIns, PPPDMTHREAD ppThread, void *pvUser, PFNPDMTHREADDRV pfnThread,
1074 PFNPDMTHREADWAKEUPDRV pfnWakeup, size_t cbStack, RTTHREADTYPE enmType, const char *pszName);
1075int pdmR3ThreadDestroyDevice(PVM pVM, PPDMDEVINS pDevIns);
1076int pdmR3ThreadDestroyUsb(PVM pVM, PPDMUSBINS pUsbIns);
1077int pdmR3ThreadDestroyDriver(PVM pVM, PPDMDRVINS pDrvIns);
1078void pdmR3ThreadDestroyAll(PVM pVM);
1079int pdmR3ThreadResumeAll(PVM pVM);
1080int pdmR3ThreadSuspendAll(PVM pVM);
1081
1082#ifdef VBOX_WITH_PDM_ASYNC_COMPLETION
1083int pdmR3AsyncCompletionInit(PVM pVM);
1084int pdmR3AsyncCompletionTerm(PVM pVM);
1085#endif
1086
1087#endif /* IN_RING3 */
1088
1089void pdmLock(PVM pVM);
1090int pdmLockEx(PVM pVM, int rc);
1091void pdmUnlock(PVM pVM);
1092
1093/** @} */
1094
1095RT_C_DECLS_END
1096
1097#endif
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