forked from Minki/linux
b861686b18
This introduces a header update and support for multisample surfaces. Signed-off-by: Dave Airlie <airlied@redhat.com> Link: https://patchwork.freedesktop.org/patch/msgid/d020efb8-776d-5e8f-9d9f-122591e074d6@vmware.com
2185 lines
63 KiB
C
2185 lines
63 KiB
C
/* SPDX-License-Identifier: GPL-2.0 OR MIT */
|
|
/**********************************************************
|
|
* Copyright 1998-2015 VMware, Inc.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person
|
|
* obtaining a copy of this software and associated documentation
|
|
* files (the "Software"), to deal in the Software without
|
|
* restriction, including without limitation the rights to use, copy,
|
|
* modify, merge, publish, distribute, sublicense, and/or sell copies
|
|
* of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be
|
|
* included in all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
|
|
* BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
|
|
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
|
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
* SOFTWARE.
|
|
*
|
|
**********************************************************/
|
|
|
|
/*
|
|
* svga3d_cmd.h --
|
|
*
|
|
* SVGA 3d hardware cmd definitions
|
|
*/
|
|
|
|
#ifndef _SVGA3D_CMD_H_
|
|
#define _SVGA3D_CMD_H_
|
|
|
|
#define INCLUDE_ALLOW_MODULE
|
|
#define INCLUDE_ALLOW_USERLEVEL
|
|
#define INCLUDE_ALLOW_VMCORE
|
|
|
|
#include "includeCheck.h"
|
|
#include "svga3d_types.h"
|
|
|
|
/*
|
|
* Identifiers for commands in the command FIFO.
|
|
*
|
|
* IDs between 1000 and 1039 (inclusive) were used by obsolete versions of
|
|
* the SVGA3D protocol and remain reserved; they should not be used in the
|
|
* future.
|
|
*
|
|
* IDs between 1040 and 2999 (inclusive) are available for use by the
|
|
* current SVGA3D protocol.
|
|
*
|
|
* FIFO clients other than SVGA3D should stay below 1000, or at 3000
|
|
* and up.
|
|
*/
|
|
|
|
typedef enum {
|
|
SVGA_3D_CMD_LEGACY_BASE = 1000,
|
|
SVGA_3D_CMD_BASE = 1040,
|
|
|
|
SVGA_3D_CMD_SURFACE_DEFINE = 1040,
|
|
SVGA_3D_CMD_SURFACE_DESTROY = 1041,
|
|
SVGA_3D_CMD_SURFACE_COPY = 1042,
|
|
SVGA_3D_CMD_SURFACE_STRETCHBLT = 1043,
|
|
SVGA_3D_CMD_SURFACE_DMA = 1044,
|
|
SVGA_3D_CMD_CONTEXT_DEFINE = 1045,
|
|
SVGA_3D_CMD_CONTEXT_DESTROY = 1046,
|
|
SVGA_3D_CMD_SETTRANSFORM = 1047,
|
|
SVGA_3D_CMD_SETZRANGE = 1048,
|
|
SVGA_3D_CMD_SETRENDERSTATE = 1049,
|
|
SVGA_3D_CMD_SETRENDERTARGET = 1050,
|
|
SVGA_3D_CMD_SETTEXTURESTATE = 1051,
|
|
SVGA_3D_CMD_SETMATERIAL = 1052,
|
|
SVGA_3D_CMD_SETLIGHTDATA = 1053,
|
|
SVGA_3D_CMD_SETLIGHTENABLED = 1054,
|
|
SVGA_3D_CMD_SETVIEWPORT = 1055,
|
|
SVGA_3D_CMD_SETCLIPPLANE = 1056,
|
|
SVGA_3D_CMD_CLEAR = 1057,
|
|
SVGA_3D_CMD_PRESENT = 1058,
|
|
SVGA_3D_CMD_SHADER_DEFINE = 1059,
|
|
SVGA_3D_CMD_SHADER_DESTROY = 1060,
|
|
SVGA_3D_CMD_SET_SHADER = 1061,
|
|
SVGA_3D_CMD_SET_SHADER_CONST = 1062,
|
|
SVGA_3D_CMD_DRAW_PRIMITIVES = 1063,
|
|
SVGA_3D_CMD_SETSCISSORRECT = 1064,
|
|
SVGA_3D_CMD_BEGIN_QUERY = 1065,
|
|
SVGA_3D_CMD_END_QUERY = 1066,
|
|
SVGA_3D_CMD_WAIT_FOR_QUERY = 1067,
|
|
SVGA_3D_CMD_PRESENT_READBACK = 1068,
|
|
SVGA_3D_CMD_BLIT_SURFACE_TO_SCREEN = 1069,
|
|
SVGA_3D_CMD_SURFACE_DEFINE_V2 = 1070,
|
|
SVGA_3D_CMD_GENERATE_MIPMAPS = 1071,
|
|
SVGA_3D_CMD_DEAD4 = 1072,
|
|
SVGA_3D_CMD_DEAD5 = 1073,
|
|
SVGA_3D_CMD_DEAD6 = 1074,
|
|
SVGA_3D_CMD_DEAD7 = 1075,
|
|
SVGA_3D_CMD_DEAD8 = 1076,
|
|
SVGA_3D_CMD_DEAD9 = 1077,
|
|
SVGA_3D_CMD_DEAD10 = 1078,
|
|
SVGA_3D_CMD_DEAD11 = 1079,
|
|
SVGA_3D_CMD_ACTIVATE_SURFACE = 1080,
|
|
SVGA_3D_CMD_DEACTIVATE_SURFACE = 1081,
|
|
SVGA_3D_CMD_SCREEN_DMA = 1082,
|
|
SVGA_3D_CMD_DEAD1 = 1083,
|
|
SVGA_3D_CMD_DEAD2 = 1084,
|
|
|
|
SVGA_3D_CMD_LOGICOPS_BITBLT = 1085,
|
|
SVGA_3D_CMD_LOGICOPS_TRANSBLT = 1086,
|
|
SVGA_3D_CMD_LOGICOPS_STRETCHBLT = 1087,
|
|
SVGA_3D_CMD_LOGICOPS_COLORFILL = 1088,
|
|
SVGA_3D_CMD_LOGICOPS_ALPHABLEND = 1089,
|
|
SVGA_3D_CMD_LOGICOPS_CLEARTYPEBLEND = 1090,
|
|
|
|
SVGA_3D_CMD_SET_OTABLE_BASE = 1091,
|
|
SVGA_3D_CMD_READBACK_OTABLE = 1092,
|
|
|
|
SVGA_3D_CMD_DEFINE_GB_MOB = 1093,
|
|
SVGA_3D_CMD_DESTROY_GB_MOB = 1094,
|
|
SVGA_3D_CMD_DEAD3 = 1095,
|
|
SVGA_3D_CMD_UPDATE_GB_MOB_MAPPING = 1096,
|
|
|
|
SVGA_3D_CMD_DEFINE_GB_SURFACE = 1097,
|
|
SVGA_3D_CMD_DESTROY_GB_SURFACE = 1098,
|
|
SVGA_3D_CMD_BIND_GB_SURFACE = 1099,
|
|
SVGA_3D_CMD_COND_BIND_GB_SURFACE = 1100,
|
|
SVGA_3D_CMD_UPDATE_GB_IMAGE = 1101,
|
|
SVGA_3D_CMD_UPDATE_GB_SURFACE = 1102,
|
|
SVGA_3D_CMD_READBACK_GB_IMAGE = 1103,
|
|
SVGA_3D_CMD_READBACK_GB_SURFACE = 1104,
|
|
SVGA_3D_CMD_INVALIDATE_GB_IMAGE = 1105,
|
|
SVGA_3D_CMD_INVALIDATE_GB_SURFACE = 1106,
|
|
|
|
SVGA_3D_CMD_DEFINE_GB_CONTEXT = 1107,
|
|
SVGA_3D_CMD_DESTROY_GB_CONTEXT = 1108,
|
|
SVGA_3D_CMD_BIND_GB_CONTEXT = 1109,
|
|
SVGA_3D_CMD_READBACK_GB_CONTEXT = 1110,
|
|
SVGA_3D_CMD_INVALIDATE_GB_CONTEXT = 1111,
|
|
|
|
SVGA_3D_CMD_DEFINE_GB_SHADER = 1112,
|
|
SVGA_3D_CMD_DESTROY_GB_SHADER = 1113,
|
|
SVGA_3D_CMD_BIND_GB_SHADER = 1114,
|
|
|
|
SVGA_3D_CMD_SET_OTABLE_BASE64 = 1115,
|
|
|
|
SVGA_3D_CMD_BEGIN_GB_QUERY = 1116,
|
|
SVGA_3D_CMD_END_GB_QUERY = 1117,
|
|
SVGA_3D_CMD_WAIT_FOR_GB_QUERY = 1118,
|
|
|
|
SVGA_3D_CMD_NOP = 1119,
|
|
|
|
SVGA_3D_CMD_ENABLE_GART = 1120,
|
|
SVGA_3D_CMD_DISABLE_GART = 1121,
|
|
SVGA_3D_CMD_MAP_MOB_INTO_GART = 1122,
|
|
SVGA_3D_CMD_UNMAP_GART_RANGE = 1123,
|
|
|
|
SVGA_3D_CMD_DEFINE_GB_SCREENTARGET = 1124,
|
|
SVGA_3D_CMD_DESTROY_GB_SCREENTARGET = 1125,
|
|
SVGA_3D_CMD_BIND_GB_SCREENTARGET = 1126,
|
|
SVGA_3D_CMD_UPDATE_GB_SCREENTARGET = 1127,
|
|
|
|
SVGA_3D_CMD_READBACK_GB_IMAGE_PARTIAL = 1128,
|
|
SVGA_3D_CMD_INVALIDATE_GB_IMAGE_PARTIAL = 1129,
|
|
|
|
SVGA_3D_CMD_SET_GB_SHADERCONSTS_INLINE = 1130,
|
|
|
|
SVGA_3D_CMD_GB_SCREEN_DMA = 1131,
|
|
SVGA_3D_CMD_BIND_GB_SURFACE_WITH_PITCH = 1132,
|
|
SVGA_3D_CMD_GB_MOB_FENCE = 1133,
|
|
SVGA_3D_CMD_DEFINE_GB_SURFACE_V2 = 1134,
|
|
SVGA_3D_CMD_DEFINE_GB_MOB64 = 1135,
|
|
SVGA_3D_CMD_REDEFINE_GB_MOB64 = 1136,
|
|
SVGA_3D_CMD_NOP_ERROR = 1137,
|
|
|
|
SVGA_3D_CMD_SET_VERTEX_STREAMS = 1138,
|
|
SVGA_3D_CMD_SET_VERTEX_DECLS = 1139,
|
|
SVGA_3D_CMD_SET_VERTEX_DIVISORS = 1140,
|
|
SVGA_3D_CMD_DRAW = 1141,
|
|
SVGA_3D_CMD_DRAW_INDEXED = 1142,
|
|
|
|
/*
|
|
* DX10 Commands
|
|
*/
|
|
SVGA_3D_CMD_DX_MIN = 1143,
|
|
SVGA_3D_CMD_DX_DEFINE_CONTEXT = 1143,
|
|
SVGA_3D_CMD_DX_DESTROY_CONTEXT = 1144,
|
|
SVGA_3D_CMD_DX_BIND_CONTEXT = 1145,
|
|
SVGA_3D_CMD_DX_READBACK_CONTEXT = 1146,
|
|
SVGA_3D_CMD_DX_INVALIDATE_CONTEXT = 1147,
|
|
SVGA_3D_CMD_DX_SET_SINGLE_CONSTANT_BUFFER = 1148,
|
|
SVGA_3D_CMD_DX_SET_SHADER_RESOURCES = 1149,
|
|
SVGA_3D_CMD_DX_SET_SHADER = 1150,
|
|
SVGA_3D_CMD_DX_SET_SAMPLERS = 1151,
|
|
SVGA_3D_CMD_DX_DRAW = 1152,
|
|
SVGA_3D_CMD_DX_DRAW_INDEXED = 1153,
|
|
SVGA_3D_CMD_DX_DRAW_INSTANCED = 1154,
|
|
SVGA_3D_CMD_DX_DRAW_INDEXED_INSTANCED = 1155,
|
|
SVGA_3D_CMD_DX_DRAW_AUTO = 1156,
|
|
SVGA_3D_CMD_DX_SET_INPUT_LAYOUT = 1157,
|
|
SVGA_3D_CMD_DX_SET_VERTEX_BUFFERS = 1158,
|
|
SVGA_3D_CMD_DX_SET_INDEX_BUFFER = 1159,
|
|
SVGA_3D_CMD_DX_SET_TOPOLOGY = 1160,
|
|
SVGA_3D_CMD_DX_SET_RENDERTARGETS = 1161,
|
|
SVGA_3D_CMD_DX_SET_BLEND_STATE = 1162,
|
|
SVGA_3D_CMD_DX_SET_DEPTHSTENCIL_STATE = 1163,
|
|
SVGA_3D_CMD_DX_SET_RASTERIZER_STATE = 1164,
|
|
SVGA_3D_CMD_DX_DEFINE_QUERY = 1165,
|
|
SVGA_3D_CMD_DX_DESTROY_QUERY = 1166,
|
|
SVGA_3D_CMD_DX_BIND_QUERY = 1167,
|
|
SVGA_3D_CMD_DX_SET_QUERY_OFFSET = 1168,
|
|
SVGA_3D_CMD_DX_BEGIN_QUERY = 1169,
|
|
SVGA_3D_CMD_DX_END_QUERY = 1170,
|
|
SVGA_3D_CMD_DX_READBACK_QUERY = 1171,
|
|
SVGA_3D_CMD_DX_SET_PREDICATION = 1172,
|
|
SVGA_3D_CMD_DX_SET_SOTARGETS = 1173,
|
|
SVGA_3D_CMD_DX_SET_VIEWPORTS = 1174,
|
|
SVGA_3D_CMD_DX_SET_SCISSORRECTS = 1175,
|
|
SVGA_3D_CMD_DX_CLEAR_RENDERTARGET_VIEW = 1176,
|
|
SVGA_3D_CMD_DX_CLEAR_DEPTHSTENCIL_VIEW = 1177,
|
|
SVGA_3D_CMD_DX_PRED_COPY_REGION = 1178,
|
|
SVGA_3D_CMD_DX_PRED_COPY = 1179,
|
|
SVGA_3D_CMD_DX_PRESENTBLT = 1180,
|
|
SVGA_3D_CMD_DX_GENMIPS = 1181,
|
|
SVGA_3D_CMD_DX_UPDATE_SUBRESOURCE = 1182,
|
|
SVGA_3D_CMD_DX_READBACK_SUBRESOURCE = 1183,
|
|
SVGA_3D_CMD_DX_INVALIDATE_SUBRESOURCE = 1184,
|
|
SVGA_3D_CMD_DX_DEFINE_SHADERRESOURCE_VIEW = 1185,
|
|
SVGA_3D_CMD_DX_DESTROY_SHADERRESOURCE_VIEW = 1186,
|
|
SVGA_3D_CMD_DX_DEFINE_RENDERTARGET_VIEW = 1187,
|
|
SVGA_3D_CMD_DX_DESTROY_RENDERTARGET_VIEW = 1188,
|
|
SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_VIEW = 1189,
|
|
SVGA_3D_CMD_DX_DESTROY_DEPTHSTENCIL_VIEW = 1190,
|
|
SVGA_3D_CMD_DX_DEFINE_ELEMENTLAYOUT = 1191,
|
|
SVGA_3D_CMD_DX_DESTROY_ELEMENTLAYOUT = 1192,
|
|
SVGA_3D_CMD_DX_DEFINE_BLEND_STATE = 1193,
|
|
SVGA_3D_CMD_DX_DESTROY_BLEND_STATE = 1194,
|
|
SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_STATE = 1195,
|
|
SVGA_3D_CMD_DX_DESTROY_DEPTHSTENCIL_STATE = 1196,
|
|
SVGA_3D_CMD_DX_DEFINE_RASTERIZER_STATE = 1197,
|
|
SVGA_3D_CMD_DX_DESTROY_RASTERIZER_STATE = 1198,
|
|
SVGA_3D_CMD_DX_DEFINE_SAMPLER_STATE = 1199,
|
|
SVGA_3D_CMD_DX_DESTROY_SAMPLER_STATE = 1200,
|
|
SVGA_3D_CMD_DX_DEFINE_SHADER = 1201,
|
|
SVGA_3D_CMD_DX_DESTROY_SHADER = 1202,
|
|
SVGA_3D_CMD_DX_BIND_SHADER = 1203,
|
|
SVGA_3D_CMD_DX_DEFINE_STREAMOUTPUT = 1204,
|
|
SVGA_3D_CMD_DX_DESTROY_STREAMOUTPUT = 1205,
|
|
SVGA_3D_CMD_DX_SET_STREAMOUTPUT = 1206,
|
|
SVGA_3D_CMD_DX_SET_COTABLE = 1207,
|
|
SVGA_3D_CMD_DX_READBACK_COTABLE = 1208,
|
|
SVGA_3D_CMD_DX_BUFFER_COPY = 1209,
|
|
SVGA_3D_CMD_DX_TRANSFER_FROM_BUFFER = 1210,
|
|
SVGA_3D_CMD_DX_SURFACE_COPY_AND_READBACK = 1211,
|
|
SVGA_3D_CMD_DX_MOVE_QUERY = 1212,
|
|
SVGA_3D_CMD_DX_BIND_ALL_QUERY = 1213,
|
|
SVGA_3D_CMD_DX_READBACK_ALL_QUERY = 1214,
|
|
SVGA_3D_CMD_DX_PRED_TRANSFER_FROM_BUFFER = 1215,
|
|
SVGA_3D_CMD_DX_MOB_FENCE_64 = 1216,
|
|
SVGA_3D_CMD_DX_BIND_ALL_SHADER = 1217,
|
|
SVGA_3D_CMD_DX_HINT = 1218,
|
|
SVGA_3D_CMD_DX_BUFFER_UPDATE = 1219,
|
|
SVGA_3D_CMD_DX_SET_VS_CONSTANT_BUFFER_OFFSET = 1220,
|
|
SVGA_3D_CMD_DX_SET_PS_CONSTANT_BUFFER_OFFSET = 1221,
|
|
SVGA_3D_CMD_DX_SET_GS_CONSTANT_BUFFER_OFFSET = 1222,
|
|
|
|
/*
|
|
* Reserve some IDs to be used for the SM5 shader types.
|
|
*/
|
|
SVGA_3D_CMD_DX_RESERVED1 = 1223,
|
|
SVGA_3D_CMD_DX_RESERVED2 = 1224,
|
|
SVGA_3D_CMD_DX_RESERVED3 = 1225,
|
|
|
|
SVGA_3D_CMD_DX_COND_BIND_ALL_SHADER = 1226,
|
|
SVGA_3D_CMD_DX_MAX = 1227,
|
|
|
|
SVGA_3D_CMD_SCREEN_COPY = 1227,
|
|
|
|
/*
|
|
* Reserve some IDs to be used for video.
|
|
*/
|
|
SVGA_3D_CMD_VIDEO_RESERVED1 = 1228,
|
|
SVGA_3D_CMD_VIDEO_RESERVED2 = 1229,
|
|
SVGA_3D_CMD_VIDEO_RESERVED3 = 1230,
|
|
SVGA_3D_CMD_VIDEO_RESERVED4 = 1231,
|
|
SVGA_3D_CMD_VIDEO_RESERVED5 = 1232,
|
|
SVGA_3D_CMD_VIDEO_RESERVED6 = 1233,
|
|
SVGA_3D_CMD_VIDEO_RESERVED7 = 1234,
|
|
SVGA_3D_CMD_VIDEO_RESERVED8 = 1235,
|
|
|
|
SVGA_3D_CMD_GROW_OTABLE = 1236,
|
|
SVGA_3D_CMD_DX_GROW_COTABLE = 1237,
|
|
SVGA_3D_CMD_INTRA_SURFACE_COPY = 1238,
|
|
|
|
SVGA_3D_CMD_DEFINE_GB_SURFACE_V3 = 1239,
|
|
|
|
SVGA_3D_CMD_DX_RESOLVE_COPY = 1240,
|
|
SVGA_3D_CMD_DX_PRED_RESOLVE_COPY = 1241,
|
|
SVGA_3D_CMD_DX_PRED_CONVERT_REGION = 1242,
|
|
SVGA_3D_CMD_DX_PRED_CONVERT = 1243,
|
|
SVGA_3D_CMD_WHOLE_SURFACE_COPY = 1244,
|
|
|
|
SVGA_3D_CMD_MAX = 1245,
|
|
SVGA_3D_CMD_FUTURE_MAX = 3000
|
|
} SVGAFifo3dCmdId;
|
|
|
|
#define SVGA_NUM_3D_CMD (SVGA_3D_CMD_MAX - SVGA_3D_CMD_BASE)
|
|
|
|
/*
|
|
* FIFO command format definitions:
|
|
*/
|
|
|
|
/*
|
|
* The data size header following cmdNum for every 3d command
|
|
*/
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 id;
|
|
uint32 size;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdHeader;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 numMipLevels;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dSurfaceFace;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
SVGA3dSurface1Flags surfaceFlags;
|
|
SVGA3dSurfaceFormat format;
|
|
/*
|
|
* If surfaceFlags has SVGA3D_SURFACE_CUBEMAP bit set, all SVGA3dSurfaceFace
|
|
* structures must have the same value of numMipLevels field.
|
|
* Otherwise, all but the first SVGA3dSurfaceFace structures must have the
|
|
* numMipLevels set to 0.
|
|
*/
|
|
SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES];
|
|
/*
|
|
* Followed by an SVGA3dSize structure for each mip level in each face.
|
|
*
|
|
* A note on surface sizes: Sizes are always specified in pixels,
|
|
* even if the true surface size is not a multiple of the minimum
|
|
* block size of the surface's format. For example, a 3x3x1 DXT1
|
|
* compressed texture would actually be stored as a 4x4x1 image in
|
|
* memory.
|
|
*/
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineSurface; /* SVGA_3D_CMD_SURFACE_DEFINE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
SVGA3dSurface1Flags surfaceFlags;
|
|
SVGA3dSurfaceFormat format;
|
|
/*
|
|
* If surfaceFlags has SVGA3D_SURFACE_CUBEMAP bit set, all SVGA3dSurfaceFace
|
|
* structures must have the same value of numMipLevels field.
|
|
* Otherwise, all but the first SVGA3dSurfaceFace structures must have the
|
|
* numMipLevels set to 0.
|
|
*/
|
|
SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES];
|
|
uint32 multisampleCount;
|
|
SVGA3dTextureFilter autogenFilter;
|
|
/*
|
|
* Followed by an SVGA3dSize structure for each mip level in each face.
|
|
*
|
|
* A note on surface sizes: Sizes are always specified in pixels,
|
|
* even if the true surface size is not a multiple of the minimum
|
|
* block size of the surface's format. For example, a 3x3x1 DXT1
|
|
* compressed texture would actually be stored as a 4x4x1 image in
|
|
* memory.
|
|
*/
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineSurface_v2; /* SVGA_3D_CMD_SURFACE_DEFINE_V2 */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDestroySurface; /* SVGA_3D_CMD_SURFACE_DESTROY */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineContext; /* SVGA_3D_CMD_CONTEXT_DEFINE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDestroyContext; /* SVGA_3D_CMD_CONTEXT_DESTROY */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dClearFlag clearFlag;
|
|
uint32 color;
|
|
float depth;
|
|
uint32 stencil;
|
|
/* Followed by variable number of SVGA3dRect structures */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdClear; /* SVGA_3D_CMD_CLEAR */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dLightType type;
|
|
SVGA3dBool inWorldSpace;
|
|
float diffuse[4];
|
|
float specular[4];
|
|
float ambient[4];
|
|
float position[4];
|
|
float direction[4];
|
|
float range;
|
|
float falloff;
|
|
float attenuation0;
|
|
float attenuation1;
|
|
float attenuation2;
|
|
float theta;
|
|
float phi;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dLightData;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
/* Followed by variable number of SVGA3dCopyRect structures */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdPresent; /* SVGA_3D_CMD_PRESENT */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dRenderStateName state;
|
|
union {
|
|
uint32 uintValue;
|
|
float floatValue;
|
|
};
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dRenderState;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
/* Followed by variable number of SVGA3dRenderState structures */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetRenderState; /* SVGA_3D_CMD_SETRENDERSTATE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dRenderTargetType type;
|
|
SVGA3dSurfaceImageId target;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetRenderTarget; /* SVGA_3D_CMD_SETRENDERTARGET */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dSurfaceImageId src;
|
|
SVGA3dSurfaceImageId dest;
|
|
/* Followed by variable number of SVGA3dCopyBox structures */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSurfaceCopy; /* SVGA_3D_CMD_SURFACE_COPY */
|
|
|
|
/*
|
|
* Perform a surface copy within the same image.
|
|
* The src/dest boxes are allowed to overlap.
|
|
*/
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dSurfaceImageId surface;
|
|
SVGA3dCopyBox box;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdIntraSurfaceCopy; /* SVGA_3D_CMD_INTRA_SURFACE_COPY */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 srcSid;
|
|
uint32 destSid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdWholeSurfaceCopy; /* SVGA_3D_CMD_WHOLE_SURFACE_COPY */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dSurfaceImageId src;
|
|
SVGA3dSurfaceImageId dest;
|
|
SVGA3dBox boxSrc;
|
|
SVGA3dBox boxDest;
|
|
SVGA3dStretchBltMode mode;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSurfaceStretchBlt; /* SVGA_3D_CMD_SURFACE_STRETCHBLT */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
/*
|
|
* If the discard flag is present in a surface DMA operation, the host may
|
|
* discard the contents of the current mipmap level and face of the target
|
|
* surface before applying the surface DMA contents.
|
|
*/
|
|
uint32 discard : 1;
|
|
|
|
/*
|
|
* If the unsynchronized flag is present, the host may perform this upload
|
|
* without syncing to pending reads on this surface.
|
|
*/
|
|
uint32 unsynchronized : 1;
|
|
|
|
/*
|
|
* Guests *MUST* set the reserved bits to 0 before submitting the command
|
|
* suffix as future flags may occupy these bits.
|
|
*/
|
|
uint32 reserved : 30;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dSurfaceDMAFlags;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGAGuestImage guest;
|
|
SVGA3dSurfaceImageId host;
|
|
SVGA3dTransferType transfer;
|
|
/*
|
|
* Followed by variable number of SVGA3dCopyBox structures. For consistency
|
|
* in all clipping logic and coordinate translation, we define the
|
|
* "source" in each copyBox as the guest image and the
|
|
* "destination" as the host image, regardless of transfer
|
|
* direction.
|
|
*
|
|
* For efficiency, the SVGA3D device is free to copy more data than
|
|
* specified. For example, it may round copy boxes outwards such
|
|
* that they lie on particular alignment boundaries.
|
|
*/
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSurfaceDMA; /* SVGA_3D_CMD_SURFACE_DMA */
|
|
|
|
/*
|
|
* SVGA3dCmdSurfaceDMASuffix --
|
|
*
|
|
* This is a command suffix that will appear after a SurfaceDMA command in
|
|
* the FIFO. It contains some extra information that hosts may use to
|
|
* optimize performance or protect the guest. This suffix exists to preserve
|
|
* backwards compatibility while also allowing for new functionality to be
|
|
* implemented.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 suffixSize;
|
|
|
|
/*
|
|
* The maximum offset is used to determine the maximum offset from the
|
|
* guestPtr base address that will be accessed or written to during this
|
|
* surfaceDMA. If the suffix is supported, the host will respect this
|
|
* boundary while performing surface DMAs.
|
|
*
|
|
* Defaults to MAX_UINT32
|
|
*/
|
|
uint32 maximumOffset;
|
|
|
|
/*
|
|
* A set of flags that describes optimizations that the host may perform
|
|
* while performing this surface DMA operation. The guest should never rely
|
|
* on behaviour that is different when these flags are set for correctness.
|
|
*
|
|
* Defaults to 0
|
|
*/
|
|
SVGA3dSurfaceDMAFlags flags;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSurfaceDMASuffix;
|
|
|
|
/*
|
|
* SVGA_3D_CMD_DRAW_PRIMITIVES --
|
|
*
|
|
* This command is the SVGA3D device's generic drawing entry point.
|
|
* It can draw multiple ranges of primitives, optionally using an
|
|
* index buffer, using an arbitrary collection of vertex buffers.
|
|
*
|
|
* Each SVGA3dVertexDecl defines a distinct vertex array to bind
|
|
* during this draw call. The declarations specify which surface
|
|
* the vertex data lives in, what that vertex data is used for,
|
|
* and how to interpret it.
|
|
*
|
|
* Each SVGA3dPrimitiveRange defines a collection of primitives
|
|
* to render using the same vertex arrays. An index buffer is
|
|
* optional.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
/*
|
|
* A range hint is an optional specification for the range of indices
|
|
* in an SVGA3dArray that will be used. If 'last' is zero, it is assumed
|
|
* that the entire array will be used.
|
|
*
|
|
* These are only hints. The SVGA3D device may use them for
|
|
* performance optimization if possible, but it's also allowed to
|
|
* ignore these values.
|
|
*/
|
|
uint32 first;
|
|
uint32 last;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dArrayRangeHint;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
/*
|
|
* Define the origin and shape of a vertex or index array. Both
|
|
* 'offset' and 'stride' are in bytes. The provided surface will be
|
|
* reinterpreted as a flat array of bytes in the same format used
|
|
* by surface DMA operations. To avoid unnecessary conversions, the
|
|
* surface should be created with the SVGA3D_BUFFER format.
|
|
*
|
|
* Index 0 in the array starts 'offset' bytes into the surface.
|
|
* Index 1 begins at byte 'offset + stride', etc. Array indices may
|
|
* not be negative.
|
|
*/
|
|
uint32 surfaceId;
|
|
uint32 offset;
|
|
uint32 stride;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dArray;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
/*
|
|
* Describe a vertex array's data type, and define how it is to be
|
|
* used by the fixed function pipeline or the vertex shader. It
|
|
* isn't useful to have two VertexDecls with the same
|
|
* VertexArrayIdentity in one draw call.
|
|
*/
|
|
SVGA3dDeclType type;
|
|
SVGA3dDeclMethod method;
|
|
SVGA3dDeclUsage usage;
|
|
uint32 usageIndex;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dVertexArrayIdentity;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dVertexDecl {
|
|
SVGA3dVertexArrayIdentity identity;
|
|
SVGA3dArray array;
|
|
SVGA3dArrayRangeHint rangeHint;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dVertexDecl;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dPrimitiveRange {
|
|
/*
|
|
* Define a group of primitives to render, from sequential indices.
|
|
*
|
|
* The value of 'primitiveType' and 'primitiveCount' imply the
|
|
* total number of vertices that will be rendered.
|
|
*/
|
|
SVGA3dPrimitiveType primType;
|
|
uint32 primitiveCount;
|
|
|
|
/*
|
|
* Optional index buffer. If indexArray.surfaceId is
|
|
* SVGA3D_INVALID_ID, we render without an index buffer. Rendering
|
|
* without an index buffer is identical to rendering with an index
|
|
* buffer containing the sequence [0, 1, 2, 3, ...].
|
|
*
|
|
* If an index buffer is in use, indexWidth specifies the width in
|
|
* bytes of each index value. It must be less than or equal to
|
|
* indexArray.stride.
|
|
*
|
|
* (Currently, the SVGA3D device requires index buffers to be tightly
|
|
* packed. In other words, indexWidth == indexArray.stride)
|
|
*/
|
|
SVGA3dArray indexArray;
|
|
uint32 indexWidth;
|
|
|
|
/*
|
|
* Optional index bias. This number is added to all indices from
|
|
* indexArray before they are used as vertex array indices. This
|
|
* can be used in multiple ways:
|
|
*
|
|
* - When not using an indexArray, this bias can be used to
|
|
* specify where in the vertex arrays to begin rendering.
|
|
*
|
|
* - A positive number here is equivalent to increasing the
|
|
* offset in each vertex array.
|
|
*
|
|
* - A negative number can be used to render using a small
|
|
* vertex array and an index buffer that contains large
|
|
* values. This may be used by some applications that
|
|
* crop a vertex buffer without modifying their index
|
|
* buffer.
|
|
*
|
|
* Note that rendering with a negative bias value may be slower and
|
|
* use more memory than rendering with a positive or zero bias.
|
|
*/
|
|
int32 indexBias;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dPrimitiveRange;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 numVertexDecls;
|
|
uint32 numRanges;
|
|
|
|
/*
|
|
* There are two variable size arrays after the
|
|
* SVGA3dCmdDrawPrimitives structure. In order,
|
|
* they are:
|
|
*
|
|
* 1. SVGA3dVertexDecl, quantity 'numVertexDecls', but no more than
|
|
* SVGA3D_MAX_VERTEX_ARRAYS;
|
|
* 2. SVGA3dPrimitiveRange, quantity 'numRanges', but no more than
|
|
* SVGA3D_MAX_DRAW_PRIMITIVE_RANGES;
|
|
* 3. Optionally, SVGA3dVertexDivisor, quantity 'numVertexDecls' (contains
|
|
* the frequency divisor for the corresponding vertex decl).
|
|
*/
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDrawPrimitives; /* SVGA_3D_CMD_DRAWPRIMITIVES */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
|
|
uint32 primitiveCount; /* How many primitives to render */
|
|
uint32 startVertexLocation; /* Which vertex do we start rendering at. */
|
|
|
|
uint8 primitiveType; /* SVGA3dPrimitiveType */
|
|
uint8 padding[3];
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDraw;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
|
|
uint8 primitiveType; /* SVGA3dPrimitiveType */
|
|
|
|
uint32 indexBufferSid; /* Valid index buffer sid. */
|
|
uint32 indexBufferOffset; /* Byte offset into the vertex buffer, almost */
|
|
/* always 0 for DX9 guests, non-zero for OpenGL */
|
|
/* guests. We can't represent non-multiple of */
|
|
/* stride offsets in D3D9Renderer... */
|
|
uint8 indexBufferStride; /* Allowable values = 1, 2, or 4 */
|
|
|
|
int32 baseVertexLocation; /* Bias applied to the index when selecting a */
|
|
/* vertex from the streams, may be negative */
|
|
|
|
uint32 primitiveCount; /* How many primitives to render */
|
|
uint32 pad0;
|
|
uint16 pad1;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDrawIndexed;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
/*
|
|
* Describe a vertex array's data type, and define how it is to be
|
|
* used by the fixed function pipeline or the vertex shader. It
|
|
* isn't useful to have two VertexDecls with the same
|
|
* VertexArrayIdentity in one draw call.
|
|
*/
|
|
uint16 streamOffset;
|
|
uint8 stream;
|
|
uint8 type; /* SVGA3dDeclType */
|
|
uint8 method; /* SVGA3dDeclMethod */
|
|
uint8 usage; /* SVGA3dDeclUsage */
|
|
uint8 usageIndex;
|
|
uint8 padding;
|
|
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dVertexElement;
|
|
|
|
/*
|
|
* Should the vertex element respect the stream value? The high bit of the
|
|
* stream should be set to indicate that the stream should be respected. If
|
|
* the high bit is not set, the stream will be ignored and replaced by the index
|
|
* of the position of the currently considered vertex element.
|
|
*
|
|
* All guests should set this bit and correctly specify the stream going
|
|
* forward.
|
|
*/
|
|
#define SVGA3D_VERTEX_ELEMENT_RESPECT_STREAM (1 << 7)
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
|
|
uint32 numElements;
|
|
|
|
/*
|
|
* Followed by numElements SVGA3dVertexElement structures.
|
|
*
|
|
* If numElements < SVGA3D_MAX_VERTEX_ARRAYS, the remaining elements
|
|
* are cleared and will not be used by following draws.
|
|
*/
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetVertexDecls;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
uint32 stride;
|
|
uint32 offset;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dVertexStream;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
|
|
uint32 numStreams;
|
|
/*
|
|
* Followed by numStream SVGA3dVertexStream structures.
|
|
*
|
|
* If numStreams < SVGA3D_MAX_VERTEX_ARRAYS, the remaining streams
|
|
* are cleared and will not be used by following draws.
|
|
*/
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetVertexStreams;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 numDivisors;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetVertexDivisors;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 stage;
|
|
SVGA3dTextureStateName name;
|
|
union {
|
|
uint32 value;
|
|
float floatValue;
|
|
};
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dTextureState;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
/* Followed by variable number of SVGA3dTextureState structures */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetTextureState; /* SVGA_3D_CMD_SETTEXTURESTATE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dTransformType type;
|
|
float matrix[16];
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetTransform; /* SVGA_3D_CMD_SETTRANSFORM */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
float min;
|
|
float max;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dZRange;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dZRange zRange;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetZRange; /* SVGA_3D_CMD_SETZRANGE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
float diffuse[4];
|
|
float ambient[4];
|
|
float specular[4];
|
|
float emissive[4];
|
|
float shininess;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dMaterial;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dFace face;
|
|
SVGA3dMaterial material;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetMaterial; /* SVGA_3D_CMD_SETMATERIAL */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 index;
|
|
SVGA3dLightData data;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetLightData; /* SVGA_3D_CMD_SETLIGHTDATA */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 index;
|
|
uint32 enabled;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetLightEnabled; /* SVGA_3D_CMD_SETLIGHTENABLED */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dRect rect;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetViewport; /* SVGA_3D_CMD_SETVIEWPORT */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dRect rect;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetScissorRect; /* SVGA_3D_CMD_SETSCISSORRECT */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 index;
|
|
float plane[4];
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetClipPlane; /* SVGA_3D_CMD_SETCLIPPLANE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 shid;
|
|
SVGA3dShaderType type;
|
|
/* Followed by variable number of DWORDs for shader bycode */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineShader; /* SVGA_3D_CMD_SHADER_DEFINE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 shid;
|
|
SVGA3dShaderType type;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDestroyShader; /* SVGA_3D_CMD_SHADER_DESTROY */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 reg; /* register number */
|
|
SVGA3dShaderType type;
|
|
SVGA3dShaderConstType ctype;
|
|
uint32 values[4];
|
|
|
|
/*
|
|
* Followed by a variable number of additional values.
|
|
*/
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetShaderConst; /* SVGA_3D_CMD_SET_SHADER_CONST */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dShaderType type;
|
|
uint32 shid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetShader; /* SVGA_3D_CMD_SET_SHADER */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dQueryType type;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdBeginQuery; /* SVGA_3D_CMD_BEGIN_QUERY */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dQueryType type;
|
|
SVGAGuestPtr guestResult; /* Points to an SVGA3dQueryResult structure */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdEndQuery; /* SVGA_3D_CMD_END_QUERY */
|
|
|
|
|
|
/*
|
|
* SVGA3D_CMD_WAIT_FOR_QUERY --
|
|
*
|
|
* Will read the SVGA3dQueryResult structure pointed to by guestResult,
|
|
* and if the state member is set to anything else than
|
|
* SVGA3D_QUERYSTATE_PENDING, this command will always be a no-op.
|
|
*
|
|
* Otherwise, in addition to the query explicitly waited for,
|
|
* All queries with the same type and issued with the same cid, for which
|
|
* an SVGA_3D_CMD_END_QUERY command has previously been sent, will
|
|
* be finished after execution of this command.
|
|
*
|
|
* A query will be identified by the gmrId and offset of the guestResult
|
|
* member. If the device can't find an SVGA_3D_CMD_END_QUERY that has
|
|
* been sent previously with an indentical gmrId and offset, it will
|
|
* effectively end all queries with an identical type issued with the
|
|
* same cid, and the SVGA3dQueryResult structure pointed to by
|
|
* guestResult will not be written to. This property can be used to
|
|
* implement a query barrier for a given cid and query type.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid; /* Same parameters passed to END_QUERY */
|
|
SVGA3dQueryType type;
|
|
SVGAGuestPtr guestResult;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdWaitForQuery; /* SVGA_3D_CMD_WAIT_FOR_QUERY */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 totalSize; /* Set by guest before query is ended. */
|
|
SVGA3dQueryState state; /* Set by host or guest. See SVGA3dQueryState. */
|
|
union { /* Set by host on exit from PENDING state */
|
|
uint32 result32;
|
|
uint32 queryCookie; /* May be used to identify which QueryGetData this
|
|
result corresponds to. */
|
|
};
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dQueryResult;
|
|
|
|
|
|
/*
|
|
* SVGA_3D_CMD_BLIT_SURFACE_TO_SCREEN --
|
|
*
|
|
* This is a blit from an SVGA3D surface to a Screen Object.
|
|
* This blit must be directed at a specific screen.
|
|
*
|
|
* The blit copies from a rectangular region of an SVGA3D surface
|
|
* image to a rectangular region of a screen.
|
|
*
|
|
* This command takes an optional variable-length list of clipping
|
|
* rectangles after the body of the command. If no rectangles are
|
|
* specified, there is no clipping region. The entire destRect is
|
|
* drawn to. If one or more rectangles are included, they describe
|
|
* a clipping region. The clip rectangle coordinates are measured
|
|
* relative to the top-left corner of destRect.
|
|
*
|
|
* The srcImage must be from mip=0 face=0.
|
|
*
|
|
* This supports scaling if the src and dest are of different sizes.
|
|
*
|
|
* Availability:
|
|
* SVGA_FIFO_CAP_SCREEN_OBJECT
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dSurfaceImageId srcImage;
|
|
SVGASignedRect srcRect;
|
|
uint32 destScreenId; /* Screen Object ID */
|
|
SVGASignedRect destRect;
|
|
/* Clipping: zero or more SVGASignedRects follow */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdBlitSurfaceToScreen; /* SVGA_3D_CMD_BLIT_SURFACE_TO_SCREEN */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
SVGA3dTextureFilter filter;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdGenerateMipmaps; /* SVGA_3D_CMD_GENERATE_MIPMAPS */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdActivateSurface; /* SVGA_3D_CMD_ACTIVATE_SURFACE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDeactivateSurface; /* SVGA_3D_CMD_DEACTIVATE_SURFACE */
|
|
|
|
/*
|
|
* Screen DMA command
|
|
*
|
|
* Available with SVGA_FIFO_CAP_SCREEN_OBJECT_2. The SVGA_CAP_3D device
|
|
* cap bit is not required.
|
|
*
|
|
* - refBuffer and destBuffer are 32bit BGRX; refBuffer and destBuffer could
|
|
* be different, but it is required that guest makes sure refBuffer has
|
|
* exactly the same contents that were written to when last time screen DMA
|
|
* command is received by host.
|
|
*
|
|
* - changemap is generated by lib/blit, and it has the changes from last
|
|
* received screen DMA or more.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdScreenDMA {
|
|
uint32 screenId;
|
|
SVGAGuestImage refBuffer;
|
|
SVGAGuestImage destBuffer;
|
|
SVGAGuestImage changeMap;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdScreenDMA; /* SVGA_3D_CMD_SCREEN_DMA */
|
|
|
|
/*
|
|
* Logic ops
|
|
*/
|
|
|
|
#define SVGA3D_LOTRANSBLT_HONORALPHA (0x01)
|
|
#define SVGA3D_LOSTRETCHBLT_MIRRORX (0x01)
|
|
#define SVGA3D_LOSTRETCHBLT_MIRRORY (0x02)
|
|
#define SVGA3D_LOALPHABLEND_SRCHASALPHA (0x01)
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdLogicOpsBitBlt {
|
|
/*
|
|
* All LogicOps surfaces are one-level
|
|
* surfaces so mipmap & face should always
|
|
* be zero.
|
|
*/
|
|
SVGA3dSurfaceImageId src;
|
|
SVGA3dSurfaceImageId dst;
|
|
SVGA3dLogicOp logicOp;
|
|
/* Followed by variable number of SVGA3dCopyBox structures */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdLogicOpsBitBlt; /* SVGA_3D_CMD_LOGICOPS_BITBLT */
|
|
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdLogicOpsTransBlt {
|
|
/*
|
|
* All LogicOps surfaces are one-level
|
|
* surfaces so mipmap & face should always
|
|
* be zero.
|
|
*/
|
|
SVGA3dSurfaceImageId src;
|
|
SVGA3dSurfaceImageId dst;
|
|
uint32 color;
|
|
uint32 flags;
|
|
SVGA3dBox srcBox;
|
|
SVGA3dBox dstBox;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdLogicOpsTransBlt; /* SVGA_3D_CMD_LOGICOPS_TRANSBLT */
|
|
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdLogicOpsStretchBlt {
|
|
/*
|
|
* All LogicOps surfaces are one-level
|
|
* surfaces so mipmap & face should always
|
|
* be zero.
|
|
*/
|
|
SVGA3dSurfaceImageId src;
|
|
SVGA3dSurfaceImageId dst;
|
|
uint16 mode;
|
|
uint16 flags;
|
|
SVGA3dBox srcBox;
|
|
SVGA3dBox dstBox;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdLogicOpsStretchBlt; /* SVGA_3D_CMD_LOGICOPS_STRETCHBLT */
|
|
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdLogicOpsColorFill {
|
|
/*
|
|
* All LogicOps surfaces are one-level
|
|
* surfaces so mipmap & face should always
|
|
* be zero.
|
|
*/
|
|
SVGA3dSurfaceImageId dst;
|
|
uint32 color;
|
|
SVGA3dLogicOp logicOp;
|
|
/* Followed by variable number of SVGA3dRect structures. */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdLogicOpsColorFill; /* SVGA_3D_CMD_LOGICOPS_COLORFILL */
|
|
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdLogicOpsAlphaBlend {
|
|
/*
|
|
* All LogicOps surfaces are one-level
|
|
* surfaces so mipmap & face should always
|
|
* be zero.
|
|
*/
|
|
SVGA3dSurfaceImageId src;
|
|
SVGA3dSurfaceImageId dst;
|
|
uint32 alphaVal;
|
|
uint32 flags;
|
|
SVGA3dBox srcBox;
|
|
SVGA3dBox dstBox;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdLogicOpsAlphaBlend; /* SVGA_3D_CMD_LOGICOPS_ALPHABLEND */
|
|
|
|
#define SVGA3D_CLEARTYPE_INVALID_GAMMA_INDEX 0xFFFFFFFF
|
|
|
|
#define SVGA3D_CLEARTYPE_GAMMA_WIDTH 512
|
|
#define SVGA3D_CLEARTYPE_GAMMA_HEIGHT 16
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdLogicOpsClearTypeBlend {
|
|
/*
|
|
* All LogicOps surfaces are one-level
|
|
* surfaces so mipmap & face should always
|
|
* be zero.
|
|
*/
|
|
SVGA3dSurfaceImageId tmp;
|
|
SVGA3dSurfaceImageId dst;
|
|
SVGA3dSurfaceImageId gammaSurf;
|
|
SVGA3dSurfaceImageId alphaSurf;
|
|
uint32 gamma;
|
|
uint32 color;
|
|
uint32 color2;
|
|
int32 alphaOffsetX;
|
|
int32 alphaOffsetY;
|
|
/* Followed by variable number of SVGA3dBox structures */
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdLogicOpsClearTypeBlend; /* SVGA_3D_CMD_LOGICOPS_CLEARTYPEBLEND */
|
|
|
|
|
|
/*
|
|
* Guest-backed objects definitions.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGAMobFormat ptDepth;
|
|
uint32 sizeInBytes;
|
|
PPN64 base;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGAOTableMobEntry;
|
|
#define SVGA3D_OTABLE_MOB_ENTRY_SIZE (sizeof(SVGAOTableMobEntry))
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dSurfaceFormat format;
|
|
SVGA3dSurface1Flags surface1Flags;
|
|
uint32 numMipLevels;
|
|
uint32 multisampleCount;
|
|
SVGA3dTextureFilter autogenFilter;
|
|
SVGA3dSize size;
|
|
SVGAMobId mobid;
|
|
uint32 arraySize;
|
|
uint32 mobPitch;
|
|
SVGA3dSurface2Flags surface2Flags;
|
|
uint8 multisamplePattern;
|
|
uint8 qualityLevel;
|
|
uint8 pad0[2];
|
|
uint32 pad1[3];
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGAOTableSurfaceEntry;
|
|
#define SVGA3D_OTABLE_SURFACE_ENTRY_SIZE (sizeof(SVGAOTableSurfaceEntry))
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGAMobId mobid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGAOTableContextEntry;
|
|
#define SVGA3D_OTABLE_CONTEXT_ENTRY_SIZE (sizeof(SVGAOTableContextEntry))
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dShaderType type;
|
|
uint32 sizeInBytes;
|
|
uint32 offsetInBytes;
|
|
SVGAMobId mobid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGAOTableShaderEntry;
|
|
#define SVGA3D_OTABLE_SHADER_ENTRY_SIZE (sizeof(SVGAOTableShaderEntry))
|
|
|
|
#define SVGA_STFLAG_PRIMARY (1 << 0)
|
|
#define SVGA_STFLAG_RESERVED (1 << 1) /* Added with cap SVGA_CAP_HP_CMD_QUEUE */
|
|
typedef uint32 SVGAScreenTargetFlags;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dSurfaceImageId image;
|
|
uint32 width;
|
|
uint32 height;
|
|
int32 xRoot;
|
|
int32 yRoot;
|
|
SVGAScreenTargetFlags flags;
|
|
uint32 dpi;
|
|
uint32 pad[7];
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGAOTableScreenTargetEntry;
|
|
#define SVGA3D_OTABLE_SCREEN_TARGET_ENTRY_SIZE \
|
|
(sizeof(SVGAOTableScreenTargetEntry))
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
float value[4];
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dShaderConstFloat;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
int32 value[4];
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dShaderConstInt;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 value;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dShaderConstBool;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint16 streamOffset;
|
|
uint8 stream;
|
|
uint8 type;
|
|
uint8 methodUsage;
|
|
uint8 usageIndex;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGAGBVertexElement;
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 sid;
|
|
uint16 stride;
|
|
uint32 offset;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGAGBVertexStream;
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGA3dRect viewport;
|
|
SVGA3dRect scissorRect;
|
|
SVGA3dZRange zRange;
|
|
|
|
SVGA3dSurfaceImageId renderTargets[SVGA3D_RT_MAX];
|
|
SVGAGBVertexElement decl1[4];
|
|
|
|
uint32 renderStates[SVGA3D_RS_MAX];
|
|
SVGAGBVertexElement decl2[18];
|
|
uint32 pad0[2];
|
|
|
|
struct {
|
|
SVGA3dFace face;
|
|
SVGA3dMaterial material;
|
|
} material;
|
|
|
|
float clipPlanes[SVGA3D_NUM_CLIPPLANES][4];
|
|
float matrices[SVGA3D_TRANSFORM_MAX][16];
|
|
|
|
SVGA3dBool lightEnabled[SVGA3D_NUM_LIGHTS];
|
|
SVGA3dLightData lightData[SVGA3D_NUM_LIGHTS];
|
|
|
|
/*
|
|
* Shaders currently bound
|
|
*/
|
|
uint32 shaders[SVGA3D_NUM_SHADERTYPE_PREDX];
|
|
SVGAGBVertexElement decl3[10];
|
|
uint32 pad1[3];
|
|
|
|
uint32 occQueryActive;
|
|
uint32 occQueryValue;
|
|
|
|
/*
|
|
* Int/Bool Shader constants
|
|
*/
|
|
SVGA3dShaderConstInt pShaderIValues[SVGA3D_CONSTINTREG_MAX];
|
|
SVGA3dShaderConstInt vShaderIValues[SVGA3D_CONSTINTREG_MAX];
|
|
uint16 pShaderBValues;
|
|
uint16 vShaderBValues;
|
|
|
|
|
|
SVGAGBVertexStream streams[SVGA3D_MAX_VERTEX_ARRAYS];
|
|
SVGA3dVertexDivisor divisors[SVGA3D_MAX_VERTEX_ARRAYS];
|
|
uint32 numVertexDecls;
|
|
uint32 numVertexStreams;
|
|
uint32 numVertexDivisors;
|
|
uint32 pad2[30];
|
|
|
|
/*
|
|
* Texture Stages
|
|
*
|
|
* SVGA3D_TS_INVALID through SVGA3D_TS_CONSTANT are in the
|
|
* textureStages array.
|
|
* SVGA3D_TS_COLOR_KEY is in tsColorKey.
|
|
*/
|
|
uint32 tsColorKey[SVGA3D_NUM_TEXTURE_UNITS];
|
|
uint32 textureStages[SVGA3D_NUM_TEXTURE_UNITS][SVGA3D_TS_CONSTANT + 1];
|
|
uint32 tsColorKeyEnable[SVGA3D_NUM_TEXTURE_UNITS];
|
|
|
|
/*
|
|
* Float Shader constants.
|
|
*/
|
|
SVGA3dShaderConstFloat pShaderFValues[SVGA3D_CONSTREG_MAX];
|
|
SVGA3dShaderConstFloat vShaderFValues[SVGA3D_CONSTREG_MAX];
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGAGBContextData;
|
|
#define SVGA3D_CONTEXT_DATA_SIZE (sizeof(SVGAGBContextData))
|
|
|
|
/*
|
|
* SVGA3dCmdSetOTableBase --
|
|
*
|
|
* This command allows the guest to specify the base PPN of the
|
|
* specified object table.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGAOTableType type;
|
|
PPN baseAddress;
|
|
uint32 sizeInBytes;
|
|
uint32 validSizeInBytes;
|
|
SVGAMobFormat ptDepth;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetOTableBase; /* SVGA_3D_CMD_SET_OTABLE_BASE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGAOTableType type;
|
|
PPN64 baseAddress;
|
|
uint32 sizeInBytes;
|
|
uint32 validSizeInBytes;
|
|
SVGAMobFormat ptDepth;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetOTableBase64; /* SVGA_3D_CMD_SET_OTABLE_BASE64 */
|
|
|
|
/*
|
|
* Guests using SVGA_3D_CMD_GROW_OTABLE are promising that
|
|
* the new OTable contains the same contents as the old one, except possibly
|
|
* for some new invalid entries at the end.
|
|
*
|
|
* (Otherwise, guests should use one of the SetOTableBase commands.)
|
|
*/
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGAOTableType type;
|
|
PPN64 baseAddress;
|
|
uint32 sizeInBytes;
|
|
uint32 validSizeInBytes;
|
|
SVGAMobFormat ptDepth;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdGrowOTable; /* SVGA_3D_CMD_GROW_OTABLE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGAOTableType type;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdReadbackOTable; /* SVGA_3D_CMD_READBACK_OTABLE */
|
|
|
|
/*
|
|
* Define a memory object (Mob) in the OTable.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDefineGBMob {
|
|
SVGAMobId mobid;
|
|
SVGAMobFormat ptDepth;
|
|
PPN base;
|
|
uint32 sizeInBytes;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineGBMob; /* SVGA_3D_CMD_DEFINE_GB_MOB */
|
|
|
|
|
|
/*
|
|
* Destroys an object in the OTable.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDestroyGBMob {
|
|
SVGAMobId mobid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDestroyGBMob; /* SVGA_3D_CMD_DESTROY_GB_MOB */
|
|
|
|
|
|
/*
|
|
* Define a memory object (Mob) in the OTable with a PPN64 base.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDefineGBMob64 {
|
|
SVGAMobId mobid;
|
|
SVGAMobFormat ptDepth;
|
|
PPN64 base;
|
|
uint32 sizeInBytes;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineGBMob64; /* SVGA_3D_CMD_DEFINE_GB_MOB64 */
|
|
|
|
/*
|
|
* Redefine an object in the OTable with PPN64 base.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdRedefineGBMob64 {
|
|
SVGAMobId mobid;
|
|
SVGAMobFormat ptDepth;
|
|
PPN64 base;
|
|
uint32 sizeInBytes;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdRedefineGBMob64; /* SVGA_3D_CMD_REDEFINE_GB_MOB64 */
|
|
|
|
/*
|
|
* Notification that the page tables have been modified.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdUpdateGBMobMapping {
|
|
SVGAMobId mobid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdUpdateGBMobMapping; /* SVGA_3D_CMD_UPDATE_GB_MOB_MAPPING */
|
|
|
|
/*
|
|
* Define a guest-backed surface.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDefineGBSurface {
|
|
uint32 sid;
|
|
SVGA3dSurface1Flags surfaceFlags;
|
|
SVGA3dSurfaceFormat format;
|
|
uint32 numMipLevels;
|
|
uint32 multisampleCount;
|
|
SVGA3dTextureFilter autogenFilter;
|
|
SVGA3dSize size;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineGBSurface; /* SVGA_3D_CMD_DEFINE_GB_SURFACE */
|
|
|
|
/*
|
|
* Defines a guest-backed surface, adding the arraySize field.
|
|
*/
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDefineGBSurface_v2 {
|
|
uint32 sid;
|
|
SVGA3dSurface1Flags surfaceFlags;
|
|
SVGA3dSurfaceFormat format;
|
|
uint32 numMipLevels;
|
|
uint32 multisampleCount;
|
|
SVGA3dTextureFilter autogenFilter;
|
|
SVGA3dSize size;
|
|
uint32 arraySize;
|
|
uint32 pad;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineGBSurface_v2; /* SVGA_3D_CMD_DEFINE_GB_SURFACE_V2 */
|
|
|
|
/*
|
|
* Defines a guest-backed surface, adding the larger flags.
|
|
*/
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDefineGBSurface_v3 {
|
|
uint32 sid;
|
|
SVGA3dSurfaceAllFlags surfaceFlags;
|
|
SVGA3dSurfaceFormat format;
|
|
uint32 numMipLevels;
|
|
uint32 multisampleCount;
|
|
SVGA3dMSPattern multisamplePattern;
|
|
SVGA3dMSQualityLevel qualityLevel;
|
|
SVGA3dTextureFilter autogenFilter;
|
|
SVGA3dSize size;
|
|
uint32 arraySize;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineGBSurface_v3; /* SVGA_3D_CMD_DEFINE_GB_SURFACE_V3 */
|
|
|
|
/*
|
|
* Destroy a guest-backed surface.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDestroyGBSurface {
|
|
uint32 sid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDestroyGBSurface; /* SVGA_3D_CMD_DESTROY_GB_SURFACE */
|
|
|
|
/*
|
|
* Bind a guest-backed surface to a mob.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdBindGBSurface {
|
|
uint32 sid;
|
|
SVGAMobId mobid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdBindGBSurface; /* SVGA_3D_CMD_BIND_GB_SURFACE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdBindGBSurfaceWithPitch {
|
|
uint32 sid;
|
|
SVGAMobId mobid;
|
|
uint32 baseLevelPitch;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdBindGBSurfaceWithPitch; /* SVGA_3D_CMD_BIND_GB_SURFACE_WITH_PITCH */
|
|
|
|
/*
|
|
* Conditionally bind a mob to a guest-backed surface if testMobid
|
|
* matches the currently bound mob. Optionally issue a
|
|
* readback/update on the surface while it is still bound to the old
|
|
* mobid if the mobid is changed by this command.
|
|
*/
|
|
|
|
#define SVGA3D_COND_BIND_GB_SURFACE_FLAG_READBACK (1 << 0)
|
|
#define SVGA3D_COND_BIND_GB_SURFACE_FLAG_UPDATE (1 << 1)
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdCondBindGBSurface {
|
|
uint32 sid;
|
|
SVGAMobId testMobid;
|
|
SVGAMobId mobid;
|
|
uint32 flags;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdCondBindGBSurface; /* SVGA_3D_CMD_COND_BIND_GB_SURFACE */
|
|
|
|
/*
|
|
* Update an image in a guest-backed surface.
|
|
* (Inform the device that the guest-contents have been updated.)
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdUpdateGBImage {
|
|
SVGA3dSurfaceImageId image;
|
|
SVGA3dBox box;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdUpdateGBImage; /* SVGA_3D_CMD_UPDATE_GB_IMAGE */
|
|
|
|
/*
|
|
* Update an entire guest-backed surface.
|
|
* (Inform the device that the guest-contents have been updated.)
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdUpdateGBSurface {
|
|
uint32 sid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdUpdateGBSurface; /* SVGA_3D_CMD_UPDATE_GB_SURFACE */
|
|
|
|
/*
|
|
* Readback an image in a guest-backed surface.
|
|
* (Request the device to flush the dirty contents into the guest.)
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdReadbackGBImage {
|
|
SVGA3dSurfaceImageId image;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdReadbackGBImage; /* SVGA_3D_CMD_READBACK_GB_IMAGE */
|
|
|
|
/*
|
|
* Readback an entire guest-backed surface.
|
|
* (Request the device to flush the dirty contents into the guest.)
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdReadbackGBSurface {
|
|
uint32 sid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdReadbackGBSurface; /* SVGA_3D_CMD_READBACK_GB_SURFACE */
|
|
|
|
/*
|
|
* Readback a sub rect of an image in a guest-backed surface. After
|
|
* issuing this command the driver is required to issue an update call
|
|
* of the same region before issuing any other commands that reference
|
|
* this surface or rendering is not guaranteed.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdReadbackGBImagePartial {
|
|
SVGA3dSurfaceImageId image;
|
|
SVGA3dBox box;
|
|
uint32 invertBox;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdReadbackGBImagePartial; /* SVGA_3D_CMD_READBACK_GB_IMAGE_PARTIAL */
|
|
|
|
|
|
/*
|
|
* Invalidate an image in a guest-backed surface.
|
|
* (Notify the device that the contents can be lost.)
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdInvalidateGBImage {
|
|
SVGA3dSurfaceImageId image;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdInvalidateGBImage; /* SVGA_3D_CMD_INVALIDATE_GB_IMAGE */
|
|
|
|
/*
|
|
* Invalidate an entire guest-backed surface.
|
|
* (Notify the device that the contents if all images can be lost.)
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdInvalidateGBSurface {
|
|
uint32 sid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdInvalidateGBSurface; /* SVGA_3D_CMD_INVALIDATE_GB_SURFACE */
|
|
|
|
/*
|
|
* Invalidate a sub rect of an image in a guest-backed surface. After
|
|
* issuing this command the driver is required to issue an update call
|
|
* of the same region before issuing any other commands that reference
|
|
* this surface or rendering is not guaranteed.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdInvalidateGBImagePartial {
|
|
SVGA3dSurfaceImageId image;
|
|
SVGA3dBox box;
|
|
uint32 invertBox;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdInvalidateGBImagePartial; /* SVGA_3D_CMD_INVALIDATE_GB_IMAGE_PARTIAL */
|
|
|
|
|
|
/*
|
|
* Define a guest-backed context.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDefineGBContext {
|
|
uint32 cid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineGBContext; /* SVGA_3D_CMD_DEFINE_GB_CONTEXT */
|
|
|
|
/*
|
|
* Destroy a guest-backed context.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDestroyGBContext {
|
|
uint32 cid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDestroyGBContext; /* SVGA_3D_CMD_DESTROY_GB_CONTEXT */
|
|
|
|
/*
|
|
* Bind a guest-backed context.
|
|
*
|
|
* validContents should be set to 0 for new contexts,
|
|
* and 1 if this is an old context which is getting paged
|
|
* back on to the device.
|
|
*
|
|
* For new contexts, it is recommended that the driver
|
|
* issue commands to initialize all interesting state
|
|
* prior to rendering.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdBindGBContext {
|
|
uint32 cid;
|
|
SVGAMobId mobid;
|
|
uint32 validContents;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdBindGBContext; /* SVGA_3D_CMD_BIND_GB_CONTEXT */
|
|
|
|
/*
|
|
* Readback a guest-backed context.
|
|
* (Request that the device flush the contents back into guest memory.)
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdReadbackGBContext {
|
|
uint32 cid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdReadbackGBContext; /* SVGA_3D_CMD_READBACK_GB_CONTEXT */
|
|
|
|
/*
|
|
* Invalidate a guest-backed context.
|
|
*/
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdInvalidateGBContext {
|
|
uint32 cid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdInvalidateGBContext; /* SVGA_3D_CMD_INVALIDATE_GB_CONTEXT */
|
|
|
|
/*
|
|
* Define a guest-backed shader.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDefineGBShader {
|
|
uint32 shid;
|
|
SVGA3dShaderType type;
|
|
uint32 sizeInBytes;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineGBShader; /* SVGA_3D_CMD_DEFINE_GB_SHADER */
|
|
|
|
/*
|
|
* Bind a guest-backed shader.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdBindGBShader {
|
|
uint32 shid;
|
|
SVGAMobId mobid;
|
|
uint32 offsetInBytes;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdBindGBShader; /* SVGA_3D_CMD_BIND_GB_SHADER */
|
|
|
|
/*
|
|
* Destroy a guest-backed shader.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdDestroyGBShader {
|
|
uint32 shid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDestroyGBShader; /* SVGA_3D_CMD_DESTROY_GB_SHADER */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
uint32 regStart;
|
|
SVGA3dShaderType shaderType;
|
|
SVGA3dShaderConstType constType;
|
|
|
|
/*
|
|
* Followed by a variable number of shader constants.
|
|
*
|
|
* Note that FLOAT and INT constants are 4-dwords in length, while
|
|
* BOOL constants are 1-dword in length.
|
|
*/
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdSetGBShaderConstInline; /* SVGA_3D_CMD_SET_GB_SHADERCONSTS_INLINE */
|
|
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dQueryType type;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdBeginGBQuery; /* SVGA_3D_CMD_BEGIN_GB_QUERY */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dQueryType type;
|
|
SVGAMobId mobid;
|
|
uint32 offset;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdEndGBQuery; /* SVGA_3D_CMD_END_GB_QUERY */
|
|
|
|
|
|
/*
|
|
* SVGA_3D_CMD_WAIT_FOR_GB_QUERY --
|
|
*
|
|
* The semantics of this command are identical to the
|
|
* SVGA_3D_CMD_WAIT_FOR_QUERY except that the results are written
|
|
* to a Mob instead of a GMR.
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 cid;
|
|
SVGA3dQueryType type;
|
|
SVGAMobId mobid;
|
|
uint32 offset;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdWaitForGBQuery; /* SVGA_3D_CMD_WAIT_FOR_GB_QUERY */
|
|
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGAMobId mobid;
|
|
uint32 mustBeZero;
|
|
uint32 initialized;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdEnableGart; /* SVGA_3D_CMD_ENABLE_GART */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
SVGAMobId mobid;
|
|
uint32 gartOffset;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdMapMobIntoGart; /* SVGA_3D_CMD_MAP_MOB_INTO_GART */
|
|
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 gartOffset;
|
|
uint32 numPages;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdUnmapGartRange; /* SVGA_3D_CMD_UNMAP_GART_RANGE */
|
|
|
|
|
|
/*
|
|
* Screen Targets
|
|
*/
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 stid;
|
|
uint32 width;
|
|
uint32 height;
|
|
int32 xRoot;
|
|
int32 yRoot;
|
|
SVGAScreenTargetFlags flags;
|
|
|
|
/*
|
|
* The physical DPI that the guest expects this screen displayed at.
|
|
*
|
|
* Guests which are not DPI-aware should set this to zero.
|
|
*/
|
|
uint32 dpi;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDefineGBScreenTarget; /* SVGA_3D_CMD_DEFINE_GB_SCREENTARGET */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 stid;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdDestroyGBScreenTarget; /* SVGA_3D_CMD_DESTROY_GB_SCREENTARGET */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 stid;
|
|
SVGA3dSurfaceImageId image;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdBindGBScreenTarget; /* SVGA_3D_CMD_BIND_GB_SCREENTARGET */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 stid;
|
|
SVGA3dRect rect;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdUpdateGBScreenTarget; /* SVGA_3D_CMD_UPDATE_GB_SCREENTARGET */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct SVGA3dCmdGBScreenDMA {
|
|
uint32 screenId;
|
|
uint32 dead;
|
|
SVGAMobId destMobID;
|
|
uint32 destPitch;
|
|
SVGAMobId changeMapMobID;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdGBScreenDMA; /* SVGA_3D_CMD_GB_SCREEN_DMA */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 value;
|
|
uint32 mobId;
|
|
uint32 mobOffset;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdGBMobFence; /* SVGA_3D_CMD_GB_MOB_FENCE */
|
|
|
|
typedef
|
|
#include "vmware_pack_begin.h"
|
|
struct {
|
|
uint32 stid;
|
|
SVGA3dSurfaceImageId dest;
|
|
|
|
uint32 statusMobId;
|
|
uint32 statusMobOffset;
|
|
|
|
/* Reserved fields */
|
|
uint32 mustBeInvalidId;
|
|
uint32 mustBeZero;
|
|
}
|
|
#include "vmware_pack_end.h"
|
|
SVGA3dCmdScreenCopy; /* SVGA_3D_CMD_SCREEN_COPY */
|
|
|
|
#define SVGA_SCREEN_COPY_STATUS_FAILURE 0x00
|
|
#define SVGA_SCREEN_COPY_STATUS_SUCCESS 0x01
|
|
#define SVGA_SCREEN_COPY_STATUS_INVALID 0xFFFFFFFF
|
|
|
|
#endif /* _SVGA3D_CMD_H_ */
|