- Timestamp:
- Oct 30, 2013 1:13:02 PM (11 years ago)
- Location:
- trunk
- Files:
-
- 10 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/include/VBox/VBoxVideo.h
r44529 r49332 1422 1422 VBOXVDMACMD_CHROMIUM_CTL_TYPE_SAVESTATE_END, 1423 1423 VBOXVDMACMD_CHROMIUM_CTL_TYPE_CRHGSMI_SETUP_COMPLETION, 1424 VBOXVDMACMD_CHROMIUM_CTL_TYPE_CRCONNECT, 1424 1425 VBOXVDMACMD_CHROMIUM_CTL_TYPE_SIZEHACK = 0xfffffffe 1425 1426 } VBOXVDMACMD_CHROMIUM_CTL_TYPE; … … 1442 1443 } VBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP, *PVBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP; 1443 1444 1445 1444 1446 typedef struct PDMIDISPLAYVBVACALLBACKS *HCRHGSMICMDCOMPLETION; 1445 1447 typedef DECLCALLBACK(int) FNCRHGSMICMDCOMPLETION(HCRHGSMICMDCOMPLETION hCompletion, PVBOXVDMACMD_CHROMIUM_CMD pCmd, int rc); … … 1452 1454 PFNCRHGSMICMDCOMPLETION pfnCompletion; 1453 1455 } VBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP_COMPLETION, *PVBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP_COMPLETION; 1456 1457 typedef struct VBOXCRCON_SERVER *HVBOXCRCON_SERVER; 1458 typedef struct PDMIDISPLAYVBVACALLBACKS* HVBOXCRCON_CLIENT; 1459 1460 typedef struct VBOXCRCON_3DRGN_CLIENT* HVBOXCRCON_3DRGN_CLIENT; 1461 typedef struct VBOXCRCON_3DRGN_ASYNCCLIENT* HVBOXCRCON_3DRGN_ASYNCCLIENT; 1462 1463 /* server callbacks */ 1464 /* submit chromium cmd */ 1465 typedef DECLCALLBACK(int) FNVBOXCRCON_SVR_CRCMD(HVBOXCRCON_SERVER hServer, PVBOXVDMACMD_CHROMIUM_CMD pCmd, uint32_t cbCmd); 1466 typedef FNVBOXCRCON_SVR_CRCMD *PFNVBOXCRCON_SVR_CRCMD; 1467 1468 /* submit chromium control cmd */ 1469 typedef DECLCALLBACK(int) FNVBOXCRCON_SVR_CRCTL(HVBOXCRCON_SERVER hServer, PVBOXVDMACMD_CHROMIUM_CTL pCtl, uint32_t cbCmd); 1470 typedef FNVBOXCRCON_SVR_CRCTL *PFNVBOXCRCON_SVR_CRCTL; 1471 1472 /* request 3D data. 1473 * The protocol is the following: 1474 * 1. if there is no 3D data displayed on screen, returns VINF_EOF immediately w/o calling any PFNVBOXCRCON_3DRGN_XXX callbacks 1475 * 2. otherwise calls PFNVBOXCRCON_3DRGN_ONSUBMIT, submits the "regions get" request to the CrOpenGL server to process it asynchronously and returns VINF_SUCCESS 1476 * 2.a on "regions get" request processing calls PFNVBOXCRCON_3DRGN_BEGIN, 1477 * 2.b then PFNVBOXCRCON_3DRGN_REPORT zero or more times for each 3D region, 1478 * 2.c and then PFNVBOXCRCON_3DRGN_END 1479 * 3. returns VERR_XXX code on failure 1480 * */ 1481 typedef DECLCALLBACK(int) FNVBOXCRCON_SVR_3DRGN_GET(HVBOXCRCON_SERVER hServer, HVBOXCRCON_3DRGN_CLIENT hRgnClient, uint32_t idScreen); 1482 typedef FNVBOXCRCON_SVR_3DRGN_GET *PFNVBOXCRCON_SVR_3DRGN_GET; 1483 1484 /* 3D Regions Client callbacks */ 1485 /* called from the PFNVBOXCRCON_SVR_3DRGN_GET callback in case server has 3D data and is going to process the request asynchronously, 1486 * see comments for PFNVBOXCRCON_SVR_3DRGN_GET above */ 1487 typedef DECLCALLBACK(int) FNVBOXCRCON_3DRGN_ONSUBMIT(HVBOXCRCON_3DRGN_CLIENT hRgnClient, uint32_t idScreen, HVBOXCRCON_3DRGN_ASYNCCLIENT *phRgnAsyncClient); 1488 typedef FNVBOXCRCON_3DRGN_ONSUBMIT *PFNVBOXCRCON_3DRGN_ONSUBMIT; 1489 1490 /* called from the "regions get" command processing thread, to indicate that the "regions get" is started. 1491 * see comments for PFNVBOXCRCON_SVR_3DRGN_GET above */ 1492 typedef DECLCALLBACK(int) FNVBOXCRCON_3DRGN_BEGIN(HVBOXCRCON_3DRGN_ASYNCCLIENT hRgnAsyncClient, uint32_t idScreen); 1493 typedef FNVBOXCRCON_3DRGN_BEGIN *PFNVBOXCRCON_3DRGN_BEGIN; 1494 1495 /* called from the "regions get" command processing thread, to report a 3D region. 1496 * see comments for PFNVBOXCRCON_SVR_3DRGN_GET above */ 1497 typedef DECLCALLBACK(int) FNVBOXCRCON_3DRGN_REPORT(HVBOXCRCON_3DRGN_ASYNCCLIENT hRgnAsyncClient, uint32_t idScreen, void *pvData, uint32_t cbStride, const RTRECT *pRect); 1498 typedef FNVBOXCRCON_3DRGN_REPORT *PFNVBOXCRCON_3DRGN_REPORT; 1499 1500 /* called from the "regions get" command processing thread, to indicate that the "regions get" is completed. 1501 * see comments for PFNVBOXCRCON_SVR_3DRGN_GET above */ 1502 typedef DECLCALLBACK(int) FNVBOXCRCON_3DRGN_END(HVBOXCRCON_3DRGN_ASYNCCLIENT hRgnAsyncClient, uint32_t idScreen); 1503 typedef FNVBOXCRCON_3DRGN_END *PFNVBOXCRCON_3DRGN_END; 1504 1505 1506 /* client callbacks */ 1507 /* complete chromium cmd */ 1508 typedef DECLCALLBACK(int) FNVBOXCRCON_CLT_CRCTL_COMPLETE(HVBOXCRCON_CLIENT hClient, PVBOXVDMACMD_CHROMIUM_CTL pCtl, int rc); 1509 typedef FNVBOXCRCON_CLT_CRCTL_COMPLETE *PFNVBOXCRCON_CLT_CRCTL_COMPLETE; 1510 1511 /* complete chromium control cmd */ 1512 typedef DECLCALLBACK(int) FNVBOXCRCON_CLT_CRCMD_COMPLETE(HVBOXCRCON_CLIENT hClient, PVBOXVDMACMD_CHROMIUM_CMD pCmd, int rc); 1513 typedef FNVBOXCRCON_CLT_CRCMD_COMPLETE *PFNVBOXCRCON_CLT_CRCMD_COMPLETE; 1514 1515 typedef struct VBOXCRCON_SERVER_CALLBACKS 1516 { 1517 HVBOXCRCON_SERVER hServer; 1518 PFNVBOXCRCON_SVR_CRCMD pfnCrCmd; 1519 PFNVBOXCRCON_SVR_CRCTL pfnCrCtl; 1520 PFNVBOXCRCON_SVR_3DRGN_GET pfn3DRgnGet; 1521 } VBOXCRCON_SERVER_CALLBACKS, *PVBOXCRCON_SERVER_CALLBACKS; 1522 1523 typedef struct VBOXCRCON_CLIENT_CALLBACKS 1524 { 1525 HVBOXCRCON_CLIENT hClient; 1526 PFNVBOXCRCON_CLT_CRCMD_COMPLETE pfnCrCmdComplete; 1527 PFNVBOXCRCON_CLT_CRCTL_COMPLETE pfnCrCtlComplete; 1528 PFNVBOXCRCON_3DRGN_ONSUBMIT pfn3DRgnOnSubmit; 1529 PFNVBOXCRCON_3DRGN_BEGIN pfn3DRgnBegin; 1530 PFNVBOXCRCON_3DRGN_REPORT pfn3DRgnReport; 1531 PFNVBOXCRCON_3DRGN_END pfn3DRgnEnd; 1532 } VBOXCRCON_CLIENT_CALLBACKS, *PVBOXCRCON_CLIENT_CALLBACKS; 1533 1534 /* issued by Main to establish connection between Main and CrOpenGL service */ 1535 typedef struct VBOXVDMACMD_CHROMIUM_CTL_CRCONNECT 1536 { 1537 VBOXVDMACMD_CHROMIUM_CTL Hdr; 1538 /*input (filled by Client) :*/ 1539 /*class VMMDev*/void *pVMMDev; 1540 VBOXCRCON_CLIENT_CALLBACKS ClientCallbacks; 1541 /*output (filled by Server) :*/ 1542 VBOXCRCON_SERVER_CALLBACKS ServerCallbacks; 1543 } VBOXVDMACMD_CHROMIUM_CTL_CRCONNECT, *PVBOXVDMACMD_CHROMIUM_CTL_CRCONNECT; 1544 1454 1545 # pragma pack() 1546 1455 1547 #endif 1456 1548 -
trunk/src/VBox/Additions/WINNT/Graphics/Video/disp/wddm/VBoxUhgsmiBase.cpp
r43723 r49332 33 33 int vboxUhgsmiBaseBufferTerm(PVBOXUHGSMI_BUFFER_PRIVATE_ESC_BASE pBuffer) 34 34 { 35 PVBOXUHGSMI_PRIVATE_BASE pPrivate = VBOXUHGSMIBASE_GET(pBuffer-> PrivateBase.pHgsmi);35 PVBOXUHGSMI_PRIVATE_BASE pPrivate = VBOXUHGSMIBASE_GET(pBuffer->BasePrivate.pHgsmi); 36 36 VBOXDISPIFESCAPE_UHGSMI_DEALLOCATE DeallocInfo = {0}; 37 37 DeallocInfo.EscapeHdr.escapeCode = VBOXESC_UHGSMI_DEALLOCATE; … … 98 98 pBuffer->Alloc = AllocInfo.Alloc; 99 99 Assert(pBuffer->Alloc.pvData); 100 pBuffer-> PrivateBase.pHgsmi = pPrivate;101 pBuffer-> PrivateBase.Base.pfnLock = vboxUhgsmiBaseEscBufferLock;102 pBuffer-> PrivateBase.Base.pfnUnlock = vboxUhgsmiBaseEscBufferUnlock;103 pBuffer-> PrivateBase.Base.pfnDestroy = pfnDestroy;104 pBuffer-> PrivateBase.Base.fType = fUhgsmiType;105 pBuffer-> PrivateBase.Base.cbBuffer = AllocInfo.Alloc.cbData;100 pBuffer->BasePrivate.pHgsmi = pPrivate; 101 pBuffer->BasePrivate.Base.pfnLock = vboxUhgsmiBaseEscBufferLock; 102 pBuffer->BasePrivate.Base.pfnUnlock = vboxUhgsmiBaseEscBufferUnlock; 103 pBuffer->BasePrivate.Base.pfnDestroy = pfnDestroy; 104 pBuffer->BasePrivate.Base.fType = fUhgsmiType; 105 pBuffer->BasePrivate.Base.cbBuffer = AllocInfo.Alloc.cbData; 106 106 pBuffer->hSynch = hSynch; 107 107 return VINF_SUCCESS; … … 137 137 if (RT_SUCCESS(rc)) 138 138 { 139 *ppBuf = &pBuffer-> PrivateBase.Base;139 *ppBuf = &pBuffer->BasePrivate.Base; 140 140 return VINF_SUCCESS; 141 141 } … … 182 182 { 183 183 pSubmInfo->Info.offData = 0; 184 pSubmInfo->Info.cbData = pBuf-> PrivateBase.Base.cbBuffer;184 pSubmInfo->Info.cbData = pBuf->BasePrivate.Base.cbBuffer; 185 185 } 186 186 else -
trunk/src/VBox/Additions/WINNT/Graphics/Video/disp/wddm/VBoxUhgsmiBase.h
r44529 r49332 68 68 typedef struct VBOXUHGSMI_BUFFER_PRIVATE_ESC_BASE 69 69 { 70 VBOXUHGSMI_BUFFER_PRIVATE_BASE PrivateBase;70 VBOXUHGSMI_BUFFER_PRIVATE_BASE BasePrivate; 71 71 VBOXVIDEOCM_UM_ALLOC Alloc; 72 72 HANDLE hSynch; … … 75 75 typedef struct VBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE 76 76 { 77 VBOXUHGSMI_BUFFER_PRIVATE_BASE PrivateBase;77 VBOXUHGSMI_BUFFER_PRIVATE_BASE BasePrivate; 78 78 D3DKMT_HANDLE hAllocation; 79 79 UINT aLockPageIndices[1]; … … 84 84 #define VBOXUHGSMIBASE_GET_BUFFER(_p) VBOXUHGSMIBASE_GET_PRIVATE(_p, VBOXUHGSMI_BUFFER_PRIVATE_BASE) 85 85 86 #define VBOXUHGSMIPRIVATEBASE_GET_PRIVATE(_p, _t) ((_t*)(((uint8_t*)_p) - RT_OFFSETOF(_t, PrivateBase.Base)))86 #define VBOXUHGSMIPRIVATEBASE_GET_PRIVATE(_p, _t) ((_t*)(((uint8_t*)_p) - RT_OFFSETOF(_t, BasePrivate.Base))) 87 87 #define VBOXUHGSMIESCBASE_GET_BUFFER(_p) VBOXUHGSMIPRIVATEBASE_GET_PRIVATE(_p, VBOXUHGSMI_BUFFER_PRIVATE_ESC_BASE) 88 88 #define VBOXUHGSMDXALLOCBASE_GET_BUFFER(_p) VBOXUHGSMIPRIVATEBASE_GET_PRIVATE(_p, VBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE) 89 89 90 DECLINLINE(int) vboxUhgsmiBaseLockData(PVBOXUHGSMI_BUFFER pBuf, uint32_t offLock, uint32_t cbLock, VBOXUHGSMI_BUFFER_LOCK_FLAGS fFlags, 91 D3DDDICB_LOCKFLAGS *pfFlags, UINT *pNumPages, UINT* pPages) 92 { 90 DECLINLINE(int) vboxUhgsmiBaseDxLockData(PVBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE pPrivate, uint32_t offLock, uint32_t cbLock, VBOXUHGSMI_BUFFER_LOCK_FLAGS fFlags, 91 D3DDDICB_LOCKFLAGS *pfFlags, UINT *pNumPages) 92 { 93 PVBOXUHGSMI_BUFFER pBuf = &pPrivate->BasePrivate.Base; 93 94 D3DDDICB_LOCKFLAGS fLockFlags; 94 95 fLockFlags.Value = 0; … … 127 128 for (UINT i = 0, j = iFirstPage; i < cPages; ++i, ++j) 128 129 { 129 pP ages[i] = j;130 pPrivate->aLockPageIndices[i] = j; 130 131 } 131 132 } … … 141 142 } 142 143 143 #if 0 144 DECLINLINE(int) vboxUhgsmiBaseDmaFill(PVBOXUHGSMI_BUFFER_SUBMIT aBuffers, uint32_t cBuffers, 144 DECLINLINE(int) vboxUhgsmiBaseDxDmaFill(PVBOXUHGSMI_BUFFER_SUBMIT aBuffers, uint32_t cBuffers, 145 145 VOID* pCommandBuffer, UINT *pCommandBufferSize, 146 146 D3DDDI_ALLOCATIONLIST *pAllocationList, UINT AllocationListSize, … … 170 170 { 171 171 PVBOXUHGSMI_BUFFER_SUBMIT pBufInfo = &aBuffers[i]; 172 PVBOXUHGSMI_BUFFER_PRIVATE_ BASE pBuffer = VBOXUHGSMIBASE_GET_BUFFER(pBufInfo->pBuf);172 PVBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE pBuffer = VBOXUHGSMDXALLOCBASE_GET_BUFFER(pBufInfo->pBuf); 173 173 174 174 memset(pAllocationList, 0, sizeof (D3DDDI_ALLOCATIONLIST)); … … 181 181 { 182 182 pBufSubmInfo->offData = 0; 183 pBufSubmInfo->cbData = pBuffer->Base .cbBuffer;183 pBufSubmInfo->cbData = pBuffer->BasePrivate.Base.cbBuffer; 184 184 } 185 185 else … … 195 195 return VINF_SUCCESS; 196 196 } 197 #endif198 197 199 198 DECLCALLBACK(int) vboxUhgsmiBaseEscBufferLock(PVBOXUHGSMI_BUFFER pBuf, uint32_t offLock, uint32_t cbLock, VBOXUHGSMI_BUFFER_LOCK_FLAGS fFlags, void**pvLock); -
trunk/src/VBox/Additions/WINNT/Graphics/Video/disp/wddm/VBoxUhgsmiDisp.cpp
r44529 r49332 22 22 #define VBOXUHGSMID3D_GET(_p) VBOXUHGSMID3D_GET_PRIVATE(_p, VBOXUHGSMI_PRIVATE_D3D) 23 23 24 #if 025 #define VBOXUHGSMID3D_GET_BUFFER(_p) VBOXUHGSMID3D_GET_PRIVATE(_p, VBOXUHGSMI_BUFFER_PRIVATE_D3D)26 27 24 #include <iprt/mem.h> 28 25 #include <iprt/err.h> 29 26 30 typedef struct VBOXUHGSMI_BUFFER_PRIVATE_D3D31 {32 VBOXUHGSMI_BUFFER_PRIVATE_BASE BasePrivate;33 PVBOXWDDMDISP_DEVICE pDevice;34 UINT aLockPageIndices[1];35 } VBOXUHGSMI_BUFFER_PRIVATE_D3D, *PVBOXUHGSMI_BUFFER_PRIVATE_D3D;36 37 38 39 27 DECLCALLBACK(int) vboxUhgsmiD3DBufferDestroy(PVBOXUHGSMI_BUFFER pBuf) 40 28 { 41 PVBOXUHGSMI_BUFFER_PRIVATE_D3D pBuffer = VBOXUHGSMID3D_GET_BUFFER(pBuf); 29 PVBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE pBuffer = VBOXUHGSMDXALLOCBASE_GET_BUFFER(pBuf); 30 struct VBOXWDDMDISP_DEVICE *pDevice = VBOXUHGSMID3D_GET(pBuffer->BasePrivate.pHgsmi)->pDevice; 42 31 D3DDDICB_DEALLOCATE DdiDealloc; 43 32 DdiDealloc.hResource = 0; 44 33 DdiDealloc.NumAllocations = 1; 45 DdiDealloc.HandleList = &pBuffer->BasePrivate.hAllocation; 46 HRESULT hr = pBuffer->pDevice->RtCallbacks.pfnDeallocateCb(pBuffer->pDevice->hDevice, &DdiDealloc); 47 Assert(hr == S_OK); 48 if (hr == S_OK) 49 { 50 if (pBuffer->BasePrivate.hSynch) 51 CloseHandle(pBuffer->BasePrivate.hSynch); 34 DdiDealloc.HandleList = &pBuffer->hAllocation; 35 HRESULT hr = pDevice->RtCallbacks.pfnDeallocateCb(pDevice->hDevice, &DdiDealloc); 36 if (hr == S_OK) 37 { 52 38 RTMemFree(pBuffer); 53 39 return VINF_SUCCESS; 54 40 } 55 return VERR_GENERAL_FAILURE; 56 } 57 41 42 WARN(("pfnDeallocateCb failed, hr %#x", hr)); 43 return VERR_GENERAL_FAILURE; 44 } 45 46 /* typedef DECLCALLBACK(int) FNVBOXUHGSMI_BUFFER_LOCK(PVBOXUHGSMI_BUFFER pBuf, uint32_t offLock, uint32_t cbLock, VBOXUHGSMI_BUFFER_LOCK_FLAGS fFlags, void**pvLock); */ 58 47 DECLCALLBACK(int) vboxUhgsmiD3DBufferLock(PVBOXUHGSMI_BUFFER pBuf, uint32_t offLock, uint32_t cbLock, VBOXUHGSMI_BUFFER_LOCK_FLAGS fFlags, void**pvLock) 59 48 { 60 PVBOXUHGSMI_BUFFER_PRIVATE_D3D pBuffer = VBOXUHGSMID3D_GET_BUFFER(pBuf); 49 PVBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE pBuffer = VBOXUHGSMDXALLOCBASE_GET_BUFFER(pBuf); 50 struct VBOXWDDMDISP_DEVICE *pDevice = VBOXUHGSMID3D_GET(pBuffer->BasePrivate.pHgsmi)->pDevice; 61 51 D3DDDICB_LOCK DdiLock = {0}; 62 DdiLock.hAllocation = pBuffer-> BasePrivate.hAllocation;52 DdiLock.hAllocation = pBuffer->hAllocation; 63 53 DdiLock.PrivateDriverData = 0; 64 54 65 int rc = vboxUhgsmiBaseLockData(pBuf, offLock, cbLock, fFlags, 66 &DdiLock.Flags, &DdiLock.NumPages, pBuffer->aLockPageIndices); 67 AssertRC(rc); 68 if (RT_FAILURE(rc)) 55 int rc = vboxUhgsmiBaseDxLockData(pBuffer, offLock, cbLock, fFlags, 56 &DdiLock.Flags, &DdiLock.NumPages); 57 if (!RT_SUCCESS(rc)) 58 { 59 WARN(("vboxUhgsmiBaseDxLockData failed rc %d", rc)); 69 60 return rc; 61 } 70 62 71 63 if (DdiLock.NumPages) … … 74 66 DdiLock.pPages = NULL; 75 67 76 HRESULT hr = pBuffer->pDevice->RtCallbacks.pfnLockCb(pBuffer->pDevice->hDevice, &DdiLock); 77 Assert(hr == S_OK); 68 HRESULT hr = pDevice->RtCallbacks.pfnLockCb(pDevice->hDevice, &DdiLock); 78 69 if (hr == S_OK) 79 70 { … … 81 72 return VINF_SUCCESS; 82 73 } 74 75 WARN(("pfnLockCb failed, hr %#x", hr)); 83 76 return VERR_GENERAL_FAILURE; 84 77 } … … 86 79 DECLCALLBACK(int) vboxUhgsmiD3DBufferUnlock(PVBOXUHGSMI_BUFFER pBuf) 87 80 { 88 PVBOXUHGSMI_BUFFER_PRIVATE_D3D pBuffer = VBOXUHGSMID3D_GET_BUFFER(pBuf); 81 PVBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE pBuffer = VBOXUHGSMDXALLOCBASE_GET_BUFFER(pBuf); 82 struct VBOXWDDMDISP_DEVICE *pDevice = VBOXUHGSMID3D_GET(pBuffer->BasePrivate.pHgsmi)->pDevice; 89 83 D3DDDICB_UNLOCK DdiUnlock; 90 84 DdiUnlock.NumAllocations = 1; 91 DdiUnlock.phAllocations = &pBuffer->BasePrivate.hAllocation; 92 HRESULT hr = pBuffer->pDevice->RtCallbacks.pfnUnlockCb(pBuffer->pDevice->hDevice, &DdiUnlock); 93 Assert(hr == S_OK); 94 if (hr == S_OK) 95 return VINF_SUCCESS; 96 return VERR_GENERAL_FAILURE; 97 } 98 99 DECLCALLBACK(int) vboxUhgsmiD3DBufferCreate(PVBOXUHGSMI pHgsmi, uint32_t cbBuf, VBOXUHGSMI_BUFFER_TYPE_FLAGS fUhgsmiType, PVBOXUHGSMI_BUFFER* ppBuf) 100 { 101 HANDLE hSynch = NULL; 85 DdiUnlock.phAllocations = &pBuffer->hAllocation; 86 HRESULT hr = pDevice->RtCallbacks.pfnUnlockCb(pDevice->hDevice, &DdiUnlock); 87 if (hr == S_OK) 88 return VINF_SUCCESS; 89 90 WARN(("pfnUnlockCb failed, hr %#x", hr)); 91 return VERR_GENERAL_FAILURE; 92 } 93 94 /*typedef DECLCALLBACK(int) FNVBOXUHGSMI_BUFFER_CREATE(PVBOXUHGSMI pHgsmi, uint32_t cbBuf, VBOXUHGSMI_BUFFER_TYPE_FLAGS fType, PVBOXUHGSMI_BUFFER* ppBuf);*/ 95 DECLCALLBACK(int) vboxUhgsmiD3DBufferCreate(PVBOXUHGSMI pHgsmi, uint32_t cbBuf, VBOXUHGSMI_BUFFER_TYPE_FLAGS fType, PVBOXUHGSMI_BUFFER* ppBuf) 96 { 102 97 if (!cbBuf) 103 98 return VERR_INVALID_PARAMETER; 104 99 105 int rc = vboxUhgsmiBaseEventChkCreate(fUhgsmiType, &hSynch); 106 AssertRC(rc); 107 if (RT_FAILURE(rc)) 108 return rc; 100 int rc = VINF_SUCCESS; 109 101 110 102 cbBuf = VBOXWDDM_ROUNDBOUND(cbBuf, 0x1000); … … 114 106 115 107 PVBOXUHGSMI_PRIVATE_D3D pPrivate = VBOXUHGSMID3D_GET(pHgsmi); 116 PVBOXUHGSMI_BUFFER_PRIVATE_D3D pBuf = (PVBOXUHGSMI_BUFFER_PRIVATE_D3D)RTMemAllocZ(RT_OFFSETOF(VBOXUHGSMI_BUFFER_PRIVATE_D3D, aLockPageIndices[cPages])); 117 Assert(pBuf); 108 PVBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE pBuf = (PVBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE)RTMemAllocZ(RT_OFFSETOF(VBOXUHGSMI_BUFFER_PRIVATE_DX_ALLOC_BASE, aLockPageIndices[cPages])); 118 109 if (pBuf) 119 110 { 120 struct 121 { 122 D3DDDICB_ALLOCATE DdiAlloc; 123 D3DDDI_ALLOCATIONINFO DdiAllocInfo; 124 VBOXWDDM_ALLOCINFO AllocInfo; 125 } Buf; 126 memset(&Buf, 0, sizeof (Buf)); 127 Buf.DdiAlloc.hResource = NULL; 128 Buf.DdiAlloc.hKMResource = NULL; 129 Buf.DdiAlloc.NumAllocations = 1; 130 Buf.DdiAlloc.pAllocationInfo = &Buf.DdiAllocInfo; 131 Buf.DdiAllocInfo.pPrivateDriverData = &Buf.AllocInfo; 132 Buf.DdiAllocInfo.PrivateDriverDataSize = sizeof (Buf.AllocInfo); 133 Buf.AllocInfo.enmType = VBOXWDDM_ALLOC_TYPE_UMD_HGSMI_BUFFER; 134 Buf.AllocInfo.cbBuffer = cbBuf; 135 Buf.AllocInfo.hSynch = hSynch; 136 Buf.AllocInfo.fUhgsmiType = fUhgsmiType; 137 138 HRESULT hr = pPrivate->pDevice->RtCallbacks.pfnAllocateCb(pPrivate->pDevice->hDevice, &Buf.DdiAlloc); 139 Assert(hr == S_OK); 111 D3DDDICB_ALLOCATE DdiAlloc; 112 D3DDDI_ALLOCATIONINFO DdiAllocInfo; 113 VBOXWDDM_ALLOCINFO AllocInfo; 114 115 memset(&DdiAlloc, 0, sizeof (DdiAlloc)); 116 DdiAlloc.hResource = NULL; 117 DdiAlloc.hKMResource = NULL; 118 DdiAlloc.NumAllocations = 1; 119 DdiAlloc.pAllocationInfo = &DdiAllocInfo; 120 DdiAllocInfo.pPrivateDriverData = &AllocInfo; 121 DdiAllocInfo.PrivateDriverDataSize = sizeof (AllocInfo); 122 AllocInfo.enmType = VBOXWDDM_ALLOC_TYPE_UMD_HGSMI_BUFFER; 123 AllocInfo.cbBuffer = cbBuf; 124 AllocInfo.hSynch = 0; 125 AllocInfo.fUhgsmiType = fType; 126 127 HRESULT hr = pPrivate->pDevice->RtCallbacks.pfnAllocateCb(pPrivate->pDevice->hDevice, &DdiAlloc); 140 128 if (hr == S_OK) 141 129 { 142 Assert( Buf.DdiAllocInfo.hAllocation);130 Assert(DdiAllocInfo.hAllocation); 143 131 pBuf->BasePrivate.Base.pfnLock = vboxUhgsmiD3DBufferLock; 144 132 pBuf->BasePrivate.Base.pfnUnlock = vboxUhgsmiD3DBufferUnlock; 145 // pBuf->Base.pfnAdjustValidDataRange = vboxUhgsmiD3DBufferAdjustValidDataRange;146 133 pBuf->BasePrivate.Base.pfnDestroy = vboxUhgsmiD3DBufferDestroy; 147 134 148 pBuf->BasePrivate.Base.fType = f UhgsmiType;135 pBuf->BasePrivate.Base.fType = fType; 149 136 pBuf->BasePrivate.Base.cbBuffer = cbBuf; 150 137 151 pBuf->pDevice = pPrivate->pDevice; 152 pBuf->BasePrivate.hAllocation = Buf.DdiAllocInfo.hAllocation; 138 pBuf->hAllocation = DdiAllocInfo.hAllocation; 153 139 154 140 *ppBuf = &pBuf->BasePrivate.Base; … … 156 142 return VINF_SUCCESS; 157 143 } 144 else 145 { 146 WARN(("pfnAllocateCb failed hr %#x")); 147 rc = VERR_GENERAL_FAILURE; 148 } 158 149 159 150 RTMemFree(pBuf); 160 151 } 161 152 else 153 { 154 WARN(("RTMemAllocZ failed")); 162 155 rc = VERR_NO_MEMORY; 163 164 if (hSynch) 165 CloseHandle(hSynch); 156 } 166 157 167 158 return rc; 168 159 } 169 160 161 /* typedef DECLCALLBACK(int) FNVBOXUHGSMI_BUFFER_SUBMIT(PVBOXUHGSMI pHgsmi, PVBOXUHGSMI_BUFFER_SUBMIT aBuffers, uint32_t cBuffers); */ 170 162 DECLCALLBACK(int) vboxUhgsmiD3DBufferSubmit(PVBOXUHGSMI pHgsmi, PVBOXUHGSMI_BUFFER_SUBMIT aBuffers, uint32_t cBuffers) 171 163 { … … 173 165 PVBOXWDDMDISP_DEVICE pDevice = pHg->pDevice; 174 166 UINT cbDmaCmd = pDevice->DefaultContext.ContextInfo.CommandBufferSize; 175 int rc = vboxUhgsmiBaseD maFill(aBuffers, cBuffers,167 int rc = vboxUhgsmiBaseDxDmaFill(aBuffers, cBuffers, 176 168 pDevice->DefaultContext.ContextInfo.pCommandBuffer, &cbDmaCmd, 177 169 pDevice->DefaultContext.ContextInfo.pAllocationList, pDevice->DefaultContext.ContextInfo.AllocationListSize, 178 170 pDevice->DefaultContext.ContextInfo.pPatchLocationList, pDevice->DefaultContext.ContextInfo.PatchLocationListSize); 179 AssertRC(rc);180 171 if (RT_FAILURE(rc)) 172 { 173 WARN(("vboxUhgsmiBaseDxDmaFill failed, rc %d", rc)); 181 174 return rc; 175 } 182 176 183 177 D3DDDICB_RENDER DdiRender = {0}; … … 194 188 195 189 HRESULT hr = pDevice->RtCallbacks.pfnRenderCb(pDevice->hDevice, &DdiRender); 196 Assert(hr == S_OK);197 190 if (hr == S_OK) 198 191 { … … 207 200 } 208 201 209 return VERR_GENERAL_FAILURE; 210 } 211 212 HRESULT vboxUhgsmiD3DInit(PVBOXUHGSMI_PRIVATE_D3D pHgsmi, PVBOXWDDMDISP_DEVICE pDevice) 202 WARN(("pfnRenderCb failed, hr %#x", hr)); 203 return VERR_GENERAL_FAILURE; 204 } 205 206 void vboxUhgsmiD3DInit(PVBOXUHGSMI_PRIVATE_D3D pHgsmi, PVBOXWDDMDISP_DEVICE pDevice) 213 207 { 214 208 pHgsmi->BasePrivate.Base.pfnBufferCreate = vboxUhgsmiD3DBufferCreate; 215 209 pHgsmi->BasePrivate.Base.pfnBufferSubmit = vboxUhgsmiD3DBufferSubmit; 210 /* no escapes (for now) */ 211 pHgsmi->BasePrivate.pfnEscape = NULL; 216 212 pHgsmi->pDevice = pDevice; 217 return S_OK; 218 } 219 #endif 213 } 220 214 221 215 static DECLCALLBACK(int) vboxCrHhgsmiDispEscape(struct VBOXUHGSMI_PRIVATE_BASE *pHgsmi, void *pvData, uint32_t cbData, BOOL fHwAccess) -
trunk/src/VBox/Additions/WINNT/Graphics/Video/disp/wddm/VBoxUhgsmiDisp.h
r44529 r49332 29 29 } VBOXUHGSMI_PRIVATE_D3D, *PVBOXUHGSMI_PRIVATE_D3D; 30 30 31 #if 032 31 void vboxUhgsmiD3DInit(PVBOXUHGSMI_PRIVATE_D3D pHgsmi, struct VBOXWDDMDISP_DEVICE *pDevice); 33 #endif34 32 35 33 void vboxUhgsmiD3DEscInit(PVBOXUHGSMI_PRIVATE_D3D pHgsmi, struct VBOXWDDMDISP_DEVICE *pDevice); -
trunk/src/VBox/Additions/WINNT/Graphics/Video/disp/wddm/VBoxUhgsmiKmt.cpp
r44529 r49332 71 71 EnterCriticalSection(&pBuffer->CritSect); 72 72 73 int rc = vboxUhgsmiBase LockData(pBuf, offLock, cbLock, fFlags,74 &DdiLock.Flags, &DdiLock.NumPages , pBuffer->aLockPageIndices);73 int rc = vboxUhgsmiBaseDxLockData(&pBuffer->BasePrivate, offLock, cbLock, fFlags, 74 &DdiLock.Flags, &DdiLock.NumPages); 75 75 AssertRC(rc); 76 76 if (RT_FAILURE(rc)) … … 194 194 PVBOXUHGSMI_PRIVATE_KMT pHg = VBOXUHGSMIKMT_GET(pHgsmi); 195 195 UINT cbDmaCmd = pHg->Context.CommandBufferSize; 196 int rc = vboxUhgsmiBaseD maFill(aBuffers, cBuffers,196 int rc = vboxUhgsmiBaseDxDmaFill(aBuffers, cBuffers, 197 197 pHg->Context.pCommandBuffer, &cbDmaCmd, 198 198 pHg->Context.pAllocationList, pHg->Context.AllocationListSize, -
trunk/src/VBox/Additions/WINNT/Graphics/Video/mp/Makefile.kmk
r48944 r49332 118 118 common/VBoxMPVidModes.cpp \ 119 119 $(PATH_ROOT)/src/VBox/Additions/common/VBoxVideo/HGSMIBase.cpp \ 120 $(PATH_ROOT)/src/VBox/Additions/common/VBoxVideo/VBVABase.cpp \ 120 121 $(PATH_ROOT)/src/VBox/Additions/common/VBoxVideo/Modesetting.cpp \ 121 122 $(PATH_ROOT)/src/VBox/GuestHost/OpenGL/util/vreg.cpp -
trunk/src/VBox/Additions/WINNT/Graphics/Video/mp/common/VBoxMPDevExt.h
r48070 r49332 208 208 #ifdef VBOXWDDM_RENDER_FROM_SHADOW 209 209 /* all memory layout info should be initialized */ 210 Assert(pDevExt->aSources[0].Vbva. offVBVA);210 Assert(pDevExt->aSources[0].Vbva.Vbva.offVRAMBuffer); 211 211 /* page aligned */ 212 Assert(!(pDevExt->aSources[0].Vbva. offVBVA& 0xfff));213 214 return (ULONG)(pDevExt->aSources[0].Vbva. offVBVA& ~0xfffULL);212 Assert(!(pDevExt->aSources[0].Vbva.Vbva.offVRAMBuffer & 0xfff)); 213 214 return (ULONG)(pDevExt->aSources[0].Vbva.Vbva.offVRAMBuffer & ~0xfffULL); 215 215 #else 216 216 /* all memory layout info should be initialized */ -
trunk/src/VBox/Additions/WINNT/Graphics/Video/mp/wddm/VBoxMPVbva.cpp
r44529 r49332 20 20 #include "common/VBoxMPCommon.h" 21 21 22 static int vboxVBVAInformHost (PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO * pVbva, BOOL bEnable)23 {24 int rc = VERR_NO_MEMORY;25 void *p = VBoxHGSMIBufferAlloc (&VBoxCommonFromDeviceExt(pDevExt)->guestCtx,26 sizeof (VBVAENABLE_EX),27 HGSMI_CH_VBVA,28 VBVA_ENABLE);29 Assert(p);30 if (!p)31 {32 LOGREL(("HGSMIHeapAlloc failed"));33 rc = VERR_NO_MEMORY;34 }35 else36 {37 VBVAENABLE_EX *pEnableEx = (VBVAENABLE_EX *)p;38 pEnableEx->u32ScreenId = pVbva->srcId;39 40 VBVAENABLE *pEnable = &pEnableEx->Base;41 pEnable->u32Flags = bEnable? VBVA_F_ENABLE: VBVA_F_DISABLE;42 pEnable->u32Flags |= VBVA_F_EXTENDED | VBVA_F_ABSOFFSET;43 pEnable->u32Offset = (uint32_t)pVbva->offVBVA;44 pEnable->i32Result = VERR_NOT_SUPPORTED;45 46 VBoxHGSMIBufferSubmit (&VBoxCommonFromDeviceExt(pDevExt)->guestCtx, p);47 48 if (bEnable)49 {50 rc = pEnable->i32Result;51 AssertRC(rc);52 }53 else54 rc = VINF_SUCCESS;55 56 VBoxHGSMIBufferFree (&VBoxCommonFromDeviceExt(pDevExt)->guestCtx, p);57 }58 return rc;59 }60 61 22 /* 62 23 * Public hardware buffer methods. … … 64 25 int vboxVbvaEnable (PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva) 65 26 { 66 VBVABUFFER *pVBVA = pVbva->pVBVA; 27 if (VBoxVBVAEnable(&pVbva->Vbva, &VBoxCommonFromDeviceExt(pDevExt)->guestCtx, 28 pVbva->Vbva.pVBVA, pVbva->srcId)) 29 return VINF_SUCCESS; 67 30 68 // DISPDBG((1, "VBoxDisp::vboxVbvaEnable screen %p vbva off 0x%x\n", ppdev->pjScreen, ppdev->layout.offVBVABuffer)); 69 70 pVBVA->hostFlags.u32HostEvents = 0; 71 pVBVA->hostFlags.u32SupportedOrders = 0; 72 pVBVA->off32Data = 0; 73 pVBVA->off32Free = 0; 74 RtlZeroMemory (pVBVA->aRecords, sizeof (pVBVA->aRecords)); 75 pVBVA->indexRecordFirst = 0; 76 pVBVA->indexRecordFree = 0; 77 pVBVA->cbPartialWriteThreshold = 256; 78 pVBVA->cbData = pVbva->cbVBVA - sizeof (VBVABUFFER) + sizeof (pVBVA->au8Data); 79 80 pVbva->fHwBufferOverflow = FALSE; 81 pVbva->pRecord = NULL; 82 83 int rc = vboxVBVAInformHost (pDevExt, pVbva, TRUE); 84 AssertRC(rc); 85 86 if (!RT_SUCCESS(rc)) 87 vboxVbvaDisable (pDevExt, pVbva); 88 89 return rc; 31 WARN(("VBoxVBVAEnable failed!")); 32 return VERR_GENERAL_FAILURE; 90 33 } 91 34 92 35 int vboxVbvaDisable (PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva) 93 36 { 94 // DISPDBG((1, "VBoxDisp::vbvaDisable called.\n")); 95 96 pVbva->fHwBufferOverflow = FALSE; 97 pVbva->pRecord = NULL; 98 // ppdev->pVBVA = NULL; 99 100 return vboxVBVAInformHost (pDevExt, pVbva, FALSE); 37 VBoxVBVADisable(&pVbva->Vbva, &VBoxCommonFromDeviceExt(pDevExt)->guestCtx, pVbva->srcId); 38 return VINF_SUCCESS; 101 39 } 102 40 … … 108 46 109 47 int rc = VBoxMPCmnMapAdapterMemory(VBoxCommonFromDeviceExt(pDevExt), 110 (void**)&pVbva-> pVBVA,48 (void**)&pVbva->Vbva.pVBVA, 111 49 offBuffer, 112 50 cbBuffer); … … 114 52 if (RT_SUCCESS(rc)) 115 53 { 116 Assert(pVbva->pVBVA); 117 pVbva->offVBVA = offBuffer; 118 pVbva->cbVBVA = cbBuffer; 54 Assert(pVbva->Vbva.pVBVA); 55 VBoxVBVASetupBufferContext(&pVbva->Vbva, offBuffer, cbBuffer); 119 56 pVbva->srcId = srcId; 120 57 } … … 126 63 { 127 64 int rc = VINF_SUCCESS; 128 VBoxMPCmnUnmapAdapterMemory(VBoxCommonFromDeviceExt(pDevExt), (void**)&pVbva-> pVBVA);129 memset(pVbva, 0, sizeof (VBOXVBVAINFO));65 VBoxMPCmnUnmapAdapterMemory(VBoxCommonFromDeviceExt(pDevExt), (void**)&pVbva->Vbva.pVBVA); 66 memset(pVbva, 0, sizeof (VBOXVBVAINFO)); 130 67 return rc; 131 68 } 132 69 133 /*134 * Private operations.135 */136 static uint32_t vboxHwBufferAvail (const VBVABUFFER *pVBVA)137 {138 int32_t i32Diff = pVBVA->off32Data - pVBVA->off32Free;139 140 return i32Diff > 0? i32Diff: pVBVA->cbData + i32Diff;141 }142 143 static void vboxHwBufferFlush (PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva)144 {145 /* Issue the flush command. */146 void *p = VBoxHGSMIBufferAlloc (&VBoxCommonFromDeviceExt(pDevExt)->guestCtx,147 sizeof (VBVAFLUSH),148 HGSMI_CH_VBVA,149 VBVA_FLUSH);150 Assert(p);151 if (!p)152 {153 LOGREL(("HGSMIHeapAlloc failed"));154 }155 else156 {157 VBVAFLUSH *pFlush = (VBVAFLUSH *)p;158 159 pFlush->u32Reserved = 0;160 161 VBoxHGSMIBufferSubmit (&VBoxCommonFromDeviceExt(pDevExt)->guestCtx, p);162 163 VBoxHGSMIBufferFree (&VBoxCommonFromDeviceExt(pDevExt)->guestCtx, p);164 }165 166 return;167 }168 169 static void vboxHwBufferPlaceDataAt (VBVABUFFER *pVBVA, const void *p, uint32_t cb, uint32_t offset)170 {171 uint32_t u32BytesTillBoundary = pVBVA->cbData - offset;172 uint8_t *dst = &pVBVA->au8Data[offset];173 int32_t i32Diff = cb - u32BytesTillBoundary;174 175 if (i32Diff <= 0)176 {177 /* Chunk will not cross buffer boundary. */178 memcpy (dst, p, cb);179 }180 else181 {182 /* Chunk crosses buffer boundary. */183 memcpy (dst, p, u32BytesTillBoundary);184 memcpy (&pVBVA->au8Data[0], (uint8_t *)p + u32BytesTillBoundary, i32Diff);185 }186 187 return;188 }189 190 BOOL vboxVbvaBufferBeginUpdate (PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva)191 {192 BOOL bRc = FALSE;193 194 // DISPDBG((1, "VBoxDisp::vboxHwBufferBeginUpdate called flags = 0x%08X\n",195 // ppdev->pVBVA? ppdev->pVBVA->u32HostEvents: -1));196 197 if ( pVbva->pVBVA198 && (pVbva->pVBVA->hostFlags.u32HostEvents & VBVA_F_MODE_ENABLED))199 {200 uint32_t indexRecordNext;201 202 Assert (!pVbva->fHwBufferOverflow);203 Assert (pVbva->pRecord == NULL);204 205 indexRecordNext = (pVbva->pVBVA->indexRecordFree + 1) % VBVA_MAX_RECORDS;206 207 if (indexRecordNext == pVbva->pVBVA->indexRecordFirst)208 {209 /* All slots in the records queue are used. */210 vboxHwBufferFlush (pDevExt, pVbva);211 }212 213 if (indexRecordNext == pVbva->pVBVA->indexRecordFirst)214 {215 // /* Even after flush there is no place. Fail the request. */216 // LOG(("no space in the queue of records!!! first %d, last %d",217 // ppdev->pVBVA->indexRecordFirst, ppdev->pVBVA->indexRecordFree));218 }219 else220 {221 /* Initialize the record. */222 VBVARECORD *pRecord = &pVbva->pVBVA->aRecords[pVbva->pVBVA->indexRecordFree];223 224 pRecord->cbRecord = VBVA_F_RECORD_PARTIAL;225 226 pVbva->pVBVA->indexRecordFree = indexRecordNext;227 228 // LOG(("indexRecordNext = %d\n", indexRecordNext));229 230 /* Remember which record we are using. */231 pVbva->pRecord = pRecord;232 233 bRc = TRUE;234 }235 }236 237 return bRc;238 }239 240 void vboxVbvaBufferEndUpdate (PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva)241 {242 VBVARECORD *pRecord;243 244 // LOG(("VBoxDisp::vboxHwBufferEndUpdate called"));245 246 Assert(pVbva->pVBVA);247 248 pRecord = pVbva->pRecord;249 Assert (pRecord && (pRecord->cbRecord & VBVA_F_RECORD_PARTIAL));250 251 /* Mark the record completed. */252 pRecord->cbRecord &= ~VBVA_F_RECORD_PARTIAL;253 254 pVbva->fHwBufferOverflow = FALSE;255 pVbva->pRecord = NULL;256 257 return;258 }259 260 static int vboxHwBufferWrite (PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva, const void *p, uint32_t cb)261 {262 VBVARECORD *pRecord;263 uint32_t cbHwBufferAvail;264 265 uint32_t cbWritten = 0;266 267 VBVABUFFER *pVBVA = pVbva->pVBVA;268 Assert(pVBVA);269 270 if (!pVBVA || pVbva->fHwBufferOverflow)271 {272 return VERR_INVALID_STATE;273 }274 275 Assert (pVBVA->indexRecordFirst != pVBVA->indexRecordFree);276 277 pRecord = pVbva->pRecord;278 Assert (pRecord && (pRecord->cbRecord & VBVA_F_RECORD_PARTIAL));279 280 // LOGF(("VW %d", cb));281 282 cbHwBufferAvail = vboxHwBufferAvail (pVBVA);283 284 while (cb > 0)285 {286 uint32_t cbChunk = cb;287 288 // LOG(("pVBVA->off32Free %d, pRecord->cbRecord 0x%08X, cbHwBufferAvail %d, cb %d, cbWritten %d\n",289 // pVBVA->off32Free, pRecord->cbRecord, cbHwBufferAvail, cb, cbWritten));290 291 if (cbChunk >= cbHwBufferAvail)292 {293 LOG(("1) avail %d, chunk %d", cbHwBufferAvail, cbChunk));294 295 vboxHwBufferFlush (pDevExt, pVbva);296 297 cbHwBufferAvail = vboxHwBufferAvail (pVBVA);298 299 if (cbChunk >= cbHwBufferAvail)300 {301 LOG(("no place for %d bytes. Only %d bytes available after flush. Going to partial writes.",302 cb, cbHwBufferAvail));303 304 if (cbHwBufferAvail <= pVBVA->cbPartialWriteThreshold)305 {306 LOGREL(("Buffer overflow!!!"));307 pVbva->fHwBufferOverflow = TRUE;308 Assert(FALSE);309 return VERR_NO_MEMORY;310 }311 312 cbChunk = cbHwBufferAvail - pVBVA->cbPartialWriteThreshold;313 }314 }315 316 Assert(cbChunk <= cb);317 Assert(cbChunk <= vboxHwBufferAvail (pVBVA));318 319 vboxHwBufferPlaceDataAt (pVbva->pVBVA, (uint8_t *)p + cbWritten, cbChunk, pVBVA->off32Free);320 321 pVBVA->off32Free = (pVBVA->off32Free + cbChunk) % pVBVA->cbData;322 pRecord->cbRecord += cbChunk;323 cbHwBufferAvail -= cbChunk;324 325 cb -= cbChunk;326 cbWritten += cbChunk;327 }328 329 return VINF_SUCCESS;330 }331 332 /*333 * Public writer to the hardware buffer.334 */335 int vboxWrite (PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva, const void *pv, uint32_t cb)336 {337 return vboxHwBufferWrite (pDevExt, pVbva, pv, cb);338 }339 340 341 70 int vboxVbvaReportDirtyRect (PVBOXMP_DEVEXT pDevExt, PVBOXWDDM_SOURCE pSrc, RECT *pRectOrig) 342 71 { 343 72 VBVACMDHDR hdr; 344 73 345 74 RECT rect = *pRectOrig; 346 75 347 76 // if (rect.left < 0) rect.left = 0; … … 350 79 // if (rect.bottom > (int)ppdev->cyScreen) rect.bottom = ppdev->cyScreen; 351 80 352 353 354 355 81 hdr.x = (int16_t)rect.left; 82 hdr.y = (int16_t)rect.top; 83 hdr.w = (uint16_t)(rect.right - rect.left); 84 hdr.h = (uint16_t)(rect.bottom - rect.top); 356 85 357 358 86 hdr.x += (int16_t)pSrc->VScreenPos.x; 87 hdr.y += (int16_t)pSrc->VScreenPos.y; 359 88 360 return vboxWrite (pDevExt, &pSrc->Vbva, &hdr, sizeof(hdr)); 89 if (VBoxVBVAWrite(&pSrc->Vbva.Vbva, &VBoxCommonFromDeviceExt(pDevExt)->guestCtx, &hdr, sizeof(hdr))) 90 return VINF_SUCCESS; 91 92 WARN(("VBoxVBVAWrite failed")); 93 return VERR_GENERAL_FAILURE; 361 94 } 362 95 -
trunk/src/VBox/Additions/WINNT/Graphics/Video/mp/wddm/VBoxMPVbva.h
r37626 r49332 22 22 typedef struct VBOXVBVAINFO 23 23 { 24 VBOXVIDEOOFFSET offVBVA; 25 uint32_t cbVBVA; 26 VBVABUFFER *pVBVA; 27 BOOL fHwBufferOverflow; 28 VBVARECORD *pRecord; 24 VBVABUFFERCONTEXT Vbva; 29 25 D3DDDI_VIDEO_PRESENT_SOURCE_ID srcId; 30 26 KSPIN_LOCK Lock; … … 37 33 int vboxVbvaReportCmdOffset(PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva, uint32_t offCmd); 38 34 int vboxVbvaReportDirtyRect(PVBOXMP_DEVEXT pDevExt, struct VBOXWDDM_SOURCE *pSrc, RECT *pRectOrig); 39 BOOL vboxVbvaBufferBeginUpdate(PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva);40 void vboxVbvaBufferEndUpdate(PVBOXMP_DEVEXT pDevExt, VBOXVBVAINFO *pVbva);41 35 42 36 #define VBOXVBVA_OP(_op, _pdext, _psrc, _arg) \ 43 37 do { \ 44 if ( vboxVbvaBufferBeginUpdate(_pdext, &(_psrc)->Vbva)) \38 if (VBoxVBVABufferBeginUpdate(&(_psrc)->Vbva.Vbva, &VBoxCommonFromDeviceExt(_pdext)->guestCtx)) \ 45 39 { \ 46 40 vboxVbva##_op(_pdext, _psrc, _arg); \ 47 vboxVbvaBufferEndUpdate(_pdext, &(_psrc)->Vbva); \41 VBoxVBVABufferEndUpdate(&(_psrc)->Vbva.Vbva); \ 48 42 } \ 49 43 } while (0)
Note:
See TracChangeset
for help on using the changeset viewer.