Changeset 35358 in vbox for trunk/src/VBox
- Timestamp:
- Dec 28, 2010 7:58:40 AM (14 years ago)
- Location:
- trunk/src/VBox
- Files:
-
- 17 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/Devices/Bus/DevPciIch9.cpp
r35357 r35358 296 296 { 297 297 int rc = VINF_SUCCESS; 298 299 if (pAddr->iRegister > 0xff) 300 { 301 LogRel(("PCI: attempt to write extended register: %x (%d) <- val\n", pAddr->iRegister, cb, val)); 302 goto out; 303 } 298 304 299 305 if (pAddr->iBus != 0) … … 927 933 static DECLCALLBACK(int) ich9pciGenericSaveExec(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, PSSMHANDLE pSSM) 928 934 { 929 Assert(!PCIIsPassthrough(pPciDev));930 935 return SSMR3PutMem(pSSM, &pPciDev->config[0], sizeof(pPciDev->config)); 931 936 } … … 1180 1185 */ 1181 1186 uint8_t const fBridge = fIsBridge ? 2 : 1; 1182 Assert(!PCIIsPassthrough(pDev));1183 1187 uint8_t *pbDstConfig = &pDev->config[0]; 1184 1185 1188 for (uint32_t i = 0; i < RT_ELEMENTS(s_aFields); i++) 1186 1189 if (s_aFields[i].fBridge & fBridge) … … 1376 1379 1377 1380 /* commit the loaded device config. */ 1378 Assert(!PCIIsPassthrough(pDev));1379 1381 pciR3CommonRestoreConfig(pDev, &DevTmp.config[0], false ); /** @todo fix bridge fun! */ 1380 1382 … … 1408 1410 static DECLCALLBACK(int) ich9pciGenericLoadExec(PPDMDEVINS pDevIns, PPCIDEVICE pPciDev, PSSMHANDLE pSSM) 1409 1411 { 1410 Assert(!PCIIsPassthrough(pPciDev));1411 1412 return SSMR3GetMem(pSSM, &pPciDev->config[0], sizeof(pPciDev->config)); 1412 1413 } … … 1624 1625 1625 1626 AssertMsg(pGlobals->uBus < 255, ("Too many bridges on the bus\n")); 1626 #if 01627 /* We assign bridges starting from 16, to allow real PCI1628 device assignment into lower slots */1629 if (pGlobals->uBus == 0)1630 pGlobals->uBus = 16;1631 else1632 pGlobals->uBus++;1633 #else1634 1627 pGlobals->uBus++; 1635 #endif1636 1628 ich9pciBiosInitBridge(pGlobals, uBus, uDevFn, cBridgeDepth, paBridgePositions); 1637 1629 break; … … 1743 1735 } 1744 1736 1745 AssertMsgReturn(u32Address + len <= 256, ("Read after end of PCI config space\n"),1746 0);1747 1748 1749 1737 if ( PCIIsMsiCapable(aDev) 1750 1738 && (u32Address >= aDev->Int.s.u8MsiCapOffset) … … 1763 1751 } 1764 1752 1753 AssertMsgReturn(u32Address + len <= 256, ("Read after end of PCI config space\n"), 1754 0); 1765 1755 switch (len) 1766 1756 { … … 1818 1808 { 1819 1809 Assert(len <= 4); 1820 Assert(!PCIIsPassthrough(aDev));1821 1810 1822 1811 if ((u32Address + len) > 256 && (u32Address + len) < 4096) 1823 1812 { 1824 LogRel(("Write to extended registers falled back to the generic code: %s register %d len=%d\n", 1825 aDev->name, u32Address, len)); 1826 return; 1813 AssertMsgReturnVoid(false, ("Write to extended registers falled back to generic code\n")); 1827 1814 } 1828 1815 … … 2143 2130 if (pPciDev != NULL) 2144 2131 { 2145 if (PCIIsPassthrough(pPciDev))2146 {2147 printIndent(pHlp, iIndent);2148 /**2149 * For passthrough devices MSI/MSI-X mostly reflects the way interrupts delivered to the guest,2150 * as host driver handles real devices interrupts.2151 */2152 pHlp->pfnPrintf(pHlp, "%02x:%02x:%02x %s: %s%s - PASSTHROUGH\n",2153 pBus->iBus, (iDev >> 3) & 0xff, iDev & 0x7,2154 pPciDev->name,2155 PCIIsMsiCapable(pPciDev) ? " MSI" : "",2156 PCIIsMsixCapable(pPciDev) ? " MSI-X" : ""2157 );2158 continue;2159 }2160 2161 2132 printIndent(pHlp, iIndent); 2162 2133 pHlp->pfnPrintf(pHlp, "%02x:%02x:%02x %s: %04x-%04x%s%s", -
trunk/src/VBox/Devices/Bus/DevPciRaw.cpp
r35357 r35358 20 20 *******************************************************************************/ 21 21 #define LOG_GROUP LOG_GROUP_DEV_PCI 22 #include <VBox/vmm/pdmdev.h> 22 23 #include <VBox/log.h> 23 #define PCI_INCLUDE_PRIVATE24 #include <VBox/pci.h>25 #include <VBox/vmm/pdmdev.h>26 24 #include <VBox/vmm/stam.h> 27 #include <VBox/vmm/pdmpci.h>28 25 #include <iprt/assert.h> 29 26 #include <iprt/string.h> 30 #include <iprt/uuid.h>31 32 27 33 28 #include "VBoxDD.h" … … 43 38 *******************************************************************************/ 44 39 40 /* Temporary PDM stubs */ 41 typedef struct PDMPCIRAWREG 42 { 43 /** Struct version+magic number (PDM_PCIRAWREG_VERSION). */ 44 uint32_t u32Version; 45 46 } PDMPCIRAWREG; 47 /** Pointer to a raw PCI registration structure. */ 48 typedef PDMPCIRAWREG *PPDMPCIRAWREG; 49 50 /** Current PDMPCIRAWREG version number. */ 51 #define PDM_PCIRAWREG_VERSION PDM_VERSION_MAKE(0xffe3, 1, 0) 52 53 struct PDMPCIRAWHLPRC 54 { 55 uint32_t u32Version; 56 }; 57 typedef RCPTRTYPE(PDMPCIRAWHLPRC *) PPDMPCIRAWHLPRC; 58 typedef RCPTRTYPE(const PDMPCIRAWHLPRC *) PCPDMPCIRAWHLPRC; 59 60 struct PDMPCIRAWHLPR0 61 { 62 uint32_t u32Version; 63 }; 64 typedef R0PTRTYPE(PDMPCIRAWHLPR0 *) PPDMPCIRAWHLPR0; 65 typedef R0PTRTYPE(const PDMPCIRAWHLPR0 *) PCPDMPCIRAWHLPR0; 66 67 struct PDMPCIRAWHLPR3 68 { 69 uint32_t u32Version; 70 /** 71 * Gets the address of the RC PCI raw helpers. 72 * 73 * This should be called at both construction and relocation time 74 * to obtain the correct address of the RC helpers. 75 * 76 * @returns RC pointer to the PCI raw helpers. 77 * @param pDevIns Device instance of the raw PCI device. 78 */ 79 DECLR3CALLBACKMEMBER(PCPDMPCIRAWHLPRC, pfnGetRCHelpers,(PPDMDEVINS pDevIns)); 80 81 /** 82 * Gets the address of the R0 PCI raw helpers. 83 * 84 * This should be called at both construction and relocation time 85 * to obtain the correct address of the R0 helpers. 86 * 87 * @returns R0 pointer to the PCI raw helpers. 88 * @param pDevIns Device instance of the raw PCI device. 89 */ 90 DECLR3CALLBACKMEMBER(PCPDMPCIRAWHLPR0, pfnGetR0Helpers,(PPDMDEVINS pDevIns)); 91 92 /** Just a safety precaution. */ 93 uint32_t u32TheEnd; 94 }; 95 /** Pointer to raw PCI R3 helpers. */ 96 typedef R3PTRTYPE(PDMPCIRAWHLPR3 *) PPDMPCIRAWHLPR3; 97 /** Pointer to const raw PCI R3 helpers. */ 98 typedef R3PTRTYPE(const PDMPCIRAWHLPR3 *) PCPDMPCIRAWHLPR3; 99 100 /** 101 * @copydoc PDMDEVHLPR3::pfnPciRawRegister 102 */ 103 DECLINLINE(int) PDMDevHlpPciRawRegister(PPDMDEVINS pDevIns, PPDMPCIRAWREG pPciRawReg, PCPDMPCIRAWHLPR3 *ppPciRawHlpR3) 104 { 105 //return pDevIns->pHlpR3->pfnPciRawRegister(pDevIns, pPciRawReg, ppPciRawHlpR3); 106 return VINF_SUCCESS; 107 } 108 109 /* End of PDM stubs */ 110 45 111 typedef struct PciRawState 46 112 { … … 63 129 PCIDEVICE aPciDevice; 64 130 65 /* Device name, as provided by Main */66 char szDeviceName[64];67 131 /* Address of device on the host */ 68 int32_t i32HostDeviceAddress;132 PciBusAddress aHostDeviceAddress; 69 133 /* Address of device in the guest */ 70 int32_t i32GuestDeviceAddress;71 72 134 PciBusAddress aGuestDeviceAddress; 135 136 /* Global device lock */ 73 137 PDMCRITSECT csLock; 74 75 /**76 * Device port - LUN#0.77 *78 * @implements PDMIBASE79 * @implements PDMIPCIRAW80 */81 struct82 {83 /** The base interface for the PCI device port. */84 PDMIBASE IBase;85 /** The device port base interface. */86 PDMIPCIRAW IDevice;87 88 /** The base interface of the attached raw PCI driver. */89 R3PTRTYPE(PPDMIBASE) pDrvBase;90 /** The device interface of the attached raw PCI driver. */91 R3PTRTYPE(PPDMIPCIRAWCONNECTOR) pDrv;92 } Lun0;93 138 } PciRawState; 94 139 95 /** Pointer to the raw PCI instance data. */96 typedef PciRawState *PPciRawState;97 140 98 141 #ifndef VBOX_DEVICE_STRUCT_TESTCASE … … 107 150 RT_C_DECLS_END 108 151 152 /* 153 * Temporary control to disable locking if problems found 154 */ 109 155 DECLINLINE(int) pcirawLock(PciRawState* pThis, int rcBusy) 110 156 { … … 116 162 PDMCritSectLeave(&pThis->csLock); 117 163 } 164 118 165 119 166 PDMBOTHCBDECL(int) pcirawMMIORead(PPDMDEVINS pDevIns, … … 165 212 166 213 rc = pcirawLock(pThis, VINF_IOM_HC_MMIO_WRITE); 214 if (RT_UNLIKELY(rc != VINF_SUCCESS)) 167 215 return rc; 168 216 … … 283 331 } 284 332 285 static DECLCALLBACK(int) pcirawAttach(PPDMDEVINS pDevIns, unsigned iLUN, uint32_t fFlags)286 {287 PciRawState *pThis = PDMINS_2_DATA(pDevIns, PciRawState *);288 289 LogFlow(("pcirawAttach: LUN%d\n", iLUN));290 /* Not yet used */291 return 0;292 }293 294 static DECLCALLBACK(void) pcirawDetach(PPDMDEVINS pDevIns, unsigned iLUN, uint32_t fFlags)295 {296 PciRawState *pThis = PDMINS_2_DATA(pDevIns, PciRawState *);297 298 LogFlow(("pcirawDetach: LUN%d\n", iLUN));299 /* Not yet used */300 }301 302 303 333 /** 304 334 * Initialization routine. … … 307 337 * @param pDevIns The device instance data. 308 338 */ 309 static int pcirawInit(PPDMDEVINS pDevIns, PciBusAddress hostAddress , PciBusAddress guestAddress)339 static int pcirawInit(PPDMDEVINS pDevIns, PciBusAddress hostAddress) 310 340 { 311 341 unsigned i; … … 319 349 pThis->pDevInsRC = PDMDEVINS_2_RCPTR(pDevIns); 320 350 321 pThis->i32HostDeviceAddress = hostAddress.asLong(); 322 pThis->i32GuestDeviceAddress = guestAddress.asLong(); 351 pThis->aHostDeviceAddress.init(hostAddress); 323 352 324 353 pcirawReset(pDevIns); 325 354 326 355 return VINF_SUCCESS; 327 }328 329 330 static uint32_t pcirawConfigRead(PPCIDEVICE pPciDev, uint32_t Address, unsigned cb)331 {332 PPDMDEVINS pDevIns = pPciDev->pDevIns;333 PciRawState* pThis = PDMINS_2_DATA(pDevIns, PciRawState *);334 335 Log2(("rawpci: PCI config read: 0x%x (%d)\n", Address, cb));336 337 return 0;338 }339 340 static void pcirawConfigWrite(PPCIDEVICE pPciDev, uint32_t Address, uint32_t u32Value, unsigned cb)341 {342 PPDMDEVINS pDevIns = pPciDev->pDevIns;343 PciRawState *pThis = PDMINS_2_DATA(pDevIns, PciRawState *);344 345 Log2(("rawpci: PCI config write: 0x%x -> 0x%x (%d)\n", u32Value, Address, cb));346 }347 348 349 /**350 * @interface_method_impl{PDMIBASE,pfnQueryInterface}351 */352 static DECLCALLBACK(void *) pcirawQueryInterface(PPDMIBASE pInterface, const char *pszIID)353 {354 PciRawState* pThis = RT_FROM_CPP_MEMBER(pInterface, PciRawState, Lun0.IBase);355 PDMIBASE_RETURN_INTERFACE(pszIID, PDMIBASE, &pThis->Lun0.IBase);356 PDMIBASE_RETURN_INTERFACE(pszIID, PDMIPCIRAW, &pThis->Lun0.IDevice);357 return NULL;358 }359 360 static DECLCALLBACK(int) pcirawFoo(PPDMIPCIRAW pInterface)361 {362 return 0;363 356 } 364 357 … … 380 373 "GCEnabled\0" 381 374 "R0Enabled\0" 382 "DeviceName\0"383 "GuestPCIBusNo\0"384 "GuestPCIDeviceNo\0"385 "GuestPCIFunctionNo\0"386 375 "HostPCIBusNo\0" 387 376 "HostPCIDeviceNo\0" … … 401 390 N_("Configuration error: failed to read R0Enabled as boolean")); 402 391 403 rc = CFGMR3QueryString(pCfg, "DeviceName", pThis->szDeviceName, sizeof(pThis->szDeviceName)); 392 /* Obtain host device address */ 393 uint32_t u32Bus, u32Device, u32Fn; 394 rc = CFGMR3QueryU32(pCfg, "HostPCIBusNo", &u32Bus); 404 395 if (RT_FAILURE(rc)) 405 396 return PDMDEV_SET_ERROR(pDevIns, rc, 406 N_("Configuration error: failed to read DeviceName as string")); 407 408 PciBusAddress hostAddress, guestAddress; 409 410 /* Obtain device address info */ 411 uint32_t u32Bus, u32Device, u32Fn; 412 413 do { 414 rc = CFGMR3QueryU32(pCfg, "HostPCIBusNo", &u32Bus); 415 if (RT_FAILURE(rc)) 397 N_("Configuration error: Querying \"HostPCIBusNo\" as a int failed")); 398 rc = CFGMR3QueryU32(pCfg, "HostPCIDeviceNo", &u32Device); 399 if (RT_FAILURE(rc)) 400 return PDMDEV_SET_ERROR(pDevIns, rc, 401 N_("Configuration error: Querying \"HostPCIDeviceNo\" as a int failed")); 402 rc = CFGMR3QueryU32(pCfg, "HostPCIFunctionNo", &u32Fn); 403 if (RT_FAILURE(rc)) 404 return PDMDEV_SET_ERROR(pDevIns, rc, 405 N_("Configuration error: Querying \"HostPCIFunctionNo\" as a int failed")); 406 407 408 /* Initialize the device state */ 409 rc = pcirawInit(pDevIns, PciBusAddress(u32Bus, u32Device, u32Fn)); 410 if (RT_FAILURE(rc)) 411 return rc; 412 413 pThis->pDevInsR3 = pDevIns; 414 pThis->pDevInsR0 = PDMDEVINS_2_R0PTR(pDevIns); 415 pThis->pDevInsRC = PDMDEVINS_2_RCPTR(pDevIns); 416 417 /* 418 * Register the raw device and get helpers. 419 */ 420 PciRawReg.u32Version = PDM_PCIRAWREG_VERSION; 421 rc = PDMDevHlpPciRawRegister(pDevIns, &PciRawReg, &pThis->pPciRawHlpR3); 422 if (RT_FAILURE(rc)) 423 { 424 AssertMsgRC(rc, ("Cannot PciRawRegister: %Rrc\n", rc)); 425 return rc; 426 } 427 428 /* 429 * Initialize critical section. 430 */ 431 rc = PDMDevHlpCritSectInit(pDevIns, &pThis->csLock, RT_SRC_POS, "PCIRAW"); 432 if (RT_FAILURE(rc)) 433 return PDMDEV_SET_ERROR(pDevIns, rc, N_("Raw PCI device cannot initialize critical section")); 434 435 #if 0 436 /* 437 * Register IO/MMIO ranges for guest, basing on real device ranges. 438 */ 439 for (int iRegion = 0; iRegion < VBOX_PCI_NUM_REGIONS; iRegion++) 440 { 441 442 } 443 #endif 444 445 if (fRCEnabled) 446 { 447 pThis->pPciRawHlpRC = pThis->pPciRawHlpR3->pfnGetRCHelpers(pDevIns); 448 if (!pThis->pPciRawHlpRC) 416 449 { 417 PDMDEV_SET_ERROR(pDevIns, rc, 418 N_("Configuration error: Querying \"HostPCIBusNo\" as a int failed")); 419 break; 450 AssertReleaseMsgFailed(("cannot get RC helper\n")); 451 return VERR_INTERNAL_ERROR; 420 452 } 421 rc = CFGMR3QueryU32(pCfg, "HostPCIDeviceNo", &u32Device); 422 if (RT_FAILURE(rc)) 453 } 454 if (fR0Enabled) 455 { 456 pThis->pPciRawHlpR0 = pThis->pPciRawHlpR3->pfnGetR0Helpers(pDevIns); 457 if (!pThis->pPciRawHlpR0) 423 458 { 424 PDMDEV_SET_ERROR(pDevIns, rc, 425 N_("Configuration error: Querying \"HostPCIDeviceNo\" as a int failed")); 426 break; 459 AssertReleaseMsgFailed(("cannot get R0 helper\n")); 460 return VERR_INTERNAL_ERROR; 427 461 } 428 rc = CFGMR3QueryU32(pCfg, "HostPCIFunctionNo", &u32Fn); 429 if (RT_FAILURE(rc)) 430 { 431 PDMDEV_SET_ERROR(pDevIns, rc, 432 N_("Configuration error: Querying \"HostPCIFunctionNo\" as a int failed")); 433 break; 434 } 435 hostAddress = PciBusAddress(u32Bus, u32Device, u32Fn); 436 437 rc = CFGMR3QueryU32(pCfg, "GuestPCIBusNo", &u32Bus); 438 if (RT_FAILURE(rc)) 439 { 440 PDMDEV_SET_ERROR(pDevIns, rc, 441 N_("Configuration error: Querying \"GuestPCIBusNo\" as a int failed")); 442 break; 443 } 444 rc = CFGMR3QueryU32(pCfg, "GuestPCIDeviceNo", &u32Device); 445 if (RT_FAILURE(rc)) 446 { 447 PDMDEV_SET_ERROR(pDevIns, rc, 448 N_("Configuration error: Querying \"GuestPCIDeviceNo\" as a int failed")); 449 break; 450 } 451 rc = CFGMR3QueryU32(pCfg, "GuestPCIFunctionNo", &u32Fn); 452 if (RT_FAILURE(rc)) 453 { 454 PDMDEV_SET_ERROR(pDevIns, rc, 455 N_("Configuration error: Querying \"GuestPCIFunctionNo\" as a int failed")); 456 break; 457 } 458 guestAddress = PciBusAddress(u32Bus, u32Device, u32Fn); 459 460 /* Initialize the device state */ 461 rc = pcirawInit(pDevIns, hostAddress, guestAddress); 462 if (RT_FAILURE(rc)) 463 break; 464 465 pThis->pDevInsR3 = pDevIns; 466 pThis->pDevInsR0 = PDMDEVINS_2_R0PTR(pDevIns); 467 pThis->pDevInsRC = PDMDEVINS_2_RCPTR(pDevIns); 468 469 /* 470 * Register the raw device and get helpers. 471 */ 472 PciRawReg.u32Version = PDM_PCIRAWREG_VERSION; 473 rc = PDMDevHlpPciRawRegister(pDevIns, &PciRawReg, &pThis->pPciRawHlpR3); 474 if (RT_FAILURE(rc)) 475 { 476 AssertMsgRC(rc, ("Cannot PciRawRegister: %Rrc\n", rc)); 477 break; 478 } 479 480 /* 481 * Initialize critical section. 482 */ 483 rc = PDMDevHlpCritSectInit(pDevIns, &pThis->csLock, RT_SRC_POS, "PCIRAW"); 484 if (RT_FAILURE(rc)) 485 { 486 PDMDEV_SET_ERROR(pDevIns, rc, N_("Raw PCI device cannot initialize critical section")); 487 break; 488 } 489 490 /* Mark device as passthrough */ 491 PCISetPassthrough(&pThis->aPciDevice); 492 493 /* IBase */ 494 pThis->Lun0.IBase.pfnQueryInterface = pcirawQueryInterface; 495 pThis->Lun0.IDevice.pfnFoo = pcirawFoo; 496 497 /* 498 * Attach to the Main driver. 499 */ 500 rc = pDevIns->pHlpR3->pfnDriverAttach(pDevIns, 0 /*iLun*/, &pThis->Lun0.IBase, &pThis->Lun0.pDrvBase, "Device Port"); 501 if (RT_FAILURE(rc)) 502 { 503 rc = PDMDevHlpVMSetError(pDevIns, rc, RT_SRC_POS, N_("Raw PCI failed to attach Main driver")); 504 break; 505 } 506 507 pThis->Lun0.pDrv = PDMIBASE_QUERY_INTERFACE(pThis->Lun0.pDrvBase, PDMIPCIRAWCONNECTOR); 508 if (!pThis->Lun0.pDrv) 509 { 510 rc = PDMDevHlpVMSetError(pDevIns, VERR_PDM_MISSING_INTERFACE, RT_SRC_POS, N_("Raw PCI failed to query interface")); 511 break; 512 } 513 514 /* Just a safety measure, this data shall never be reached */ 515 PCIDevSetVendorId(&pThis->aPciDevice, 0xdead); 516 PCIDevSetDeviceId(&pThis->aPciDevice, 0xbeef); 517 518 rc = PDMDevHlpPCIRegister(pDevIns, &pThis->aPciDevice); 519 if (RT_FAILURE(rc)) 520 break; 521 522 PDMDevHlpPCISetConfigCallbacks(pDevIns, &pThis->aPciDevice, 523 pcirawConfigRead, NULL /* we don't care about old ones */, 524 pcirawConfigWrite, NULL /* we don't care about old ones */); 525 526 #if 1 527 /* 528 * Register IO/MMIO ranges for the guest, basing on real device ranges. 529 */ 530 for (int iRegion = 0; iRegion < VBOX_PCI_NUM_REGIONS; iRegion++) 531 { 532 RTHCPHYS RegStart; 533 uint64_t iRegSize; 534 bool fMmio; 535 536 if (pThis->Lun0.pDrv->pfnGetRegionInfo(pThis->Lun0.pDrv, hostAddress.asLong(), iRegion, 537 &RegStart, &iRegSize, &fMmio)) 538 { 539 /* If region is present, register callbacks in guest. 540 @todo: replace it with direct region access with remap */ 541 // @todo: check if host's PA make sense for the guest 542 if (fMmio) 543 { 544 rc = PDMDevHlpMMIORegister(pDevIns, RegStart, iRegSize, NULL, 545 pcirawMMIOWrite, pcirawMMIORead, NULL, 546 "Raw PCI MMIO regions"); 547 if (RT_FAILURE(rc)) 548 { 549 AssertMsgRC(rc, ("Cannot register MMIO: %Rrc\n", rc)); 550 break; 551 } 552 } 553 else 554 { 555 rc = PDMDevHlpIOPortRegister(pDevIns, (RTIOPORT)RegStart, iRegSize, NULL, 556 pcirawIOPortWrite, pcirawIOPortRead, NULL, NULL, 557 "Raw PCI IO regions"); 558 if (RT_FAILURE(rc)) 559 { 560 AssertMsgRC(rc, ("Cannot register IO: %Rrc\n", rc)); 561 break; 562 } 563 } 564 } 565 } 566 567 if (RT_FAILURE(rc)) 568 break; 569 #endif 570 571 if (fRCEnabled) 572 { 573 pThis->pPciRawHlpRC = pThis->pPciRawHlpR3->pfnGetRCHelpers(pDevIns); 574 if (!pThis->pPciRawHlpRC) 575 { 576 AssertReleaseMsgFailed(("cannot get RC helper\n")); 577 rc = VERR_INTERNAL_ERROR; 578 break; 579 } 580 } 581 if (fR0Enabled) 582 { 583 pThis->pPciRawHlpR0 = pThis->pPciRawHlpR3->pfnGetR0Helpers(pDevIns); 584 if (!pThis->pPciRawHlpR0) 585 { 586 AssertReleaseMsgFailed(("cannot get R0 helper\n")); 587 rc = VERR_INTERNAL_ERROR; 588 break; 589 } 590 } 591 592 /* Register SSM callbacks */ 593 rc = PDMDevHlpSSMRegister3(pDevIns, PCIRAW_SAVED_STATE_VERSION, sizeof(*pThis), pcirawLiveExec, pcirawSaveExec, pcirawLoadExec); 594 if (RT_FAILURE(rc)) 595 break; 596 } while (0); 597 /* Notify Main about result of PCI device attach attempt */ 598 if (pThis->Lun0.pDrv != NULL) 599 pThis->Lun0.pDrv->pfnPciDeviceConstructComplete(pThis->Lun0.pDrv, hostAddress.asLong(), guestAddress.asLong(), 600 rc, pThis->szDeviceName); 601 602 return rc; 462 } 463 464 /* Register SSM callbacks */ 465 rc = PDMDevHlpSSMRegister3(pDevIns, PCIRAW_SAVED_STATE_VERSION, sizeof(*pThis), pcirawLiveExec, pcirawSaveExec, pcirawLoadExec); 466 if (RT_FAILURE(rc)) 467 return rc; 468 469 return VINF_SUCCESS; 603 470 } 604 471 … … 644 511 NULL, 645 512 /* pfnAttach */ 646 NULL , //pcirawAttach,513 NULL, 647 514 /* pfnDetach */ 648 NULL, //pcirawDetach,515 NULL, 649 516 /* pfnQueryInterface. */ 650 517 NULL, -
trunk/src/VBox/Devices/Bus/PCIInternal.h
r35357 r35358 87 87 /** Flag whether the device is capable of MSI-X. 88 88 * This one is set by MsixInit(). */ 89 PCIDEV_FLAG_MSIX_CAPABLE = 1<<4, 90 /** Flag if device represents real physical device in passthrough mode. */ 91 PCIDEV_FLAG_PASSTHROUGH = 1<<5 89 PCIDEV_FLAG_MSIX_CAPABLE = 1<<4 92 90 }; 93 91 -
trunk/src/VBox/Devices/Makefile.kmk
r35357 r35358 512 512 Bus/DevPCI.cpp_INCS = Bus 513 513 Bus/DevPciIch9.cpp_INCS = Bus 514 Bus/MsiCommon.cpp_INCS 514 Bus/MsiCommon.cpp_INCS = Bus 515 515 Bus/MsixCommon.cpp_INCS = Bus 516 Bus/DevPciRaw.cpp_INCS = Bus517 518 516 519 517 # For finding and generating vbetables.h (see Graphics/BIOS/Makefile.kmk). -
trunk/src/VBox/Main/ConsoleImpl.cpp
r35357 r35358 307 307 break; 308 308 mConsole->onNATRedirectRuleChange(ulSlot, fRemove, proto, hostIp.raw(), hostPort, guestIp.raw(), guestPort); 309 break;310 309 } 311 case VBoxEventType_OnHostPciDevicePlug: 312 { 313 // handle if needed 314 break; 315 } 310 break; 316 311 default: 317 312 AssertFailed(); … … 489 484 com::SafeArray<VBoxEventType_T> eventTypes; 490 485 eventTypes.push_back(VBoxEventType_OnNATRedirect); 491 eventTypes.push_back(VBoxEventType_OnHostPciDevicePlug);492 486 rc = pES->RegisterListener(mVmListner, ComSafeArrayAsInParam(eventTypes), true); 493 487 AssertComRC(rc); -
trunk/src/VBox/Main/ConsoleImpl2.cpp
r35357 r35358 34 34 #include "VMMDev.h" 35 35 #include "Global.h" 36 #include "PciRawDevImpl.h"37 36 38 37 // generated header … … 456 455 457 456 458 static HRESULT attachRawPciDevices(BusAssignmentManager* BusMgr,459 PCFGMNODE pDevices,460 Console* pConsole)461 {462 HRESULT hrc = S_OK;463 PCFGMNODE pDev, pInst, pCfg, pLunL0;464 465 SafeIfaceArray<IPciDeviceAttachment> assignments;466 ComPtr<IMachine> aMachine = pConsole->machine();467 468 hrc = aMachine->COMGETTER(PciDeviceAssignments)(ComSafeArrayAsOutParam(assignments));469 if (hrc != S_OK)470 return hrc;471 472 for (size_t iDev = 0; iDev < assignments.size(); iDev++)473 {474 PciBusAddress HostPciAddress, GuestPciAddress;475 ComPtr<IPciDeviceAttachment> assignment = assignments[iDev];476 LONG host, guest;477 Bstr aDevName;478 479 assignment->COMGETTER(HostAddress)(&host);480 assignment->COMGETTER(GuestAddress)(&guest);481 assignment->COMGETTER(Name)(aDevName.asOutParam());482 483 InsertConfigNode(pDevices, "pciraw", &pDev);484 InsertConfigNode(pDev, Utf8StrFmt("%d", iDev).c_str(), &pInst);485 InsertConfigInteger(pInst, "Trusted", 1);486 487 HostPciAddress.fromLong(host);488 Assert(HostPciAddress.valid());489 InsertConfigNode(pInst, "Config", &pCfg);490 InsertConfigString(pCfg, "DeviceName", aDevName);491 492 InsertConfigInteger(pCfg, "HostPCIBusNo", HostPciAddress.iBus);493 InsertConfigInteger(pCfg, "HostPCIDeviceNo", HostPciAddress.iDevice);494 InsertConfigInteger(pCfg, "HostPCIFunctionNo", HostPciAddress.iFn);495 496 GuestPciAddress.fromLong(guest);497 Assert(GuestPciAddress.valid());498 hrc = BusMgr->assignPciDevice("pciraw", pInst, GuestPciAddress, true);499 if (hrc != S_OK)500 return hrc;501 InsertConfigInteger(pCfg, "GuestPCIBusNo", GuestPciAddress.iBus);502 InsertConfigInteger(pCfg, "GuestPCIDeviceNo", GuestPciAddress.iDevice);503 InsertConfigInteger(pCfg, "GuestPCIFunctionNo", GuestPciAddress.iFn);504 505 /* the Main driver */506 PciRawDev* pMainDev = new PciRawDev(pConsole);507 InsertConfigNode(pInst, "LUN#0", &pLunL0);508 InsertConfigString(pLunL0, "Driver", "PciRawMain");509 InsertConfigNode(pLunL0, "Config" , &pCfg);510 InsertConfigInteger(pCfg, "Object", (uintptr_t)pMainDev);511 }512 513 return hrc;514 }515 516 457 /** 517 458 * Construct the VM configuration tree (CFGM). … … 970 911 InsertConfigInteger(pCfg, "McfgLength", u32McfgLength); 971 912 913 972 914 /* And register 2 bridges */ 973 915 InsertConfigNode(pDevices, "ich9pcibridge", &pDev); … … 979 921 InsertConfigInteger(pInst, "Trusted", 1); /* boolean */ 980 922 hrc = BusMgr->assignPciDevice("ich9pcibridge", pInst); H(); 981 982 /* Add PCI passthrough devices */983 hrc = attachRawPciDevices(BusMgr, pDevices, pConsole); H();984 923 } 985 924 986 925 /* 987 * Enable 3 following devices: HPET, SMC, LPC on MacOS X guests or on ICH9926 * Enable 3 following devices: HPET, SMC, LPC on MacOS X guests 988 927 */ 989 928 /* -
trunk/src/VBox/Main/GuestCtrlImpl.cpp
r35357 r35358 206 206 { 207 207 rc = TaskGuest::setProgressErrorInfo(VBOX_E_IPRT_ERROR, aTask->progress, 208 Guest::tr("Source file \"%s\" does not exist , or is not a file"),208 Guest::tr("Source file \"%s\" does not exist"), 209 209 aTask->strSource.c_str()); 210 210 } -
trunk/src/VBox/Main/MachineImpl.cpp
r35357 r35358 50 50 #include "DisplayUtils.h" 51 51 #include "BandwidthControlImpl.h" 52 #include "VBoxEvents.h"53 52 54 53 #ifdef VBOX_WITH_USB … … 5811 5810 } 5812 5811 5813 /** 5814 * Currently this method doesn't attach device to the running VM, 5815 * just makes sure it's plugged on next VM start. 5816 */ 5817 STDMETHODIMP Machine::AttachHostPciDevice(LONG hostAddress, LONG desiredGuestAddress, BOOL /*tryToUnbind*/) 5818 { 5819 AutoCaller autoCaller(this); 5820 if (FAILED(autoCaller.rc())) return autoCaller.rc(); 5821 5822 // lock scope 5823 { 5824 AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS); 5825 5826 //HRESULT rc = checkStateDependency(MutableStateDep); 5827 //if (FAILED(rc)) return rc; 5828 5829 ComObjPtr<PciDeviceAttachment> pda; 5830 char name[32]; 5831 5832 RTStrPrintf(name, sizeof(name), "host%02x:%02x.%x", (hostAddress>>8) & 0xff, (hostAddress & 0xf8) >> 3, hostAddress & 7); 5833 Bstr bname(name); 5834 pda.createObject(); 5835 pda->init(this, bname, hostAddress, desiredGuestAddress, TRUE); 5836 setModified(IsModified_MachineData); 5837 mHWData.backup(); 5838 mHWData->mPciDeviceAssignments.push_back(pda); 5839 } 5840 5841 // do we need it? 5842 //saveSettings(NULL); 5843 mHWData.commit(); 5844 5845 return S_OK; 5846 } 5847 5848 /** 5849 * Currently this method doesn't detach device from the running VM, 5850 * just makes sure it's not plugged on next VM start. 5851 */ 5852 STDMETHODIMP Machine::DetachHostPciDevice(LONG hostAddress) 5853 { 5854 AutoCaller autoCaller(this); 5855 if (FAILED(autoCaller.rc())) return autoCaller.rc(); 5856 5857 ComObjPtr<PciDeviceAttachment> pAttach; 5858 bool fRemoved = false; 5859 HRESULT rc; 5860 5861 // lock scope 5862 { 5863 AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS); 5864 5865 rc = checkStateDependency(MutableStateDep); 5866 if (FAILED(rc)) return rc; 5867 5868 for (HWData::PciDeviceAssignmentList::iterator it = mHWData->mPciDeviceAssignments.begin(); 5869 it != mHWData->mPciDeviceAssignments.end(); 5870 ++it) 5871 { 5872 LONG iHostAddress = -1; 5873 pAttach = *it; 5874 pAttach->COMGETTER(HostAddress)(&iHostAddress); 5875 if (iHostAddress != -1 && iHostAddress == hostAddress) 5876 { 5877 setModified(IsModified_MachineData); 5878 mHWData.backup(); 5879 mHWData->mPciDeviceAssignments.remove(pAttach); 5880 fRemoved = true; 5881 break; 5882 } 5883 } 5884 // Indeed under lock? 5885 mHWData.commit(); 5886 5887 // do we need it? 5888 // saveSettings(NULL); 5889 } 5890 5891 5892 /* Fire event outside of the lock */ 5893 if (fRemoved) 5894 { 5895 Assert(!pAttach.isNull()); 5896 ComPtr<IEventSource> es; 5897 rc = mParent->COMGETTER(EventSource)(es.asOutParam()); 5898 Assert(SUCCEEDED(rc)); 5899 Bstr mid; 5900 rc = this->COMGETTER(Id)(mid.asOutParam()); 5901 Assert(SUCCEEDED(rc)); 5902 fireHostPciDevicePlugEvent(es, mid.raw(), false /* unplugged */, true /* success */, pAttach, NULL); 5903 } 5904 5905 return S_OK; 5812 5813 STDMETHODIMP Machine::AttachHostPciDevice(LONG hostAddress, LONG desiredGuestAddress, IEventContext * /*eventContext*/, BOOL /*tryToUnbind*/) 5814 { 5815 AutoCaller autoCaller(this); 5816 if (FAILED(autoCaller.rc())) return autoCaller.rc(); 5817 AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS); 5818 5819 ComObjPtr<PciDeviceAttachment> pda; 5820 char name[32]; 5821 5822 pda.createObject(); 5823 RTStrPrintf(name, sizeof(name), "host%02x:%02x.%x", (hostAddress>>8) & 0xff, (hostAddress & 0xf8) >> 3, hostAddress & 7); 5824 Bstr bname(name); 5825 pda.createObject(); 5826 pda->init(this, bname, hostAddress, desiredGuestAddress, TRUE); 5827 5828 mPciDeviceAssignments.push_back(pda); 5829 return S_OK; 5830 } 5831 5832 STDMETHODIMP Machine::DetachHostPciDevice(LONG /*hostAddress*/) 5833 { 5834 AutoCaller autoCaller(this); 5835 if (FAILED(autoCaller.rc())) return autoCaller.rc(); 5836 AutoWriteLock alock(this COMMA_LOCKVAL_SRC_POS); 5837 5838 return E_NOTIMPL; 5906 5839 } 5907 5840 … … 5915 5848 AutoReadLock alock(this COMMA_LOCKVAL_SRC_POS); 5916 5849 5917 SafeIfaceArray<IPciDeviceAttachment> assignments(m HWData->mPciDeviceAssignments);5850 SafeIfaceArray<IPciDeviceAttachment> assignments(mPciDeviceAssignments); 5918 5851 assignments.detachTo(ComSafeArrayOutArg(aAssignments)); 5919 5852 … … 6529 6462 6530 6463 HRESULT rc = S_OK; 6464 6531 6465 // Ensure the settings are saved. If we are going to be registered and 6532 6466 // no config file exists yet, create it by calling saveSettings() too. -
trunk/src/VBox/Main/Makefile.kmk
r35357 r35358 653 653 BusAssignmentManager.cpp \ 654 654 PciDeviceAttachmentImpl.cpp \ 655 PciRawDevImpl.cpp \656 655 $(VBOX_AUTOGEN_EVENT_CPP) \ 657 656 $(VBOX_XML_SCHEMADEFS_CPP) \ -
trunk/src/VBox/Main/PciDeviceAttachmentImpl.cpp
r35357 r35358 25 25 struct PciDeviceAttachment::Data 26 26 { 27 Data(Machine 28 const Bstr 29 LONG 30 LONG 31 BOOL 27 Data(Machine *aParent, 28 const Bstr &aDevName, 29 LONG aHostAddress, 30 LONG aGuestAddress, 31 BOOL afPhysical) 32 32 : pMachine(aParent), 33 33 HostAddress(aHostAddress), GuestAddress(aGuestAddress), … … 61 61 // public initializer/uninitializer for internal purposes only 62 62 ///////////////////////////////////////////////////////////////////////////// 63 HRESULT PciDeviceAttachment::init(Machine 64 const Bstr 65 LONG 66 LONG 67 BOOL 63 HRESULT PciDeviceAttachment::init(Machine *aParent, 64 const Bstr &aDevName, 65 LONG aHostAddress, 66 LONG aGuestAddress, 67 BOOL fPhysical) 68 68 { 69 69 m = new Data(aParent, aDevName, aHostAddress, aGuestAddress, fPhysical); -
trunk/src/VBox/Main/VBoxDriversRegister.cpp
r35357 r35358 26 26 #include "AudioSnifferInterface.h" 27 27 #include "ConsoleImpl.h" 28 #include "PciRawDevImpl.h"29 28 30 29 #include "Logging.h" … … 68 67 if (RT_FAILURE(rc)) 69 68 return rc; 70 71 rc = pCallbacks->pfnRegister(pCallbacks, &PciRawDev::DrvReg);72 if (RT_FAILURE(rc))73 return rc;74 75 69 return VINF_SUCCESS; 76 70 } -
trunk/src/VBox/Main/idl/VirtualBox.xidl
r35357 r35358 4705 4705 <desc>Desired position of this device on guest PCI bus.</desc> 4706 4706 </param> 4707 <param name="eventContext" type="IEventContext" dir="in"> 4708 <desc>Context passed into IHostPciDevicePlugEvent event.</desc> 4709 </param> 4707 4710 <param name="tryToUnbind" type="boolean" dir="in"> 4708 4711 <desc>If VMM shall try to unbind existing drivers from the … … 4715 4718 Detach host PCI device from the virtual machine. 4716 4719 Also HostPciDevicePlugEvent on IVirtualBox event source 4717 will be delivered. As currently we don't support hot device 4718 unplug, IHostPciDevicePlugEvent event is delivered immediately. 4720 will be delivered. 4721 4722 <note> 4723 Not yet implemented. 4724 </note> 4719 4725 4720 4726 <see>IHostPciDevicePlugEvent</see> … … 16591 16597 > 16592 16598 <desc> 16593 Notification when host PCI device is plugged/unplugged. Plugging 16594 usually takes place on VM startup, unplug - when 16595 IMachine::DetachHostPciDevice is called. 16596 <see> 16597 IMachine::DetachHostPciDevice 16598 </see> 16599 Notification when host PCI device is plugged/unplugged. 16599 16600 </desc> 16600 16601 … … 16615 16616 <desc> 16616 16617 Attachment info for this device. 16618 </desc> 16619 </attribute> 16620 16621 <attribute name="eventContext" type="IEventContext" readonly="yes"> 16622 <desc> 16623 Context object, passed into attachHostPciDevice() and 16624 attachHostPciDevice(). 16617 16625 </desc> 16618 16626 </attribute> -
trunk/src/VBox/Main/include/MachineImpl.h
r35357 r35358 291 291 BOOL mIoCacheEnabled; 292 292 ULONG mIoCacheSize; 293 294 typedef std::list< ComObjPtr<PciDeviceAttachment> > PciDeviceAssignmentList;295 PciDeviceAssignmentList mPciDeviceAssignments;296 293 }; 297 294 … … 526 523 STDMETHOD(QueryLogFilename(ULONG aIdx, BSTR *aName)); 527 524 STDMETHOD(ReadLog(ULONG aIdx, LONG64 aOffset, LONG64 aSize, ComSafeArrayOut(BYTE, aData))); 528 STDMETHOD(AttachHostPciDevice(LONG hostAddress, LONG desiredGuestAddress, BOOL tryToUnbind));525 STDMETHOD(AttachHostPciDevice(LONG hostAddress, LONG desiredGuestAddress, IEventContext *eventContext, BOOL tryToUnbind)); 529 526 STDMETHOD(DetachHostPciDevice(LONG hostAddress)); 530 527 STDMETHOD(COMGETTER(PciDeviceAssignments))(ComSafeArrayOut(IPciDeviceAttachment *, aAssignments)); … … 873 870 typedef std::list< ComObjPtr<StorageController> > StorageControllerList; 874 871 Backupable<StorageControllerList> mStorageControllers; 872 873 typedef std::list< ComObjPtr<PciDeviceAttachment> > PciDeviceAssignmentList; 874 PciDeviceAssignmentList mPciDeviceAssignments; 875 875 876 876 friend class SessionMachine; -
trunk/src/VBox/VMM/VMMR0/PDMR0Device.cpp
r35357 r35358 48 48 extern DECLEXPORT(const PDMPCIHLPR0) g_pdmR0PciHlp; 49 49 extern DECLEXPORT(const PDMHPETHLPR0) g_pdmR0HpetHlp; 50 extern DECLEXPORT(const PDMPCIRAWHLPR0) g_pdmR0PciRawHlp;51 50 extern DECLEXPORT(const PDMDRVHLPR0) g_pdmR0DrvHlp; 52 51 RT_C_DECLS_END … … 679 678 }; 680 679 681 /**682 * The Ring-0 PCI raw Helper Callbacks.683 */684 extern DECLEXPORT(const PDMPCIRAWHLPR0) g_pdmR0PciRawHlp =685 {686 PDM_PCIRAWHLPR0_VERSION,687 PDM_PCIRAWHLPR0_VERSION, /* the end */688 };689 690 680 /** @} */ 691 681 -
trunk/src/VBox/VMM/VMMR3/PDMDevHlp.cpp
r35357 r35358 2809 2809 *ppHpetHlpR3 = &g_pdmR3DevHpetHlp; 2810 2810 LogFlow(("pdmR3DevHlp_HPETRegister: caller='%s'/%d: returns %Rrc\n", pDevIns->pReg->szName, pDevIns->iInstance, VINF_SUCCESS)); 2811 return VINF_SUCCESS;2812 }2813 2814 /** @interface_method_impl{PDMDEVHLPR3,pfnPciRawRegister} */2815 static DECLCALLBACK(int) pdmR3DevHlp_PciRawRegister(PPDMDEVINS pDevIns, PPDMPCIRAWREG pPciRawReg, PCPDMPCIRAWHLPR3 *ppPciRawHlpR3)2816 {2817 PDMDEV_ASSERT_DEVINS(pDevIns);2818 VM_ASSERT_EMT(pDevIns->Internal.s.pVMR3);2819 LogFlow(("pdmR3DevHlp_PciRawRegister: caller='%s'/%d:\n"));2820 2821 /*2822 * Validate input.2823 */2824 if (pPciRawReg->u32Version != PDM_PCIRAWREG_VERSION)2825 {2826 AssertMsgFailed(("u32Version=%#x expected %#x\n", pPciRawReg->u32Version, PDM_PCIRAWREG_VERSION));2827 LogFlow(("pdmR3DevHlp_PciRawRegister: caller='%s'/%d: returns %Rrc (version)\n", pDevIns->pReg->szName, pDevIns->iInstance, VERR_INVALID_PARAMETER));2828 return VERR_INVALID_PARAMETER;2829 }2830 2831 if (!ppPciRawHlpR3)2832 {2833 Assert(ppPciRawHlpR3);2834 LogFlow(("pdmR3DevHlp_PciRawRegister: caller='%s'/%d: returns %Rrc (ppApicHlpR3)\n", pDevIns->pReg->szName, pDevIns->iInstance, VERR_INVALID_PARAMETER));2835 return VERR_INVALID_PARAMETER;2836 }2837 2838 /* set the helper pointer and return. */2839 *ppPciRawHlpR3 = &g_pdmR3DevPciRawHlp;2840 LogFlow(("pdmR3DevHlp_PciRawRegister: caller='%s'/%d: returns %Rrc\n", pDevIns->pReg->szName, pDevIns->iInstance, VINF_SUCCESS));2841 2811 return VINF_SUCCESS; 2842 2812 } … … 3212 3182 pdmR3DevHlp_IOAPICRegister, 3213 3183 pdmR3DevHlp_HPETRegister, 3214 pdmR3DevHlp_PciRawRegister,3215 3184 pdmR3DevHlp_DMACRegister, 3216 3185 pdmR3DevHlp_DMARegister, … … 3423 3392 pdmR3DevHlp_IOAPICRegister, 3424 3393 pdmR3DevHlp_HPETRegister, 3425 pdmR3DevHlp_PciRawRegister,3426 3394 pdmR3DevHlp_DMACRegister, 3427 3395 pdmR3DevHlp_DMARegister, … … 3501 3469 3502 3470 /** @} */ 3471 -
trunk/src/VBox/VMM/VMMR3/PDMDevMiscHlp.cpp
r35357 r35358 652 652 653 653 654 /** @interface_method_impl{PDMPCIRAWHLPR3,pfnGetRCHelpers} */655 static DECLCALLBACK(PCPDMPCIRAWHLPRC) pdmR3PciRawHlp_GetRCHelpers(PPDMDEVINS pDevIns)656 {657 PDMDEV_ASSERT_DEVINS(pDevIns);658 VM_ASSERT_EMT(pDevIns->Internal.s.pVMR3);659 RTRCPTR pRCHelpers = 0;660 int rc = PDMR3LdrGetSymbolRC(pDevIns->Internal.s.pVMR3, NULL, "g_pdmRCPciRawHlp", &pRCHelpers);661 AssertReleaseRC(rc);662 AssertRelease(pRCHelpers);663 LogFlow(("pdmR3PciRawHlp_GetGCHelpers: caller='%s'/%d: returns %RRv\n",664 pDevIns->pReg->szName, pDevIns->iInstance, pRCHelpers));665 return pRCHelpers;666 }667 668 669 /** @interface_method_impl{PDMPCIRAWHLPR3,pfnGetR0Helpers} */670 static DECLCALLBACK(PCPDMPCIRAWHLPR0) pdmR3PciRawHlp_GetR0Helpers(PPDMDEVINS pDevIns)671 {672 PDMDEV_ASSERT_DEVINS(pDevIns);673 VM_ASSERT_EMT(pDevIns->Internal.s.pVMR3);674 PCPDMHPETHLPR0 pR0Helpers = 0;675 int rc = PDMR3LdrGetSymbolR0(pDevIns->Internal.s.pVMR3, NULL, "g_pdmR0PciRawHlp", &pR0Helpers);676 AssertReleaseRC(rc);677 AssertRelease(pR0Helpers);678 LogFlow(("pdmR3PciRawHlp_GetR0Helpers: caller='%s'/%d: returns %RHv\n",679 pDevIns->pReg->szName, pDevIns->iInstance, pR0Helpers));680 return pR0Helpers;681 }682 683 /**684 * Raw PCI Device Helpers.685 */686 const PDMPCIRAWHLPR3 g_pdmR3DevPciRawHlp =687 {688 PDM_PCIRAWHLPR3_VERSION,689 pdmR3PciRawHlp_GetRCHelpers,690 pdmR3PciRawHlp_GetR0Helpers,691 PDM_PCIRAWHLPR3_VERSION, /* the end */692 };693 654 694 655 /* none yet */ -
trunk/src/VBox/VMM/include/PDMInternal.h
r35357 r35358 1085 1085 extern const PDMRTCHLP g_pdmR3DevRtcHlp; 1086 1086 extern const PDMHPETHLPR3 g_pdmR3DevHpetHlp; 1087 extern const PDMPCIRAWHLPR3 g_pdmR3DevPciRawHlp;1088 1087 #endif 1089 1088
Note:
See TracChangeset
for help on using the changeset viewer.