dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync/* $Id$ */
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync/** @file
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * VBoxVideo Display D3D User mode dll
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync */
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync/*
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * Copyright (C) 2012 Oracle Corporation
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync *
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * available from http://www.virtualbox.org. This file is free software;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * you can redistribute it and/or modify it under the terms of the GNU
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * General Public License (GPL) as published by the Free Software
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync */
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#ifndef ___VBoxDispD3DRcIf_h__
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#define ___VBoxDispD3DRcIf_h__
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#include "VBoxDispD3DCmn.h"
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncstatic D3DFORMAT vboxDDI2D3DFormat(D3DDDIFORMAT format);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncD3DMULTISAMPLE_TYPE vboxDDI2D3DMultiSampleType(D3DDDIMULTISAMPLE_TYPE enmType);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncD3DPOOL vboxDDI2D3DPool(D3DDDI_POOL enmPool);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncD3DRENDERSTATETYPE vboxDDI2D3DRenderStateType(D3DDDIRENDERSTATETYPE enmType);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncVBOXWDDMDISP_TSS_LOOKUP vboxDDI2D3DTestureStageStateType(D3DDDITEXTURESTAGESTATETYPE enmType);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncDWORD vboxDDI2D3DUsage(D3DDDI_RESOURCEFLAGS fFlags);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncDWORD vboxDDI2D3DLockFlags(D3DDDI_LOCKFLAGS fLockFlags);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncD3DTEXTUREFILTERTYPE vboxDDI2D3DBltFlags(D3DDDI_BLTFLAGS fFlags);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncD3DQUERYTYPE vboxDDI2D3DQueryType(D3DDDIQUERYTYPE enmType);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncDWORD vboxDDI2D3DIssueQueryFlags(D3DDDI_ISSUEQUERYFLAGS Flags);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncHRESULT VBoxD3DIfCreateForRc(struct VBOXWDDMDISP_RESOURCE *pRc);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncHRESULT VBoxD3DIfLockRect(struct VBOXWDDMDISP_RESOURCE *pRc, UINT iAlloc,
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync D3DLOCKED_RECT * pLockedRect,
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync CONST RECT *pRect,
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync DWORD fLockFlags);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncHRESULT VBoxD3DIfUnlockRect(struct VBOXWDDMDISP_RESOURCE *pRc, UINT iAlloc);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncvoid VBoxD3DIfLockUnlockMemSynch(struct VBOXWDDMDISP_ALLOCATION *pAlloc, D3DLOCKED_RECT *pLockInfo, RECT *pRect, bool bToLockInfo);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
1c0d3d017f9a45748b4839bf6622b53e83a4f1f8vboxsyncIUnknown* vboxD3DIfCreateSharedPrimary(PVBOXWDDMDISP_ALLOCATION pAlloc);
1c0d3d017f9a45748b4839bf6622b53e83a4f1f8vboxsync
1c0d3d017f9a45748b4839bf6622b53e83a4f1f8vboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync/* NOTE: does NOT increment a ref counter! NO Release needed!! */
1c0d3d017f9a45748b4839bf6622b53e83a4f1f8vboxsyncDECLINLINE(IUnknown*) vboxD3DIfGet(PVBOXWDDMDISP_ALLOCATION pAlloc)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync{
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync if (pAlloc->pD3DIf)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync return pAlloc->pD3DIf;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync if (pAlloc->enmType != VBOXWDDM_ALLOC_TYPE_STD_SHAREDPRIMARYSURFACE)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync {
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync WARN(("dynamic creation is supported for VBOXWDDM_ALLOC_TYPE_STD_SHAREDPRIMARYSURFACE only!, current type is %d", pAlloc->enmType));
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync return NULL;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync }
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
1c0d3d017f9a45748b4839bf6622b53e83a4f1f8vboxsync return vboxD3DIfCreateSharedPrimary(pAlloc);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync}
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync/* on success increments the surface ref counter,
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * i.e. one must call pSurf->Release() once the surface is not needed*/
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncDECLINLINE(HRESULT) VBoxD3DIfSurfGet(PVBOXWDDMDISP_RESOURCE pRc, UINT iAlloc, IDirect3DSurface9 **ppSurf)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync{
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync HRESULT hr = S_OK;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(pRc->cAllocations > iAlloc);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync *ppSurf = NULL;
1c0d3d017f9a45748b4839bf6622b53e83a4f1f8vboxsync IUnknown* pD3DIf = vboxD3DIfGet(&pRc->aAllocations[iAlloc]);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync switch (pRc->aAllocations[0].enmD3DIfType)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync {
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync case VBOXDISP_D3DIFTYPE_SURFACE:
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync {
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync IDirect3DSurface9 *pD3DIfSurf = (IDirect3DSurface9*)pD3DIf;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(pD3DIfSurf);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync pD3DIfSurf->AddRef();
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync *ppSurf = pD3DIfSurf;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync break;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync }
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync case VBOXDISP_D3DIFTYPE_TEXTURE:
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync {
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(pRc->cAllocations == 1); /* <- VBoxD3DIfSurfGet is typically used in Blt & ColorFill functions
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * in this case, if texture is used as a destination,
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * we should update sub-layers as well which is not done currently
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync * so for now check VBoxD3DIfSurfGet is used for one-level textures */
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync IDirect3DTexture9 *pD3DIfTex = (IDirect3DTexture9*)pD3DIf;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync IDirect3DSurface9 *pSurfaceLevel;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(pD3DIfTex);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync hr = pD3DIfTex->GetSurfaceLevel(iAlloc, &pSurfaceLevel);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(hr == S_OK);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync if (hr == S_OK)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync {
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync *ppSurf = pSurfaceLevel;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync }
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync break;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync }
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync case VBOXDISP_D3DIFTYPE_CUBE_TEXTURE:
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync {
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync IDirect3DCubeTexture9 *pD3DIfCubeTex = (IDirect3DCubeTexture9*)pD3DIf;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync IDirect3DSurface9 *pSurfaceLevel;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(pD3DIfCubeTex);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync hr = pD3DIfCubeTex->GetCubeMapSurface(VBOXDISP_CUBEMAP_INDEX_TO_FACE(pRc, iAlloc),
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync VBOXDISP_CUBEMAP_INDEX_TO_LEVEL(pRc, iAlloc), &pSurfaceLevel);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(hr == S_OK);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync if (hr == S_OK)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync {
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync *ppSurf = pSurfaceLevel;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync }
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync break;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync }
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync default:
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync {
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync WARN(("unexpected enmD3DIfType %d", pRc->aAllocations[0].enmD3DIfType));
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync hr = E_FAIL;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync break;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync }
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync }
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync return hr;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync}
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncVOID VBoxD3DIfFillPresentParams(D3DPRESENT_PARAMETERS *pParams, PVBOXWDDMDISP_RESOURCE pRc, UINT cRTs);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncHRESULT VBoxD3DIfDeviceCreateDummy(PVBOXWDDMDISP_DEVICE pDevice);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsyncDECLINLINE(IDirect3DDevice9*) VBoxD3DIfDeviceGet(PVBOXWDDMDISP_DEVICE pDevice)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync{
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync if (pDevice->pDevice9If)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync return pDevice->pDevice9If;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#ifdef VBOXWDDMDISP_DEBUG
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync g_VBoxVDbgInternalDevice = pDevice;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#endif
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync HRESULT hr = VBoxD3DIfDeviceCreateDummy(pDevice);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(hr == S_OK);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync Assert(pDevice->pDevice9If);
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync return pDevice->pDevice9If;
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync}
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#define VBOXDISPMODE_IS_3D(_p) (!!((_p)->D3D.pD3D9If))
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#ifdef VBOXDISP_EARLYCREATEDEVICE
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#define VBOXDISP_D3DEV(_p) (_p)->pDevice9If
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#else
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#define VBOXDISP_D3DEV(_p) VBoxD3DIfDeviceGet(_p)
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#endif
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync
dc4c9f05c58012e8b1f0bfdd12b2e14fc2f228devboxsync#endif /* ___VBoxDispD3DRcIf_h__ */