- Timestamp:
- Aug 3, 2007 12:11:38 AM (17 years ago)
- Location:
- trunk
- Files:
-
- 14 edited
- 1 copied
Legend:
- Unmodified
- Added
- Removed
-
trunk/include/VBox/pdm.h
r4011 r4013 22 22 #define ___VBox_pdm_h 23 23 24 #include <VBox/pdmapi.h> 24 25 #include <VBox/pdmqueue.h> 25 26 #include <VBox/pdmcritsect.h> … … 30 31 #include <VBox/pdmusb.h> 31 32 #include <VBox/pdmsrv.h> 32 33 __BEGIN_DECLS34 35 /** @defgroup grp_pdm The Pluggable Device Manager API36 * @{37 */38 33 39 34 /** Source position. … … 49 44 #define PDM_SRC_POS_ARGS RT_SRC_POS_ARGS 50 45 51 52 53 /**54 * Gets the pending interrupt.55 *56 * @returns VBox status code.57 * @param pVM VM handle.58 * @param pu8Interrupt Where to store the interrupt on success.59 */60 PDMDECL(int) PDMGetInterrupt(PVM pVM, uint8_t *pu8Interrupt);61 62 /**63 * Sets the pending ISA interrupt.64 *65 * @returns VBox status code.66 * @param pVM VM handle.67 * @param u8Irq The IRQ line.68 * @param u8Level The new level. See the PDM_IRQ_LEVEL_* \#defines.69 */70 PDMDECL(int) PDMIsaSetIrq(PVM pVM, uint8_t u8Irq, uint8_t u8Level);71 72 /**73 * Sets the pending I/O APIC interrupt.74 *75 * @returns VBox status code.76 * @param pVM VM handle.77 * @param u8Irq The IRQ line.78 * @param u8Level The new level. See the PDM_IRQ_LEVEL_* \#defines.79 */80 PDMDECL(int) PDMIoApicSetIrq(PVM pVM, uint8_t u8Irq, uint8_t u8Level);81 82 /**83 * Set the APIC base.84 *85 * @returns VBox status code.86 * @param pVM VM handle.87 * @param u64Base The new base.88 */89 PDMDECL(int) PDMApicSetBase(PVM pVM, uint64_t u64Base);90 91 /**92 * Get the APIC base.93 *94 * @returns VBox status code.95 * @param pVM VM handle.96 * @param pu64Base Where to store the APIC base.97 */98 PDMDECL(int) PDMApicGetBase(PVM pVM, uint64_t *pu64Base);99 100 /**101 * Set the TPR (task priority register?).102 *103 * @returns VBox status code.104 * @param pVM VM handle.105 * @param u8TPR The new TPR.106 */107 PDMDECL(int) PDMApicSetTPR(PVM pVM, uint8_t u8TPR);108 109 /**110 * Get the TPR (task priority register?).111 *112 * @returns The current TPR.113 * @param pVM VM handle.114 * @param pu8TPR Where to store the TRP.115 */116 PDMDECL(int) PDMApicGetTPR(PVM pVM, uint8_t *pu8TPR);117 118 119 #ifdef IN_RING3120 /** @defgroup grp_pdm_r3 The PDM Host Context Ring-3 API121 * @ingroup grp_pdm122 * @{123 */124 125 /**126 * Initializes the PDM.127 *128 * @returns VBox status code.129 * @param pVM The VM to operate on.130 */131 PDMR3DECL(int) PDMR3Init(PVM pVM);132 133 /**134 * This function will notify all the devices and their135 * attached drivers about the VM now being powered on.136 *137 * @param pVM VM Handle.138 */139 PDMR3DECL(void) PDMR3PowerOn(PVM pVM);140 141 /**142 * This function will notify all the devices and their143 * attached drivers about the VM now being reset.144 *145 * @param pVM VM Handle.146 */147 PDMR3DECL(void) PDMR3Reset(PVM pVM);148 149 /**150 * This function will notify all the devices and their151 * attached drivers about the VM now being suspended.152 *153 * @param pVM VM Handle.154 */155 PDMR3DECL(void) PDMR3Suspend(PVM pVM);156 157 /**158 * This function will notify all the devices and their159 * attached drivers about the VM now being resumed.160 *161 * @param pVM VM Handle.162 */163 PDMR3DECL(void) PDMR3Resume(PVM pVM);164 165 /**166 * This function will notify all the devices and their167 * attached drivers about the VM being powered off.168 *169 * @param pVM VM Handle.170 */171 PDMR3DECL(void) PDMR3PowerOff(PVM pVM);172 173 174 /**175 * Applies relocations to GC modules.176 *177 * This must be done very early in the relocation178 * process so that components can resolve GC symbols during relocation.179 *180 * @param pVM VM handle.181 * @param offDelta Relocation delta relative to old location.182 */183 PDMR3DECL(void) PDMR3LdrRelocate(PVM pVM, RTGCINTPTR offDelta);184 185 /**186 * Applies relocations to data and code managed by this187 * component. This function will be called at init and188 * whenever the VMM need to relocate it self inside the GC.189 *190 * @param pVM VM handle.191 * @param offDelta Relocation delta relative to old location.192 */193 PDMR3DECL(void) PDMR3Relocate(PVM pVM, RTGCINTPTR offDelta);194 195 /**196 * Terminates the PDM.197 *198 * Termination means cleaning up and freeing all resources,199 * the VM it self is at this point powered off or suspended.200 *201 * @returns VBox status code.202 * @param pVM The VM to operate on.203 */204 PDMR3DECL(int) PDMR3Term(PVM pVM);205 206 207 /**208 * Get the address of a symbol in a given HC ring-3 module.209 *210 * @returns VBox status code.211 * @param pVM VM handle.212 * @param pszModule Module name.213 * @param pszSymbol Symbol name. If it's value is less than 64k it's treated like a214 * ordinal value rather than a string pointer.215 * @param ppvValue Where to store the symbol value.216 */217 PDMR3DECL(int) PDMR3GetSymbolR3(PVM pVM, const char *pszModule, const char *pszSymbol, void **ppvValue);218 219 /**220 * Get the address of a symbol in a given HC ring-0 module.221 *222 * @returns VBox status code.223 * @param pVM VM handle.224 * @param pszModule Module name. If NULL the main R0 module (VMMR0.r0) is assumed.225 * @param pszSymbol Symbol name. If it's value is less than 64k it's treated like a226 * ordinal value rather than a string pointer.227 * @param ppvValue Where to store the symbol value.228 */229 PDMR3DECL(int) PDMR3GetSymbolR0(PVM pVM, const char *pszModule, const char *pszSymbol, PRTR0PTR ppvValue);230 231 /**232 * Same as PDMR3GetSymbolR0 except that the module will be attempted loaded if not found.233 *234 * @returns VBox status code.235 * @param pVM VM handle.236 * @param pszModule Module name. If NULL the main R0 module (VMMR0.r0) is assumed.237 * @param pszSymbol Symbol name. If it's value is less than 64k it's treated like a238 * ordinal value rather than a string pointer.239 * @param ppvValue Where to store the symbol value.240 */241 PDMR3DECL(int) PDMR3GetSymbolR0Lazy(PVM pVM, const char *pszModule, const char *pszSymbol, PRTR0PTR ppvValue);242 243 /**244 * Loads a module into the guest context (i.e. into the Hypervisor memory region).245 *246 * The external (to PDM) use of this interface is to load VMMGC.gc.247 *248 * @returns VBox status code.249 * @param pVM The VM to load it into.250 * @param pszFilename Filename of the module binary.251 * @param pszName Module name. Case sensitive and the length is limited!252 */253 PDMR3DECL(int) PDMR3LoadGC(PVM pVM, const char *pszFilename, const char *pszName);254 255 /**256 * Get the address of a symbol in a given GC module.257 *258 * @returns VBox status code.259 * @param pVM VM handle.260 * @param pszModule Module name. If NULL the main GC module (VMMGC.gc) is assumed.261 * @param pszSymbol Symbol name. If it's value is less than 64k it's treated like a262 * ordinal value rather than a string pointer.263 * @param pGCPtrValue Where to store the symbol value.264 */265 PDMR3DECL(int) PDMR3GetSymbolGC(PVM pVM, const char *pszModule, const char *pszSymbol, PRTGCPTR pGCPtrValue);266 267 /**268 * Same as PDMR3GetSymbolGC except that the module will be attempted loaded if not found.269 *270 * @returns VBox status code.271 * @param pVM VM handle.272 * @param pszModule Module name. If NULL the main GC module (VMMGC.gc) is assumed.273 * @param pszSymbol Symbol name. If it's value is less than 64k it's treated like a274 * ordinal value rather than a string pointer.275 * @param pGCPtrValue Where to store the symbol value.276 */277 PDMR3DECL(int) PDMR3GetSymbolGCLazy(PVM pVM, const char *pszModule, const char *pszSymbol, PRTGCPTR pGCPtrValue);278 279 /**280 * Queries module information from an EIP.281 *282 * This is typically used to locate a crash address.283 *284 * @returns VBox status code.285 * @param pVM VM handle286 * @param uEIP EIP to locate.287 * @param pszModName Where to store the module name.288 * @param cchModName Size of the module name buffer.289 * @param pMod Base address of the module.290 * @param pszNearSym1 Name of the closes symbol from below.291 * @param cchNearSym1 Size of the buffer pointed to by pszNearSym1.292 * @param pNearSym1 The address of pszNearSym1.293 * @param pszNearSym2 Name of the closes symbol from below.294 * @param cchNearSym2 Size of the buffer pointed to by pszNearSym2.295 * @param pNearSym2 The address of pszNearSym2.296 */297 PDMR3DECL(int) PDMR3QueryModFromEIP(PVM pVM, uint32_t uEIP,298 char *pszModName, unsigned cchModName, RTGCPTR *pMod,299 char *pszNearSym1, unsigned cchNearSym1, RTGCPTR *pNearSym1,300 char *pszNearSym2, unsigned cchNearSym2, RTGCPTR *pNearSym2);301 302 303 /**304 * Module enumeration callback function.305 *306 * @returns VBox status.307 * Failure will stop the search and return the return code.308 * Warnings will be ignored and not returned.309 * @param pVM VM Handle.310 * @param pszFilename Module filename.311 * @param pszName Module name. (short and unique)312 * @param ImageBase Address where to executable image is loaded.313 * @param cbImage Size of the executable image.314 * @param fGC Set if guest context, clear if host context.315 * @param pvArg User argument.316 */317 typedef DECLCALLBACK(int) FNPDMR3ENUM(PVM pVM, const char *pszFilename, const char *pszName, RTUINTPTR ImageBase, size_t cbImage, bool fGC);318 /** Pointer to a FNPDMR3ENUM() function. */319 typedef FNPDMR3ENUM *PFNPDMR3ENUM;320 321 322 /**323 * Enumerate all PDM modules.324 *325 * @returns VBox status.326 * @param pVM VM Handle.327 * @param pfnCallback Function to call back for each of the modules.328 * @param pvArg User argument.329 */330 PDMR3DECL(int) PDMR3EnumModules(PVM pVM, PFNPDMR3ENUM pfnCallback, void *pvArg);331 332 333 /**334 * Queries the base interace of a device instance.335 *336 * The caller can use this to query other interfaces the device implements337 * and use them to talk to the device.338 *339 * @returns VBox status code.340 * @param pVM VM handle.341 * @param pszDevice Device name.342 * @param iInstance Device instance.343 * @param ppBase Where to store the pointer to the base device interface on success.344 * @remark We're not doing any locking ATM, so don't try call this at times when the345 * device chain is known to be updated.346 */347 PDMR3DECL(int) PDMR3QueryDevice(PVM pVM, const char *pszDevice, unsigned iInstance, PPDMIBASE *ppBase);348 349 /**350 * Queries the base interface of a device LUN.351 *352 * This differs from PDMR3QueryLun by that it returns the interface on the353 * device and not the top level driver.354 *355 * @returns VBox status code.356 * @param pVM VM Handle.357 * @param pszDevice Device name.358 * @param iInstance Device instance.359 * @param iLun The Logical Unit to obtain the interface of.360 * @param ppBase Where to store the base interface pointer.361 * @remark We're not doing any locking ATM, so don't try call this at times when the362 * device chain is known to be updated.363 */364 PDMR3DECL(int) PDMR3QueryDeviceLun(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PPDMIBASE *ppBase);365 366 /**367 * Query the interface of the top level driver on a LUN.368 *369 * @returns VBox status code.370 * @param pVM VM Handle.371 * @param pszDevice Device name.372 * @param iInstance Device instance.373 * @param iLun The Logical Unit to obtain the interface of.374 * @param ppBase Where to store the base interface pointer.375 * @remark We're not doing any locking ATM, so don't try call this at times when the376 * device chain is known to be updated.377 */378 PDMR3DECL(int) PDMR3QueryLun(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PPDMIBASE *ppBase);379 380 /**381 * Attaches a preconfigured driver to an existing device instance.382 *383 * This is used to change drivers and suchlike at runtime.384 *385 * @returns VBox status code.386 * @param pVM VM Handle.387 * @param pszDevice Device name.388 * @param iInstance Device instance.389 * @param iLun The Logical Unit to obtain the interface of.390 * @param ppBase Where to store the base interface pointer. Optional.391 * @thread EMT392 */393 PDMR3DECL(int) PDMR3DeviceAttach(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PPDMIBASE *ppBase);394 395 /**396 * Detaches a driver from an existing device instance.397 *398 * This is used to change drivers and suchlike at runtime.399 *400 * @returns VBox status code.401 * @param pVM VM Handle.402 * @param pszDevice Device name.403 * @param iInstance Device instance.404 * @param iLun The Logical Unit to obtain the interface of.405 * @thread EMT406 */407 PDMR3DECL(int) PDMR3DeviceDetach(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun);408 409 /**410 * Executes pending DMA transfers.411 * Forced Action handler.412 *413 * @param pVM VM handle.414 */415 PDMR3DECL(void) PDMR3DmaRun(PVM pVM);416 417 /**418 * Call polling function.419 *420 * @param pVM VM handle.421 */422 PDMR3DECL(void) PDMR3Poll(PVM pVM);423 424 /**425 * Service a VMMCALLHOST_PDM_LOCK call.426 *427 * @returns VBox status code.428 * @param pVM The VM handle.429 */430 PDMR3DECL(int) PDMR3LockCall(PVM pVM);431 432 /** @} */433 46 #endif 434 47 435 436 #ifdef IN_GC437 /** @defgroup grp_pdm_gc The PDM Guest Context API438 * @ingroup grp_pdm439 * @{440 */441 /** @} */442 #endif443 444 __END_DECLS445 446 /** @} */447 448 #endif449 -
trunk/include/VBox/pdmapi.h
r4011 r4013 1 1 /** @file 2 * PDM - Pluggable Device Manager. 2 * PDM - Pluggable Device Manager, Core API. 3 * 4 * The 'Core API' has been put in a different header because everyone 5 * is currently including pdm.h. So, pdm.h is for including all of the 6 * PDM stuff, while pdmapi.h is for the core stuff. 3 7 */ 4 8 … … 19 23 */ 20 24 21 #ifndef ___VBox_pdm_h 22 #define ___VBox_pdm_h 23 24 #include <VBox/pdmqueue.h> 25 #include <VBox/pdmcritsect.h> 26 #include <VBox/pdmthread.h> 27 #include <VBox/pdmifs.h> 28 #include <VBox/pdmdrv.h> 29 #include <VBox/pdmdev.h> 30 #include <VBox/pdmusb.h> 31 #include <VBox/pdmsrv.h> 25 #ifndef ___VBox_pdmapi_h 26 #define ___VBox_pdmapi_h 27 28 #include <VBox/types.h> 32 29 33 30 __BEGIN_DECLS … … 36 33 * @{ 37 34 */ 38 39 /** Source position.40 * @deprecated Use RT_SRC_POS */41 #define PDM_SRC_POS RT_SRC_POS42 43 /** Source position declaration.44 * @deprecated Use RT_SRC_POS_DECL */45 #define PDM_SRC_POS_DECL RT_SRC_POS_DECL46 47 /** Source position arguments.48 * @deprecated Use RT_SRC_POS_ARGS */49 #define PDM_SRC_POS_ARGS RT_SRC_POS_ARGS50 51 52 35 53 36 /** … … 345 328 * device chain is known to be updated. 346 329 */ 347 PDMR3DECL(int) PDMR3QueryDevice(PVM pVM, const char *pszDevice, unsigned iInstance, PP DMIBASE *ppBase);330 PDMR3DECL(int) PDMR3QueryDevice(PVM pVM, const char *pszDevice, unsigned iInstance, PPPDMIBASE ppBase); 348 331 349 332 /** … … 362 345 * device chain is known to be updated. 363 346 */ 364 PDMR3DECL(int) PDMR3QueryDeviceLun(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PP DMIBASE *ppBase);347 PDMR3DECL(int) PDMR3QueryDeviceLun(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PPPDMIBASE ppBase); 365 348 366 349 /** … … 376 359 * device chain is known to be updated. 377 360 */ 378 PDMR3DECL(int) PDMR3QueryLun(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PP DMIBASE *ppBase);361 PDMR3DECL(int) PDMR3QueryLun(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PPPDMIBASE ppBase); 379 362 380 363 /** … … 391 374 * @thread EMT 392 375 */ 393 PDMR3DECL(int) PDMR3DeviceAttach(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PP DMIBASE *ppBase);376 PDMR3DECL(int) PDMR3DeviceAttach(PVM pVM, const char *pszDevice, unsigned iInstance, unsigned iLun, PPPDMIBASE ppBase); 394 377 395 378 /** -
trunk/include/VBox/pdmifs.h
r4011 r4013 153 153 DECLR3CALLBACKMEMBER(void *, pfnQueryInterface,(struct PDMIBASE *pInterface, PDMINTERFACE enmInterface)); 154 154 } PDMIBASE; 155 /** Pointer to a PDM Driver Base Interface. */156 typedef PDMIBASE *PPDMIBASE;157 155 158 156 -
trunk/include/VBox/types.h
r3852 r4013 118 118 } VMSTATE; 119 119 120 121 /** Pointer to a PDM Driver Base Interface. */ 122 typedef struct PDMIBASE *PPDMIBASE; 123 /** Pointer to a pointer to a PDM Driver Base Interface. */ 124 typedef PPDMIBASE *PPPDMIBASE; 120 125 121 126 /** Pointer to a PDM Device Instance. */ -
trunk/src/VBox/VMM/EM.cpp
r3184 r4013 46 46 #include <VBox/tm.h> 47 47 #include <VBox/mm.h> 48 #include <VBox/pdm.h> 48 #include <VBox/ssm.h> 49 #include <VBox/pdmapi.h> 50 #include <VBox/pdmcritsect.h> 51 #include <VBox/pdmqueue.h> 49 52 #include <VBox/hwaccm.h> 50 53 #include <VBox/patm.h> -
trunk/src/VBox/VMM/PGM.cpp
r3776 r4013 125 125 #include <VBox/sup.h> 126 126 #include <VBox/mm.h> 127 #include <VBox/pdm.h>128 127 #include <VBox/em.h> 129 128 #include <VBox/stam.h> -
trunk/src/VBox/VMM/PGMHandler.cpp
r2981 r4013 31 31 #include <VBox/sup.h> 32 32 #include <VBox/mm.h> 33 #include <VBox/pdm.h>34 33 #include <VBox/em.h> 35 34 #include <VBox/stam.h> -
trunk/src/VBox/VMM/PGMInternal.h
r3776 r4013 30 30 #include <VBox/vmm.h> 31 31 #include <VBox/mm.h> 32 #include <VBox/pdm.h> 32 #include <VBox/pdmcritsect.h> 33 #include <VBox/pdmapi.h> 34 #include <VBox/dis.h> 35 #include <VBox/dbgf.h> 33 36 #include <VBox/log.h> 34 37 #include <iprt/avl.h> -
trunk/src/VBox/VMM/PGMPhys.cpp
r2981 r4013 30 30 #include <VBox/sup.h> 31 31 #include <VBox/mm.h> 32 #include <VBox/pdm.h>33 32 #include <VBox/stam.h> 34 33 #include <VBox/rem.h> -
trunk/src/VBox/VMM/SELM.cpp
r3724 r4013 28 28 #include <VBox/stam.h> 29 29 #include <VBox/mm.h> 30 #include <VBox/ pdm.h>30 #include <VBox/ssm.h> 31 31 #include <VBox/pgm.h> 32 32 #include <VBox/trpm.h> -
trunk/src/VBox/VMM/TRPM.cpp
r3696 r4013 55 55 #include <VBox/cpum.h> 56 56 #include <VBox/selm.h> 57 #include <VBox/pdm.h> 57 #include <VBox/ssm.h> 58 #include <VBox/pdmapi.h> 58 59 #include <VBox/pgm.h> 60 #include <VBox/dbgf.h> 59 61 #include <VBox/mm.h> 60 62 #include <VBox/stam.h> -
trunk/src/VBox/VMM/VM.cpp
r3696 r4013 33 33 #include <VBox/dbgf.h> 34 34 #include <VBox/pgm.h> 35 #include <VBox/pdm.h> 35 #include <VBox/pdmapi.h> 36 #include <VBox/pdmcritsect.h> 36 37 #include <VBox/em.h> 37 38 #include <VBox/rem.h> … … 41 42 #include <VBox/csam.h> 42 43 #include <VBox/iom.h> 44 #include <VBox/ssm.h> 43 45 #include <VBox/hwaccm.h> 44 46 #include "VMInternal.h" -
trunk/src/VBox/VMM/VMEmt.cpp
r3273 r4013 28 28 #include <VBox/dbgf.h> 29 29 #include <VBox/em.h> 30 #include <VBox/pdm .h>30 #include <VBox/pdmapi.h> 31 31 #include <VBox/rem.h> 32 32 #include "VMInternal.h" -
trunk/src/VBox/VMM/VMM.cpp
r3753 r4013 126 126 #include <VBox/pgm.h> 127 127 #include <VBox/cfgm.h> 128 #include <VBox/pdm.h> 128 #include <VBox/pdmqueue.h> 129 #include <VBox/pdmapi.h> 129 130 #include <VBox/cpum.h> 130 131 #include <VBox/mm.h> -
trunk/src/VBox/VMM/VMMAll/PGMAllPhys.cpp
r2981 r4013 36 36 #include <VBox/trpm.h> 37 37 #include <VBox/vmm.h> 38 #include <VBox/iom.h> 38 39 #include "PGMInternal.h" 39 40 #include <VBox/vm.h>
Note:
See TracChangeset
for help on using the changeset viewer.