930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync/** @file
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync * DevVMWare - VMWare SVGA device - 3D part.
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync */
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync/*
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync * Copyright (C) 2013-2015 Oracle Corporation
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync *
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync * available from http://www.virtualbox.org. This file is free software;
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync * you can redistribute it and/or modify it under the terms of the GNU
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync * General Public License (GPL) as published by the Free Software
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync */
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync#ifndef ___DEVVMWARE3D_H___
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync#define ___DEVVMWARE3D_H___
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#include "vmsvga/svga_reg.h"
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#include "vmsvga/svga3d_reg.h"
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#include "vmsvga/svga_escape.h"
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#include "vmsvga/svga_overlay.h"
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#if defined(RT_OS_WINDOWS) && defined(IN_RING3)
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync# include <Windows.h>
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync# define WM_VMSVGA3D_WAKEUP (WM_APP+1)
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync# define WM_VMSVGA3D_CREATEWINDOW (WM_APP+2)
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync# define WM_VMSVGA3D_DESTROYWINDOW (WM_APP+3)
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync# define WM_VMSVGA3D_RESIZEWINDOW (WM_APP+4)
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync# define WM_VMSVGA3D_EXIT (WM_APP+5)
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncDECLCALLBACK(int) vmsvga3dWindowThread(RTTHREAD ThreadSelf, void *pvUser);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSendThreadMessage(RTTHREAD pWindowThread, RTSEMEVENT WndRequestSem, UINT msg, WPARAM wParam, LPARAM lParam);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#endif
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync/** Arbitrary limit */
e87c9f91d6faa28a6fdc129ec7c52e4a18b49975vboxsync#define SVGA3D_MAX_SHADER_IDS 0x800
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync/** D3D allows up to 8 texture stages. */
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#define SVGA3D_MAX_TEXTURE_STAGE 8
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync/** Arbitrary upper limit; seen 8 so far. */
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#define SVGA3D_MAX_LIGHTS 32
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncvoid vmsvgaGMRFree(PVGASTATE pThis, uint32_t idGMR);
c049162517778158b3507c0389358a7342622b99vboxsyncint vmsvgaGMRTransfer(PVGASTATE pThis, const SVGA3dTransferType enmTransferType, uint8_t *pDest, int32_t cbDestPitch,
c049162517778158b3507c0389358a7342622b99vboxsync SVGAGuestPtr src, uint32_t offSrc, int32_t cbSrcPitch, uint32_t cbWidth, uint32_t cHeight);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dInit(PVGASTATE pThis);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dPowerOn(PVGASTATE pThis);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dLoadExec(PVGASTATE pThis, PSSMHANDLE pSSM, uint32_t uVersion, uint32_t uPass);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSaveExec(PVGASTATE pThis, PSSMHANDLE pSSM);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dTerminate(PVGASTATE pThis);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dReset(PVGASTATE pThis);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dQueryCaps(PVGASTATE pThis, uint32_t idx3dCaps, uint32_t *pu32Val);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint 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);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSurfaceDestroy(PVGASTATE pThis, uint32_t sid);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSurfaceCopy(PVGASTATE pThis, SVGA3dSurfaceImageId dest, SVGA3dSurfaceImageId src, uint32_t cCopyBoxes, SVGA3dCopyBox *pBox);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSurfaceStretchBlt(PVGASTATE pThis, SVGA3dSurfaceImageId dest, SVGA3dBox destBox, SVGA3dSurfaceImageId src, SVGA3dBox srcBox, SVGA3dStretchBltMode mode);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSurfaceDMA(PVGASTATE pThis, SVGA3dGuestImage guest, SVGA3dSurfaceImageId host, SVGA3dTransferType transfer, uint32_t cCopyBoxes, SVGA3dCopyBox *pBoxes);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSurfaceBlitToScreen(PVGASTATE pThis, uint32_t dest, SVGASignedRect destRect, SVGA3dSurfaceImageId src, SVGASignedRect srcRect, uint32_t cRects, SVGASignedRect *pRect);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
d7dbbf62e47482dad97a2d17ae567e879b5d57b6vboxsyncint vmsvga3dContextDefine(PVGASTATE pThis, uint32_t cid);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dContextDestroy(PVGASTATE pThis, uint32_t cid);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dChangeMode(PVGASTATE pThis);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetTransform(PVGASTATE pThis, uint32_t cid, SVGA3dTransformType type, float matrix[16]);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetZRange(PVGASTATE pThis, uint32_t cid, SVGA3dZRange zRange);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetRenderState(PVGASTATE pThis, uint32_t cid, uint32_t cRenderStates, SVGA3dRenderState *pRenderState);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetRenderTarget(PVGASTATE pThis, uint32_t cid, SVGA3dRenderTargetType type, SVGA3dSurfaceImageId target);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetTextureState(PVGASTATE pThis, uint32_t cid, uint32_t cTextureStates, SVGA3dTextureState *pTextureState);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetMaterial(PVGASTATE pThis, uint32_t cid, SVGA3dFace face, SVGA3dMaterial *pMaterial);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetLightData(PVGASTATE pThis, uint32_t cid, uint32_t index, SVGA3dLightData *pData);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetLightEnabled(PVGASTATE pThis, uint32_t cid, uint32_t index, uint32_t enabled);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetViewPort(PVGASTATE pThis, uint32_t cid, SVGA3dRect *pRect);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetClipPlane(PVGASTATE pThis, uint32_t cid, uint32_t index, float plane[4]);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dCommandClear(PVGASTATE pThis, uint32_t cid, SVGA3dClearFlag clearFlag, uint32_t color, float depth, uint32_t stencil, uint32_t cRects, SVGA3dRect *pRect);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dCommandPresent(PVGASTATE pThis, uint32_t sid, uint32_t cRects, SVGA3dCopyRect *pRect);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dDrawPrimitives(PVGASTATE pThis, uint32_t cid, uint32_t numVertexDecls, SVGA3dVertexDecl *pVertexDecl, uint32_t numRanges, SVGA3dPrimitiveRange *pNumRange, uint32_t cVertexDivisor, SVGA3dVertexDivisor *pVertexDivisor);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dSetScissorRect(PVGASTATE pThis, uint32_t cid, SVGA3dRect *pRect);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dGenerateMipmaps(PVGASTATE pThis, uint32_t sid, SVGA3dTextureFilter filter);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dShaderDefine(PVGASTATE pThis, uint32_t cid, uint32_t shid, SVGA3dShaderType type, uint32_t cbData, uint32_t *pShaderData);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dShaderDestroy(PVGASTATE pThis, uint32_t cid, uint32_t shid, SVGA3dShaderType type);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dShaderSet(PVGASTATE pThis, uint32_t cid, SVGA3dShaderType type, uint32_t shid);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dShaderSetConst(PVGASTATE pThis, uint32_t cid, uint32_t reg, SVGA3dShaderType type, SVGA3dShaderConstType ctype, uint32_t cRegisters, uint32_t *pValues);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dQueryBegin(PVGASTATE pThis, uint32_t cid, SVGA3dQueryType type);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dQueryEnd(PVGASTATE pThis, uint32_t cid, SVGA3dQueryType type, SVGAGuestPtr guestResult);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncint vmsvga3dQueryWait(PVGASTATE pThis, uint32_t cid, SVGA3dQueryType type, SVGAGuestPtr guestResult);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncuint32_t vmsvga3dSurfaceFormatSize(SVGA3dSurfaceFormat format);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#ifdef LOG_ENABLED
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvga3dGetCapString(uint32_t idxCap);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvga3dGet3dFormatString(uint32_t format);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvga3dGetRenderStateName(uint32_t state);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvga3dTextureStateToString(SVGA3dTextureStateName textureState);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvgaTransformToString(SVGA3dTransformType type);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvgaDeclUsage2String(SVGA3dDeclUsage usage);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvgaDeclType2String(SVGA3dDeclType type);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvgaDeclMethod2String(SVGA3dDeclMethod method);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvgaSurfaceType2String(SVGA3dSurfaceFormat format);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsyncconst char *vmsvga3dPrimitiveType2String(SVGA3dPrimitiveType PrimitiveType);
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync#endif
930b5f872e89407f445d4000d4e4aaecaa6a0998vboxsync
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync#endif /* !___DEVVMWARE3D_H___ */
ad3fbb4984b64893329d7d2694fde329da2cad0fvboxsync