/* SPDX-License-Identifier: GPL-2.0 OR MIT */
/*
* Copyright 2012-2021 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_
#include "svga3d_types.h"
#include "svga3d_limits.h"
#include "svga_reg.h"
typedef enum SVGAFifo3dCmdId {
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_DEAD12 = 1085 ,
SVGA_3D_CMD_DEAD13 = 1086 ,
SVGA_3D_CMD_DEAD14 = 1087 ,
SVGA_3D_CMD_DEAD15 = 1088 ,
SVGA_3D_CMD_DEAD16 = 1089 ,
SVGA_3D_CMD_DEAD17 = 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 ,
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 ,
SVGA_3D_CMD_DX_SET_HS_CONSTANT_BUFFER_OFFSET = 1223 ,
SVGA_3D_CMD_DX_SET_DS_CONSTANT_BUFFER_OFFSET = 1224 ,
SVGA_3D_CMD_DX_SET_CS_CONSTANT_BUFFER_OFFSET = 1225 ,
SVGA_3D_CMD_DX_COND_BIND_ALL_SHADER = 1226 ,
SVGA_3D_CMD_DX_MAX = 1227 ,
SVGA_3D_CMD_SCREEN_COPY = 1227 ,
SVGA_3D_CMD_RESERVED1 = 1228 ,
SVGA_3D_CMD_RESERVED2 = 1229 ,
SVGA_3D_CMD_RESERVED3 = 1230 ,
SVGA_3D_CMD_RESERVED4 = 1231 ,
SVGA_3D_CMD_RESERVED5 = 1232 ,
SVGA_3D_CMD_RESERVED6 = 1233 ,
SVGA_3D_CMD_RESERVED7 = 1234 ,
SVGA_3D_CMD_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_DX_DEFINE_UA_VIEW = 1245 ,
SVGA_3D_CMD_DX_DESTROY_UA_VIEW = 1246 ,
SVGA_3D_CMD_DX_CLEAR_UA_VIEW_UINT = 1247 ,
SVGA_3D_CMD_DX_CLEAR_UA_VIEW_FLOAT = 1248 ,
SVGA_3D_CMD_DX_COPY_STRUCTURE_COUNT = 1249 ,
SVGA_3D_CMD_DX_SET_UA_VIEWS = 1250 ,
SVGA_3D_CMD_DX_DRAW_INDEXED_INSTANCED_INDIRECT = 1251 ,
SVGA_3D_CMD_DX_DRAW_INSTANCED_INDIRECT = 1252 ,
SVGA_3D_CMD_DX_DISPATCH = 1253 ,
SVGA_3D_CMD_DX_DISPATCH_INDIRECT = 1254 ,
SVGA_3D_CMD_WRITE_ZERO_SURFACE = 1255 ,
SVGA_3D_CMD_UPDATE_ZERO_SURFACE = 1256 ,
SVGA_3D_CMD_DX_TRANSFER_TO_BUFFER = 1257 ,
SVGA_3D_CMD_DX_SET_STRUCTURE_COUNT = 1258 ,
SVGA_3D_CMD_LOGICOPS_BITBLT = 1259 ,
SVGA_3D_CMD_LOGICOPS_TRANSBLT = 1260 ,
SVGA_3D_CMD_LOGICOPS_STRETCHBLT = 1261 ,
SVGA_3D_CMD_LOGICOPS_COLORFILL = 1262 ,
SVGA_3D_CMD_LOGICOPS_ALPHABLEND = 1263 ,
SVGA_3D_CMD_LOGICOPS_CLEARTYPEBLEND = 1264 ,
SVGA_3D_CMD_DX_COPY_COTABLE_INTO_MOB = 1265 ,
SVGA_3D_CMD_UPDATE_GB_SCREENTARGET_V2 = 1266 ,
SVGA_3D_CMD_DEFINE_GB_SURFACE_V4 = 1267 ,
SVGA_3D_CMD_DX_SET_CS_UA_VIEWS = 1268 ,
SVGA_3D_CMD_DX_SET_MIN_LOD = 1269 ,
SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_VIEW_V2 = 1272 ,
SVGA_3D_CMD_DX_DEFINE_STREAMOUTPUT_WITH_MOB = 1273 ,
SVGA_3D_CMD_DX_SET_SHADER_IFACE = 1274 ,
SVGA_3D_CMD_DX_BIND_STREAMOUTPUT = 1275 ,
SVGA_3D_CMD_SURFACE_STRETCHBLT_NON_MS_TO_MS = 1276 ,
SVGA_3D_CMD_DX_BIND_SHADER_IFACE = 1277 ,
SVGA_3D_CMD_UPDATE_GB_SCREENTARGET_MOVE = 1278 ,
SVGA_3D_CMD_DX_PRED_STAGING_COPY = 1281 ,
SVGA_3D_CMD_DX_STAGING_COPY = 1282 ,
SVGA_3D_CMD_DX_PRED_STAGING_COPY_REGION = 1283 ,
SVGA_3D_CMD_DX_SET_VERTEX_BUFFERS_V2 = 1284 ,
SVGA_3D_CMD_DX_SET_INDEX_BUFFER_V2 = 1285 ,
SVGA_3D_CMD_DX_SET_VERTEX_BUFFERS_OFFSET_AND_SIZE = 1286 ,
SVGA_3D_CMD_DX_SET_INDEX_BUFFER_OFFSET_AND_SIZE = 1287 ,
SVGA_3D_CMD_DX_DEFINE_RASTERIZER_STATE_V2 = 1288 ,
SVGA_3D_CMD_DX_PRED_STAGING_CONVERT_REGION = 1289 ,
SVGA_3D_CMD_DX_PRED_STAGING_CONVERT = 1290 ,
SVGA_3D_CMD_DX_STAGING_BUFFER_COPY = 1291 ,
SVGA_3D_CMD_MAX = 1303 ,
SVGA_3D_CMD_FUTURE_MAX = 3000
} SVGAFifo3dCmdId;
#define SVGA_NUM_3D_CMD (SVGA_3D_CMD_MAX - SVGA_3D_CMD_BASE)
#pragma pack (push, 1 )
typedef struct {
uint32 id;
uint32 size;
} SVGA3dCmdHeader;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 numMipLevels;
} SVGA3dSurfaceFace;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
SVGA3dSurface1Flags surfaceFlags;
SVGA3dSurfaceFormat format;
SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES];
} SVGA3dCmdDefineSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
SVGA3dSurface1Flags surfaceFlags;
SVGA3dSurfaceFormat format;
SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES];
uint32 multisampleCount;
SVGA3dTextureFilter autogenFilter;
} SVGA3dCmdDefineSurface_v2;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
} SVGA3dCmdDestroySurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
} SVGA3dCmdDefineContext;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
} SVGA3dCmdDestroyContext;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dClearFlag clearFlag;
uint32 color;
float depth;
uint32 stencil;
} SVGA3dCmdClear;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef 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;
} SVGA3dLightData;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
} SVGA3dCmdPresent;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGA3dRenderStateName state;
union {
uint32 uintValue;
float floatValue;
};
} SVGA3dRenderState;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
} SVGA3dCmdSetRenderState;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dRenderTargetType type;
SVGA3dSurfaceImageId target;
} SVGA3dCmdSetRenderTarget;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGA3dSurfaceImageId src;
SVGA3dSurfaceImageId dest;
} SVGA3dCmdSurfaceCopy;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGA3dSurfaceImageId surface;
SVGA3dCopyBox box;
} SVGA3dCmdIntraSurfaceCopy;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 srcSid;
uint32 destSid;
} SVGA3dCmdWholeSurfaceCopy;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGA3dSurfaceImageId src;
SVGA3dSurfaceImageId dest;
SVGA3dBox boxSrc;
SVGA3dBox boxDest;
} SVGA3dCmdSurfaceStretchBltNonMSToMS;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGA3dSurfaceImageId src;
SVGA3dSurfaceImageId dest;
SVGA3dBox boxSrc;
SVGA3dBox boxDest;
SVGA3dStretchBltMode mode;
} SVGA3dCmdSurfaceStretchBlt;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 discard : 1 ;
uint32 unsynchronized : 1 ;
uint32 reserved : 30 ;
} SVGA3dSurfaceDMAFlags;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGAGuestImage guest;
SVGA3dSurfaceImageId host;
SVGA3dTransferType transfer;
} SVGA3dCmdSurfaceDMA;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 suffixSize;
uint32 maximumOffset;
SVGA3dSurfaceDMAFlags flags;
} SVGA3dCmdSurfaceDMASuffix;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 first;
uint32 last;
} SVGA3dArrayRangeHint;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 surfaceId;
uint32 offset;
uint32 stride;
} SVGA3dArray;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGA3dDeclType type;
SVGA3dDeclMethod method;
SVGA3dDeclUsage usage;
uint32 usageIndex;
} SVGA3dVertexArrayIdentity;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dVertexDecl {
SVGA3dVertexArrayIdentity identity;
SVGA3dArray array;
SVGA3dArrayRangeHint rangeHint;
} SVGA3dVertexDecl;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dPrimitiveRange {
SVGA3dPrimitiveType primType;
uint32 primitiveCount;
SVGA3dArray indexArray;
uint32 indexWidth;
int32 indexBias;
} SVGA3dPrimitiveRange;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 numVertexDecls;
uint32 numRanges;
} SVGA3dCmdDrawPrimitives;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 primitiveCount;
uint32 startVertexLocation;
uint8 primitiveType;
uint8 padding[3 ];
} SVGA3dCmdDraw;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint8 primitiveType;
uint32 indexBufferSid;
uint32 indexBufferOffset;
uint8 indexBufferStride;
int32 baseVertexLocation;
uint32 primitiveCount;
uint32 pad0;
uint16 pad1;
} SVGA3dCmdDrawIndexed;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint16 streamOffset;
uint8 stream;
uint8 type;
uint8 method;
uint8 usage;
uint8 usageIndex;
uint8 padding;
} SVGA3dVertexElement;
#pragma pack (pop)
#define SVGA3D_VERTEX_ELEMENT_RESPECT_STREAM (1 << 7 )
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 numElements;
} SVGA3dCmdSetVertexDecls;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
uint32 stride;
uint32 offset;
} SVGA3dVertexStream;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 numStreams;
} SVGA3dCmdSetVertexStreams;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 numDivisors;
} SVGA3dCmdSetVertexDivisors;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 stage;
SVGA3dTextureStateName name;
union {
uint32 value;
float floatValue;
};
} SVGA3dTextureState;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
} SVGA3dCmdSetTextureState;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dTransformType type;
float matrix[16 ];
} SVGA3dCmdSetTransform;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
float min;
float max;
} SVGA3dZRange;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dZRange zRange;
} SVGA3dCmdSetZRange;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
float diffuse[4 ];
float ambient[4 ];
float specular[4 ];
float emissive[4 ];
float shininess;
} SVGA3dMaterial;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dFace face;
SVGA3dMaterial material;
} SVGA3dCmdSetMaterial;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 index;
SVGA3dLightData data;
} SVGA3dCmdSetLightData;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 index;
uint32 enabled;
} SVGA3dCmdSetLightEnabled;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dRect rect;
} SVGA3dCmdSetViewport;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dRect rect;
} SVGA3dCmdSetScissorRect;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 index;
float plane[4 ];
} SVGA3dCmdSetClipPlane;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 shid;
SVGA3dShaderType type;
} SVGA3dCmdDefineShader;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 shid;
SVGA3dShaderType type;
} SVGA3dCmdDestroyShader;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 reg;
SVGA3dShaderType type;
SVGA3dShaderConstType ctype;
uint32 values[4 ];
} SVGA3dCmdSetShaderConst;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dShaderType type;
uint32 shid;
} SVGA3dCmdSetShader;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dQueryType type;
} SVGA3dCmdBeginQuery;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dQueryType type;
SVGAGuestPtr guestResult;
} SVGA3dCmdEndQuery;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dQueryType type;
SVGAGuestPtr guestResult;
} SVGA3dCmdWaitForQuery;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 totalSize;
SVGA3dQueryState state;
union {
uint32 result32;
uint32 queryCookie;
};
} SVGA3dQueryResult;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGA3dSurfaceImageId srcImage;
SVGASignedRect srcRect;
uint32 destScreenId;
SVGASignedRect destRect;
} SVGA3dCmdBlitSurfaceToScreen;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
SVGA3dTextureFilter filter;
} SVGA3dCmdGenerateMipmaps;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
} SVGA3dCmdActivateSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
} SVGA3dCmdDeactivateSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdScreenDMA {
uint32 screenId;
SVGAGuestImage refBuffer;
SVGAGuestImage destBuffer;
SVGAGuestImage changeMap;
} SVGA3dCmdScreenDMA;
#pragma pack (pop)
#define SVGA3D_LOTRANSBLT_HONORALPHA (0 x01)
#define SVGA3D_LOSTRETCHBLT_MIRRORX (0 x01)
#define SVGA3D_LOSTRETCHBLT_MIRRORY (0 x02)
#define SVGA3D_LOALPHABLEND_SRCHASALPHA (0 x01)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdLogicOpsBitBlt {
SVGA3dSurfaceImageId src;
SVGA3dSurfaceImageId dst;
SVGA3dLogicOp logicOp;
SVGA3dLogicOpRop3 logicOpRop3;
} SVGA3dCmdLogicOpsBitBlt;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdLogicOpsTransBlt {
SVGA3dSurfaceImageId src;
SVGA3dSurfaceImageId dst;
uint32 color;
uint32 flags;
SVGA3dBox srcBox;
SVGA3dSignedBox dstBox;
SVGA3dBox clipBox;
} SVGA3dCmdLogicOpsTransBlt;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdLogicOpsStretchBlt {
SVGA3dSurfaceImageId src;
SVGA3dSurfaceImageId dst;
uint16 mode;
uint16 flags;
SVGA3dBox srcBox;
SVGA3dSignedBox dstBox;
SVGA3dBox clipBox;
} SVGA3dCmdLogicOpsStretchBlt;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdLogicOpsColorFill {
SVGA3dSurfaceImageId dst;
uint32 color;
SVGA3dLogicOp logicOp;
SVGA3dLogicOpRop3 logicOpRop3;
} SVGA3dCmdLogicOpsColorFill;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdLogicOpsAlphaBlend {
SVGA3dSurfaceImageId src;
SVGA3dSurfaceImageId dst;
uint32 alphaVal;
uint32 flags;
SVGA3dBox srcBox;
SVGA3dSignedBox dstBox;
SVGA3dBox clipBox;
} SVGA3dCmdLogicOpsAlphaBlend;
#pragma pack (pop)
#define SVGA3D_CLEARTYPE_INVALID_GAMMA_INDEX 0 xFFFFFFFF
#define SVGA3D_CLEARTYPE_GAMMA_WIDTH 512
#define SVGA3D_CLEARTYPE_GAMMA_HEIGHT 16
#pragma pack (push, 1 )
typedef struct SVGA3dCmdLogicOpsClearTypeBlend {
SVGA3dSurfaceImageId tmp;
SVGA3dSurfaceImageId dst;
SVGA3dSurfaceImageId gammaSurf;
SVGA3dSurfaceImageId alphaSurf;
uint32 gamma;
uint32 color;
uint32 color2;
int32 alphaOffsetX;
int32 alphaOffsetY;
} SVGA3dCmdLogicOpsClearTypeBlend;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGAMobFormat ptDepth;
uint32 sizeInBytes;
PPN64 base;
} SVGAOTableMobEntry;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef 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;
uint16 bufferByteStride;
float minLOD;
uint32 pad0[2 ];
} SVGAOTableSurfaceEntry;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGAMobId mobid;
} SVGAOTableContextEntry;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGA3dShaderType type;
uint32 sizeInBytes;
uint32 offsetInBytes;
SVGAMobId mobid;
} SVGAOTableShaderEntry;
#pragma pack (pop)
#define SVGA_STFLAG_PRIMARY (1 << 0 )
#define SVGA_STFLAG_RESERVED (1 << 1 )
typedef uint32 SVGAScreenTargetFlags;
#pragma pack (push, 1 )
typedef struct {
SVGA3dSurfaceImageId image;
uint32 width;
uint32 height;
int32 xRoot;
int32 yRoot;
SVGAScreenTargetFlags flags;
uint32 dpi;
uint32 pad[7 ];
} SVGAOTableScreenTargetEntry;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
float value[4 ];
} SVGA3dShaderConstFloat;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
int32 value[4 ];
} SVGA3dShaderConstInt;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 value;
} SVGA3dShaderConstBool;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint16 streamOffset;
uint8 stream;
uint8 type;
uint8 methodUsage;
uint8 usageIndex;
} SVGAGBVertexElement;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
uint16 stride;
uint32 offset;
} SVGAGBVertexStream;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef 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_MAX_CLIP_PLANES][4 ];
float matrices[SVGA3D_TRANSFORM_MAX][16 ];
SVGA3dBool lightEnabled[SVGA3D_NUM_LIGHTS];
SVGA3dLightData lightData[SVGA3D_NUM_LIGHTS];
uint32 shaders[SVGA3D_NUM_SHADERTYPE_PREDX];
SVGAGBVertexElement decl3[10 ];
uint32 pad1[3 ];
uint32 occQueryActive;
uint32 occQueryValue;
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 ];
uint32 tsColorKey[SVGA3D_NUM_TEXTURE_UNITS];
uint32 textureStages[SVGA3D_NUM_TEXTURE_UNITS][SVGA3D_TS_CONSTANT + 1 ];
uint32 tsColorKeyEnable[SVGA3D_NUM_TEXTURE_UNITS];
SVGA3dShaderConstFloat pShaderFValues[SVGA3D_CONSTREG_MAX];
SVGA3dShaderConstFloat vShaderFValues[SVGA3D_CONSTREG_MAX];
} SVGAGBContextData;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGAOTableType type;
PPN32 baseAddress;
uint32 sizeInBytes;
uint32 validSizeInBytes;
SVGAMobFormat ptDepth;
} SVGA3dCmdSetOTableBase;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGAOTableType type;
PPN64 baseAddress;
uint32 sizeInBytes;
uint32 validSizeInBytes;
SVGAMobFormat ptDepth;
} SVGA3dCmdSetOTableBase64;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGAOTableType type;
PPN64 baseAddress;
uint32 sizeInBytes;
uint32 validSizeInBytes;
SVGAMobFormat ptDepth;
} SVGA3dCmdGrowOTable;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGAOTableType type;
} SVGA3dCmdReadbackOTable;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDefineGBMob {
SVGAMobId mobid;
SVGAMobFormat ptDepth;
PPN32 base;
uint32 sizeInBytes;
} SVGA3dCmdDefineGBMob;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDestroyGBMob {
SVGAMobId mobid;
} SVGA3dCmdDestroyGBMob;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDefineGBMob64 {
SVGAMobId mobid;
SVGAMobFormat ptDepth;
PPN64 base;
uint32 sizeInBytes;
} SVGA3dCmdDefineGBMob64;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdRedefineGBMob64 {
SVGAMobId mobid;
SVGAMobFormat ptDepth;
PPN64 base;
uint32 sizeInBytes;
} SVGA3dCmdRedefineGBMob64;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdUpdateGBMobMapping {
SVGAMobId mobid;
} SVGA3dCmdUpdateGBMobMapping;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDefineGBSurface {
uint32 sid;
SVGA3dSurface1Flags surfaceFlags;
SVGA3dSurfaceFormat format;
uint32 numMipLevels;
uint32 multisampleCount;
SVGA3dTextureFilter autogenFilter;
SVGA3dSize size;
} SVGA3dCmdDefineGBSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDefineGBSurface_v2 {
uint32 sid;
SVGA3dSurface1Flags surfaceFlags;
SVGA3dSurfaceFormat format;
uint32 numMipLevels;
uint32 multisampleCount;
SVGA3dTextureFilter autogenFilter;
SVGA3dSize size;
uint32 arraySize;
uint32 pad;
} SVGA3dCmdDefineGBSurface_v2;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDefineGBSurface_v3 {
uint32 sid;
SVGA3dSurfaceAllFlags surfaceFlags;
SVGA3dSurfaceFormat format;
uint32 numMipLevels;
uint32 multisampleCount;
SVGA3dMSPattern multisamplePattern;
SVGA3dMSQualityLevel qualityLevel;
SVGA3dTextureFilter autogenFilter;
SVGA3dSize size;
uint32 arraySize;
} SVGA3dCmdDefineGBSurface_v3;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDefineGBSurface_v4 {
uint32 sid;
SVGA3dSurfaceAllFlags surfaceFlags;
SVGA3dSurfaceFormat format;
uint32 numMipLevels;
uint32 multisampleCount;
SVGA3dMSPattern multisamplePattern;
SVGA3dMSQualityLevel qualityLevel;
SVGA3dTextureFilter autogenFilter;
SVGA3dSize size;
uint32 arraySize;
uint32 bufferByteStride;
} SVGA3dCmdDefineGBSurface_v4;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDestroyGBSurface {
uint32 sid;
} SVGA3dCmdDestroyGBSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdBindGBSurface {
uint32 sid;
SVGAMobId mobid;
} SVGA3dCmdBindGBSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdBindGBSurfaceWithPitch {
uint32 sid;
SVGAMobId mobid;
uint32 baseLevelPitch;
} SVGA3dCmdBindGBSurfaceWithPitch;
#pragma pack (pop)
#define SVGA3D_COND_BIND_GB_SURFACE_FLAG_READBACK (1 << 0 )
#define SVGA3D_COND_BIND_GB_SURFACE_FLAG_UPDATE (1 << 1 )
#pragma pack (push, 1 )
typedef struct SVGA3dCmdCondBindGBSurface {
uint32 sid;
SVGAMobId testMobid;
SVGAMobId mobid;
uint32 flags;
} SVGA3dCmdCondBindGBSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdUpdateGBImage {
SVGA3dSurfaceImageId image;
SVGA3dBox box;
} SVGA3dCmdUpdateGBImage;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdUpdateGBSurface {
uint32 sid;
} SVGA3dCmdUpdateGBSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdReadbackGBImage {
SVGA3dSurfaceImageId image;
} SVGA3dCmdReadbackGBImage;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdReadbackGBSurface {
uint32 sid;
} SVGA3dCmdReadbackGBSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdReadbackGBImagePartial {
SVGA3dSurfaceImageId image;
SVGA3dBox box;
uint32 invertBox;
} SVGA3dCmdReadbackGBImagePartial;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdInvalidateGBImage {
SVGA3dSurfaceImageId image;
} SVGA3dCmdInvalidateGBImage;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdInvalidateGBSurface {
uint32 sid;
} SVGA3dCmdInvalidateGBSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdInvalidateGBImagePartial {
SVGA3dSurfaceImageId image;
SVGA3dBox box;
uint32 invertBox;
} SVGA3dCmdInvalidateGBImagePartial;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDefineGBContext {
uint32 cid;
} SVGA3dCmdDefineGBContext;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDestroyGBContext {
uint32 cid;
} SVGA3dCmdDestroyGBContext;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdBindGBContext {
uint32 cid;
SVGAMobId mobid;
uint32 validContents;
} SVGA3dCmdBindGBContext;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdReadbackGBContext {
uint32 cid;
} SVGA3dCmdReadbackGBContext;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdInvalidateGBContext {
uint32 cid;
} SVGA3dCmdInvalidateGBContext;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDefineGBShader {
uint32 shid;
SVGA3dShaderType type;
uint32 sizeInBytes;
} SVGA3dCmdDefineGBShader;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdBindGBShader {
uint32 shid;
SVGAMobId mobid;
uint32 offsetInBytes;
} SVGA3dCmdBindGBShader;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdDestroyGBShader {
uint32 shid;
} SVGA3dCmdDestroyGBShader;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
uint32 regStart;
SVGA3dShaderType shaderType;
SVGA3dShaderConstType constType;
} SVGA3dCmdSetGBShaderConstInline;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dQueryType type;
} SVGA3dCmdBeginGBQuery;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dQueryType type;
SVGAMobId mobid;
uint32 offset;
} SVGA3dCmdEndGBQuery;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 cid;
SVGA3dQueryType type;
SVGAMobId mobid;
uint32 offset;
} SVGA3dCmdWaitForGBQuery;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGAMobId mobid;
uint32 mustBeZero;
uint32 initialized;
} SVGA3dCmdEnableGart;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
SVGAMobId mobid;
uint32 gartOffset;
} SVGA3dCmdMapMobIntoGart;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 gartOffset;
uint32 numPages;
} SVGA3dCmdUnmapGartRange;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 stid;
uint32 width;
uint32 height;
int32 xRoot;
int32 yRoot;
SVGAScreenTargetFlags flags;
uint32 dpi;
} SVGA3dCmdDefineGBScreenTarget;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 stid;
} SVGA3dCmdDestroyGBScreenTarget;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 stid;
SVGA3dSurfaceImageId image;
} SVGA3dCmdBindGBScreenTarget;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 stid;
SVGA3dRect rect;
} SVGA3dCmdUpdateGBScreenTarget;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 stid;
SVGA3dRect rect;
SVGA3dFrameUpdateType type;
} SVGA3dCmdUpdateGBScreenTarget_v2;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 stid;
SVGA3dRect rect;
SVGA3dFrameUpdateType type;
SVGAUnsignedPoint srcPoint;
} SVGA3dCmdUpdateGBScreenTargetMove;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct SVGA3dCmdGBScreenDMA {
uint32 screenId;
uint32 dead;
SVGAMobId destMobID;
uint32 destPitch;
SVGAMobId changeMapMobID;
} SVGA3dCmdGBScreenDMA;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 value;
uint32 mobId;
uint32 mobOffset;
} SVGA3dCmdGBMobFence;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 stid;
SVGA3dSurfaceImageId dest;
uint32 statusMobId;
uint32 statusMobOffset;
uint32 mustBeInvalidId;
uint32 mustBeZero;
} SVGA3dCmdScreenCopy;
#pragma pack (pop)
#define SVGA_SCREEN_COPY_STATUS_FAILURE 0 x00
#define SVGA_SCREEN_COPY_STATUS_SUCCESS 0 x01
#define SVGA_SCREEN_COPY_STATUS_INVALID 0 xFFFFFFFF
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
} SVGA3dCmdWriteZeroSurface;
#pragma pack (pop)
#pragma pack (push, 1 )
typedef struct {
uint32 sid;
} SVGA3dCmdUpdateZeroSurface;
#pragma pack (pop)
#endif
Messung V0.5 in Prozent C=97 H=95 G=95
¤ Dauer der Verarbeitung: 0.17 Sekunden
(vorverarbeitet am 2026-06-07)
¤
*© Formatika GbR, Deutschland