VirtualBox

source: vbox/trunk/src/VBox/Devices/Graphics/DevVGA-SVGA3d.h@ 57761

Last change on this file since 57761 was 57151, checked in by vboxsync, 9 years ago

VMSVGA3d: Started reworking 3d command handling code to avoid duplicating code and ending up with slightly different versions. E.g. the input validation is the same regardless of the backend.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 11.2 KB
Line 
1/* $Id: DevVGA-SVGA3d.h 57151 2015-08-02 19:46:25Z vboxsync $ */
2/** @file
3 * DevVMWare - VMWare SVGA device - 3D part.
4 */
5
6/*
7 * Copyright (C) 2013-2015 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 */
17
18#ifndef ___DEVVMWARE3D_H___
19#define ___DEVVMWARE3D_H___
20
21#include "vmsvga/svga_reg.h"
22#include "vmsvga/svga3d_reg.h"
23#include "vmsvga/svga_escape.h"
24#include "vmsvga/svga_overlay.h"
25
26
27/** Arbitrary limit */
28#define SVGA3D_MAX_SHADER_IDS 0x800
29/** D3D allows up to 8 texture stages. */
30#define SVGA3D_MAX_TEXTURE_STAGE 8
31/** Arbitrary upper limit; seen 8 so far. */
32#define SVGA3D_MAX_LIGHTS 32
33
34
35/**@def FLOAT_FMT_STR
36 * Format string bits to go with FLOAT_FMT_ARGS. */
37#define FLOAT_FMT_STR "%d.%06d"
38/** @def FLOAT_FMT_ARGS
39 * Format arguments for a float value, corresponding to FLOAT_FMT_STR.
40 * @param r The floating point value to format. */
41#define FLOAT_FMT_ARGS(r) (int)(r), ((unsigned)((r) * 1000000) % 1000000U)
42
43
44/* DevVGA-SVGA.cpp: */
45void vmsvgaGMRFree(PVGASTATE pThis, uint32_t idGMR);
46int vmsvgaGMRTransfer(PVGASTATE pThis, const SVGA3dTransferType enmTransferType, uint8_t *pDest, int32_t cbDestPitch,
47 SVGAGuestPtr src, uint32_t offSrc, int32_t cbSrcPitch, uint32_t cbWidth, uint32_t cHeight);
48void vmsvga3dSurfaceUpdateHeapBuffersOnFifoThread(PVGASTATE pThis, uint32_t sid);
49
50
51/* DevVGA-SVGA3d-ogl.cpp & DevVGA-SVGA3d-win.cpp: */
52int vmsvga3dInit(PVGASTATE pThis);
53int vmsvga3dPowerOn(PVGASTATE pThis);
54int vmsvga3dLoadExec(PVGASTATE pThis, PSSMHANDLE pSSM, uint32_t uVersion, uint32_t uPass);
55int vmsvga3dSaveExec(PVGASTATE pThis, PSSMHANDLE pSSM);
56int vmsvga3dTerminate(PVGASTATE pThis);
57int vmsvga3dReset(PVGASTATE pThis);
58int vmsvga3dQueryCaps(PVGASTATE pThis, uint32_t idx3dCaps, uint32_t *pu32Val);
59
60int vmsvga3dSurfaceDefine(PVGASTATE pThis, uint32_t sid, uint32_t surfaceFlags, SVGA3dSurfaceFormat format, SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES], uint32_t multisampleCount, SVGA3dTextureFilter autogenFilter, uint32_t cMipLevels, SVGA3dSize *pMipLevelSize);
61int vmsvga3dSurfaceDestroy(PVGASTATE pThis, uint32_t sid);
62int vmsvga3dSurfaceCopy(PVGASTATE pThis, SVGA3dSurfaceImageId dest, SVGA3dSurfaceImageId src, uint32_t cCopyBoxes, SVGA3dCopyBox *pBox);
63int vmsvga3dSurfaceStretchBlt(PVGASTATE pThis, SVGA3dSurfaceImageId const *pDstSfcImg, SVGA3dBox const *pDstBox,
64 SVGA3dSurfaceImageId const *pSrcSfcImg, SVGA3dBox const *pSrcBox, SVGA3dStretchBltMode enmMode);
65int vmsvga3dSurfaceDMA(PVGASTATE pThis, SVGA3dGuestImage guest, SVGA3dSurfaceImageId host, SVGA3dTransferType transfer, uint32_t cCopyBoxes, SVGA3dCopyBox *pBoxes);
66int vmsvga3dSurfaceBlitToScreen(PVGASTATE pThis, uint32_t dest, SVGASignedRect destRect, SVGA3dSurfaceImageId src, SVGASignedRect srcRect, uint32_t cRects, SVGASignedRect *pRect);
67
68int vmsvga3dContextDefine(PVGASTATE pThis, uint32_t cid);
69int vmsvga3dContextDestroy(PVGASTATE pThis, uint32_t cid);
70
71int vmsvga3dChangeMode(PVGASTATE pThis);
72
73int vmsvga3dSetTransform(PVGASTATE pThis, uint32_t cid, SVGA3dTransformType type, float matrix[16]);
74int vmsvga3dSetZRange(PVGASTATE pThis, uint32_t cid, SVGA3dZRange zRange);
75int vmsvga3dSetRenderState(PVGASTATE pThis, uint32_t cid, uint32_t cRenderStates, SVGA3dRenderState *pRenderState);
76int vmsvga3dSetRenderTarget(PVGASTATE pThis, uint32_t cid, SVGA3dRenderTargetType type, SVGA3dSurfaceImageId target);
77int vmsvga3dSetTextureState(PVGASTATE pThis, uint32_t cid, uint32_t cTextureStates, SVGA3dTextureState *pTextureState);
78int vmsvga3dSetMaterial(PVGASTATE pThis, uint32_t cid, SVGA3dFace face, SVGA3dMaterial *pMaterial);
79int vmsvga3dSetLightData(PVGASTATE pThis, uint32_t cid, uint32_t index, SVGA3dLightData *pData);
80int vmsvga3dSetLightEnabled(PVGASTATE pThis, uint32_t cid, uint32_t index, uint32_t enabled);
81int vmsvga3dSetViewPort(PVGASTATE pThis, uint32_t cid, SVGA3dRect *pRect);
82int vmsvga3dSetClipPlane(PVGASTATE pThis, uint32_t cid, uint32_t index, float plane[4]);
83int vmsvga3dCommandClear(PVGASTATE pThis, uint32_t cid, SVGA3dClearFlag clearFlag, uint32_t color, float depth, uint32_t stencil, uint32_t cRects, SVGA3dRect *pRect);
84int vmsvga3dCommandPresent(PVGASTATE pThis, uint32_t sid, uint32_t cRects, SVGA3dCopyRect *pRect);
85int vmsvga3dDrawPrimitives(PVGASTATE pThis, uint32_t cid, uint32_t numVertexDecls, SVGA3dVertexDecl *pVertexDecl, uint32_t numRanges, SVGA3dPrimitiveRange *pNumRange, uint32_t cVertexDivisor, SVGA3dVertexDivisor *pVertexDivisor);
86int vmsvga3dSetScissorRect(PVGASTATE pThis, uint32_t cid, SVGA3dRect *pRect);
87int vmsvga3dGenerateMipmaps(PVGASTATE pThis, uint32_t sid, SVGA3dTextureFilter filter);
88
89int vmsvga3dShaderDefine(PVGASTATE pThis, uint32_t cid, uint32_t shid, SVGA3dShaderType type, uint32_t cbData, uint32_t *pShaderData);
90int vmsvga3dShaderDestroy(PVGASTATE pThis, uint32_t cid, uint32_t shid, SVGA3dShaderType type);
91int vmsvga3dShaderSet(PVGASTATE pThis, struct VMSVGA3DCONTEXT *pContext, uint32_t cid, SVGA3dShaderType type, uint32_t shid);
92int vmsvga3dShaderSetConst(PVGASTATE pThis, uint32_t cid, uint32_t reg, SVGA3dShaderType type, SVGA3dShaderConstType ctype, uint32_t cRegisters, uint32_t *pValues);
93
94int vmsvga3dQueryBegin(PVGASTATE pThis, uint32_t cid, SVGA3dQueryType type);
95int vmsvga3dQueryEnd(PVGASTATE pThis, uint32_t cid, SVGA3dQueryType type, SVGAGuestPtr guestResult);
96int vmsvga3dQueryWait(PVGASTATE pThis, uint32_t cid, SVGA3dQueryType type, SVGAGuestPtr guestResult);
97
98/* DevVGA-SVGA3d-shared.h: */
99#if defined(RT_OS_WINDOWS) && defined(IN_RING3)
100# include <Windows.h>
101
102# define WM_VMSVGA3D_WAKEUP (WM_APP+1)
103# define WM_VMSVGA3D_CREATEWINDOW (WM_APP+2)
104# define WM_VMSVGA3D_DESTROYWINDOW (WM_APP+3)
105# define WM_VMSVGA3D_RESIZEWINDOW (WM_APP+4)
106# define WM_VMSVGA3D_EXIT (WM_APP+5)
107
108DECLCALLBACK(int) vmsvga3dWindowThread(RTTHREAD ThreadSelf, void *pvUser);
109int vmsvga3dSendThreadMessage(RTTHREAD pWindowThread, RTSEMEVENT WndRequestSem, UINT msg, WPARAM wParam, LPARAM lParam);
110
111#endif
112
113void vmsvga3dUpdateHeapBuffersForSurfaces(PVGASTATE pThis, uint32_t sid);
114void vmsvga3dInfoContextWorker(PVGASTATE pThis, PCDBGFINFOHLP pHlp, uint32_t cid, bool fVerbose);
115void vmsvga3dInfoSurfaceWorker(PVGASTATE pThis, PCDBGFINFOHLP pHlp, uint32_t sid, bool fVerbose, uint32_t cxAscii, bool fInvY);
116
117
118/* DevVGA-SVGA3d-shared.cpp: */
119
120/**
121 * Structure for use with vmsvga3dInfoU32Flags.
122 */
123typedef struct VMSVGAINFOFLAGS32
124{
125 /** The flags. */
126 uint32_t fFlags;
127 /** The corresponding mnemonic. */
128 const char *pszJohnny;
129} VMSVGAINFOFLAGS32;
130/** Pointer to a read-only flag translation entry. */
131typedef VMSVGAINFOFLAGS32 const *PCVMSVGAINFOFLAGS32;
132void vmsvga3dInfoU32Flags(PCDBGFINFOHLP pHlp, uint32_t fFlags, const char *pszPrefix, PCVMSVGAINFOFLAGS32 paFlags, uint32_t cFlags);
133
134/**
135 * Structure for use with vmsvgaFormatEnumValueEx and vmsvgaFormatEnumValue.
136 */
137typedef struct VMSVGAINFOENUM
138{
139 /** The enum value. */
140 int32_t iValue;
141 /** The corresponding value name. */
142 const char *pszName;
143} VMSVGAINFOENUM;
144/** Pointer to a read-only enum value translation entry. */
145typedef VMSVGAINFOENUM const *PCVMSVGAINFOENUM;
146/**
147 * Structure for use with vmsvgaFormatEnumValueEx and vmsvgaFormatEnumValue.
148 */
149typedef struct VMSVGAINFOENUMMAP
150{
151 /** Pointer to the value mapping array. */
152 PCVMSVGAINFOENUM paValues;
153 /** The number of value mappings. */
154 size_t cValues;
155 /** The prefix. */
156 const char *pszPrefix;
157#ifdef RT_STRICT
158 /** Indicates whether we've checked that it's sorted or not. */
159 bool *pfAsserted;
160#endif
161} VMSVGAINFOENUMMAP;
162typedef VMSVGAINFOENUMMAP const *PCVMSVGAINFOENUMMAP;
163/** @def VMSVGAINFOENUMMAP_MAKE
164 * Macro for defining a VMSVGAINFOENUMMAP, silently dealing with pfAsserted.
165 *
166 * @param a_Scope The scope. RT_NOTHING or static.
167 * @param a_VarName The variable name for this map.
168 * @param a_aValues The variable name of the value mapping array.
169 * @param a_pszPrefix The value name prefix.
170 */
171#ifdef VBOX_STRICT
172# define VMSVGAINFOENUMMAP_MAKE(a_Scope, a_VarName, a_aValues, a_pszPrefix) \
173 static bool RT_CONCAT(a_VarName,_AssertedSorted) = false; \
174 a_Scope VMSVGAINFOENUMMAP const a_VarName = { \
175 a_aValues, RT_ELEMENTS(a_aValues), a_pszPrefix, &RT_CONCAT(a_VarName,_AssertedSorted) \
176 }
177#else
178# define VMSVGAINFOENUMMAP_MAKE(a_Scope, a_VarName, a_aValues, a_pszPrefix) \
179 a_Scope VMSVGAINFOENUMMAP const a_VarName = { a_aValues, RT_ELEMENTS(a_aValues), a_pszPrefix }
180#endif
181extern VMSVGAINFOENUMMAP const g_SVGA3dSurfaceFormat2String;
182const char *vmsvgaLookupEnum(int32_t iValue, PCVMSVGAINFOENUMMAP pEnumMap);
183char *vmsvgaFormatEnumValueEx(char *pszBuffer, size_t cbBuffer, const char *pszName, int32_t iValue,
184 bool fPrefix, PCVMSVGAINFOENUMMAP pEnumMap);
185char *vmsvgaFormatEnumValue(char *pszBuffer, size_t cbBuffer, const char *pszName, uint32_t uValue,
186 const char *pszPrefix, const char * const *papszValues, size_t cValues);
187
188/**
189 * ASCII "art" scanline printer callback.
190 *
191 * @param pszLine The line to output.
192 * @param pvUser The user argument.
193 */
194typedef DECLCALLBACK(void) FMVMSVGAASCIIPRINTLN(const char *pszLine, void *pvUser);
195/** Pointer to an ASCII "art" print line callback. */
196typedef FMVMSVGAASCIIPRINTLN *PFMVMSVGAASCIIPRINTLN;
197void vmsvga3dAsciiPrint(PFMVMSVGAASCIIPRINTLN pfnPrintLine, void *pvUser, void const *pvImage, size_t cbImage,
198 uint32_t cx, uint32_t cy, uint32_t cbScanline, SVGA3dSurfaceFormat enmFormat, bool fInvY,
199 uint32_t cchMaxX, uint32_t cchMaxY);
200DECLCALLBACK(void) vmsvga3dAsciiPrintlnInfo(const char *pszLine, void *pvUser);
201DECLCALLBACK(void) vmsvga3dAsciiPrintlnLog(const char *pszLine, void *pvUser);
202
203char *vmsvga3dFormatRenderState(char *pszBuffer, size_t cbBuffer, SVGA3dRenderState const *pRenderState);
204char *vmsvga3dFormatTextureState(char *pszBuffer, size_t cbBuffer, SVGA3dTextureState const *pTextureState);
205void vmsvga3dInfoHostWindow(PCDBGFINFOHLP pHlp, uint64_t idHostWindow);
206
207uint32_t vmsvga3dSurfaceFormatSize(SVGA3dSurfaceFormat format);
208
209#ifdef LOG_ENABLED
210const char *vmsvga3dGetCapString(uint32_t idxCap);
211const char *vmsvga3dGet3dFormatString(uint32_t format);
212const char *vmsvga3dGetRenderStateName(uint32_t state);
213const char *vmsvga3dTextureStateToString(SVGA3dTextureStateName textureState);
214const char *vmsvgaTransformToString(SVGA3dTransformType type);
215const char *vmsvgaDeclUsage2String(SVGA3dDeclUsage usage);
216const char *vmsvgaDeclType2String(SVGA3dDeclType type);
217const char *vmsvgaDeclMethod2String(SVGA3dDeclMethod method);
218const char *vmsvgaSurfaceType2String(SVGA3dSurfaceFormat format);
219const char *vmsvga3dPrimitiveType2String(SVGA3dPrimitiveType PrimitiveType);
220#endif
221
222#endif /* !___DEVVMWARE3D_H___ */
223
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