VirtualBox

source: vbox/trunk/src/VBox/Additions/WINNT/Graphics/Video/disp/xpdm/VBoxDispVHWA.h@ 106061

Last change on this file since 106061 was 106061, checked in by vboxsync, 5 months ago

Copyright year updates by scm.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.1 KB
Line 
1/* $Id: VBoxDispVHWA.h 106061 2024-09-16 14:03:52Z vboxsync $ */
2/** @file
3 * VBox XPDM Display driver, helper functions which interacts with our miniport driver
4 */
5
6/*
7 * Copyright (C) 2011-2024 Oracle and/or its affiliates.
8 *
9 * This file is part of VirtualBox base platform packages, as
10 * available from https://www.virtualbox.org.
11 *
12 * This program is free software; you can redistribute it and/or
13 * modify it under the terms of the GNU General Public License
14 * as published by the Free Software Foundation, in version 3 of the
15 * License.
16 *
17 * This program is distributed in the hope that it will be useful, but
18 * WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 * General Public License for more details.
21 *
22 * You should have received a copy of the GNU General Public License
23 * along with this program; if not, see <https://www.gnu.org/licenses>.
24 *
25 * SPDX-License-Identifier: GPL-3.0-only
26 */
27
28#ifndef GA_INCLUDED_SRC_WINNT_Graphics_Video_disp_xpdm_VBoxDispVHWA_h
29#define GA_INCLUDED_SRC_WINNT_Graphics_Video_disp_xpdm_VBoxDispVHWA_h
30#ifndef RT_WITHOUT_PRAGMA_ONCE
31# pragma once
32#endif
33
34#include "VBoxDisp.h"
35
36#ifdef VBOX_WITH_VIDEOHWACCEL
37typedef struct _VBOXDISPVHWAINFO
38{
39 uint32_t caps;
40 uint32_t caps2;
41 uint32_t colorKeyCaps;
42 uint32_t stretchCaps;
43 uint32_t surfaceCaps;
44 uint32_t numOverlays;
45 uint32_t numFourCC;
46 HGSMIOFFSET FourCC;
47 ULONG_PTR offVramBase;
48 BOOLEAN bEnabled;
49} VBOXDISPVHWAINFO;
50#endif
51
52typedef struct _VBOXVHWAREGION
53{
54 RECTL Rect;
55 bool bValid;
56}VBOXVHWAREGION, *PVBOXVHWAREGION;
57
58typedef struct _VBOXVHWASURFDESC
59{
60 VBOXVHWA_SURFHANDLE hHostHandle;
61 volatile uint32_t cPendingBltsSrc;
62 volatile uint32_t cPendingBltsDst;
63 volatile uint32_t cPendingFlipsCurr;
64 volatile uint32_t cPendingFlipsTarg;
65#ifdef DEBUG
66 volatile uint32_t cFlipsCurr;
67 volatile uint32_t cFlipsTarg;
68#endif
69 bool bVisible;
70 VBOXVHWAREGION UpdatedMemRegion;
71 VBOXVHWAREGION NonupdatedMemRegion;
72}VBOXVHWASURFDESC, *PVBOXVHWASURFDESC;
73
74typedef DECLCALLBACKTYPE(void, FNVBOXVHWACMDCOMPLETION,(PVBOXDISPDEV pDev, VBOXVHWACMD RT_UNTRUSTED_VOLATILE_HOST *pCmd,
75 void *pvContext));
76typedef FNVBOXVHWACMDCOMPLETION *PFNVBOXVHWACMDCOMPLETION;
77
78void VBoxDispVHWAInit(PVBOXDISPDEV pDev);
79int VBoxDispVHWAEnable(PVBOXDISPDEV pDev);
80int VBoxDispVHWADisable(PVBOXDISPDEV pDev);
81int VBoxDispVHWAInitHostInfo1(PVBOXDISPDEV pDev);
82int VBoxDispVHWAInitHostInfo2(PVBOXDISPDEV pDev, DWORD *pFourCC);
83
84VBOXVHWACMD RT_UNTRUSTED_VOLATILE_HOST *VBoxDispVHWACommandCreate(PVBOXDISPDEV pDev, VBOXVHWACMD_TYPE enmCmd, VBOXVHWACMD_LENGTH cbCmd);
85void VBoxDispVHWACommandRelease(PVBOXDISPDEV pDev, VBOXVHWACMD RT_UNTRUSTED_VOLATILE_HOST *pCmd);
86BOOL VBoxDispVHWACommandSubmit(PVBOXDISPDEV pDev, VBOXVHWACMD RT_UNTRUSTED_VOLATILE_HOST*pCmd);
87void VBoxDispVHWACommandSubmitAsynch(PVBOXDISPDEV pDev, VBOXVHWACMD RT_UNTRUSTED_VOLATILE_HOST *pCmd,
88 PFNVBOXVHWACMDCOMPLETION pfnCompletion, void * pContext);
89void VBoxDispVHWACommandSubmitAsynchAndComplete(PVBOXDISPDEV pDev, VBOXVHWACMD RT_UNTRUSTED_VOLATILE_HOST *pCmd);
90void VBoxDispVHWACommandCheckHostCmds(PVBOXDISPDEV pDev);
91
92PVBOXVHWASURFDESC VBoxDispVHWASurfDescAlloc();
93void VBoxDispVHWASurfDescFree(PVBOXVHWASURFDESC pDesc);
94
95uint64_t VBoxDispVHWAVramOffsetFromPDEV(PVBOXDISPDEV pDev, ULONG_PTR offPdev);
96
97void VBoxDispVHWARectUnited(RECTL * pDst, RECTL * pRect1, RECTL * pRect2);
98bool VBoxDispVHWARectIsEmpty(RECTL * pRect);
99bool VBoxDispVHWARectIntersect(RECTL * pRect1, RECTL * pRect2);
100bool VBoxDispVHWARectInclude(RECTL * pRect1, RECTL * pRect2);
101bool VBoxDispVHWARegionIntersects(PVBOXVHWAREGION pReg, RECTL * pRect);
102bool VBoxDispVHWARegionIncludes(PVBOXVHWAREGION pReg, RECTL * pRect);
103bool VBoxDispVHWARegionIncluded(PVBOXVHWAREGION pReg, RECTL * pRect);
104void VBoxDispVHWARegionSet(PVBOXVHWAREGION pReg, RECTL * pRect);
105void VBoxDispVHWARegionAdd(PVBOXVHWAREGION pReg, RECTL * pRect);
106void VBoxDispVHWARegionInit(PVBOXVHWAREGION pReg);
107void VBoxDispVHWARegionClear(PVBOXVHWAREGION pReg);
108bool VBoxDispVHWARegionValid(PVBOXVHWAREGION pReg);
109void VBoxDispVHWARegionTrySubstitute(PVBOXVHWAREGION pReg, const RECTL *pRect);
110
111uint32_t VBoxDispVHWAFromDDCAPS(uint32_t caps);
112uint32_t VBoxDispVHWAToDDCAPS(uint32_t caps);
113uint32_t VBoxDispVHWAFromDDSCAPS(uint32_t caps);
114uint32_t VBoxDispVHWAToDDSCAPS(uint32_t caps);
115uint32_t VBoxDispVHWAFromDDPFS(uint32_t caps);
116uint32_t VBoxDispVHWAToDDPFS(uint32_t caps);
117uint32_t VBoxDispVHWAFromDDCKEYCAPS(uint32_t caps);
118uint32_t VBoxDispVHWAToDDCKEYCAPS(uint32_t caps);
119uint32_t VBoxDispVHWAToDDBLTs(uint32_t caps);
120uint32_t VBoxDispVHWAFromDDBLTs(uint32_t caps);
121uint32_t VBoxDispVHWAFromDDCAPS2(uint32_t caps);
122uint32_t VBoxDispVHWAToDDCAPS2(uint32_t caps);
123uint32_t VBoxDispVHWAFromDDOVERs(uint32_t caps);
124uint32_t VBoxDispVHWAToDDOVERs(uint32_t caps);
125uint32_t VBoxDispVHWAFromDDCKEYs(uint32_t caps);
126uint32_t VBoxDispVHWAToDDCKEYs(uint32_t caps);
127
128int VBoxDispVHWAFromDDSURFACEDESC(VBOXVHWA_SURFACEDESC RT_UNTRUSTED_VOLATILE_HOST *pVHWADesc, DDSURFACEDESC *pDdDesc);
129int VBoxDispVHWAFromDDPIXELFORMAT(VBOXVHWA_PIXELFORMAT RT_UNTRUSTED_VOLATILE_HOST *pVHWAFormat, DDPIXELFORMAT *pDdFormat);
130void VBoxDispVHWAFromDDOVERLAYFX(VBOXVHWA_OVERLAYFX RT_UNTRUSTED_VOLATILE_HOST *pVHWAOverlay, DDOVERLAYFX *pDdOverlay);
131void VBoxDispVHWAFromDDCOLORKEY(VBOXVHWA_COLORKEY RT_UNTRUSTED_VOLATILE_HOST *pVHWACKey, DDCOLORKEY *pDdCKey);
132void VBoxDispVHWAFromDDBLTFX(VBOXVHWA_BLTFX RT_UNTRUSTED_VOLATILE_HOST *pVHWABlt, DDBLTFX *pDdBlt);
133void VBoxDispVHWAFromRECTL(VBOXVHWA_RECTL *pDst, RECTL const *pSrc);
134void VBoxDispVHWAFromRECTL(VBOXVHWA_RECTL RT_UNTRUSTED_VOLATILE_HOST *pDst, RECTL const *pSrc);
135
136uint32_t VBoxDispVHWAUnsupportedDDCAPS(uint32_t caps);
137uint32_t VBoxDispVHWAUnsupportedDDSCAPS(uint32_t caps);
138uint32_t VBoxDispVHWAUnsupportedDDPFS(uint32_t caps);
139uint32_t VBoxDispVHWAUnsupportedDDCEYCAPS(uint32_t caps);
140uint32_t VBoxDispVHWASupportedDDCAPS(uint32_t caps);
141uint32_t VBoxDispVHWASupportedDDSCAPS(uint32_t caps);
142uint32_t VBoxDispVHWASupportedDDPFS(uint32_t caps);
143uint32_t VBoxDispVHWASupportedDDCEYCAPS(uint32_t caps);
144
145#endif /* !GA_INCLUDED_SRC_WINNT_Graphics_Video_disp_xpdm_VBoxDispVHWA_h */
146
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette