1 /********************************************************** 2 * Copyright 2012-2021 VMware, Inc. 3 * SPDX-License-Identifier: GPL-2.0 OR MIT 4 * 5 * Permission is hereby granted, free of charge, to any person 6 * obtaining a copy of this software and associated documentation 7 * files (the "Software"), to deal in the Software without 8 * restriction, including without limitation the rights to use, copy, 9 * modify, merge, publish, distribute, sublicense, and/or sell copies 10 * of the Software, and to permit persons to whom the Software is 11 * furnished to do so, subject to the following conditions: 12 * 13 * The above copyright notice and this permission notice shall be 14 * included in all copies or substantial portions of the Software. 15 * 16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, 17 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND 19 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS 20 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN 21 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN 22 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 23 * SOFTWARE. 24 * 25 **********************************************************/ 26 27 /* 28 * svga3d_cmd.h -- 29 * 30 * SVGA 3d hardware cmd definitions 31 */ 32 33 34 35 #ifndef _SVGA3D_CMD_H_ 36 #define _SVGA3D_CMD_H_ 37 38 #include "svga3d_types.h" 39 #include "svga3d_limits.h" 40 #include "svga_reg.h" 41 42 typedef enum SVGAFifo3dCmdId { 43 SVGA_3D_CMD_LEGACY_BASE = 1000, 44 SVGA_3D_CMD_BASE = 1040, 45 46 SVGA_3D_CMD_SURFACE_DEFINE = 1040, 47 SVGA_3D_CMD_SURFACE_DESTROY = 1041, 48 SVGA_3D_CMD_SURFACE_COPY = 1042, 49 SVGA_3D_CMD_SURFACE_STRETCHBLT = 1043, 50 SVGA_3D_CMD_SURFACE_DMA = 1044, 51 SVGA_3D_CMD_CONTEXT_DEFINE = 1045, 52 SVGA_3D_CMD_CONTEXT_DESTROY = 1046, 53 SVGA_3D_CMD_SETTRANSFORM = 1047, 54 SVGA_3D_CMD_SETZRANGE = 1048, 55 SVGA_3D_CMD_SETRENDERSTATE = 1049, 56 SVGA_3D_CMD_SETRENDERTARGET = 1050, 57 SVGA_3D_CMD_SETTEXTURESTATE = 1051, 58 SVGA_3D_CMD_SETMATERIAL = 1052, 59 SVGA_3D_CMD_SETLIGHTDATA = 1053, 60 SVGA_3D_CMD_SETLIGHTENABLED = 1054, 61 SVGA_3D_CMD_SETVIEWPORT = 1055, 62 SVGA_3D_CMD_SETCLIPPLANE = 1056, 63 SVGA_3D_CMD_CLEAR = 1057, 64 SVGA_3D_CMD_PRESENT = 1058, 65 SVGA_3D_CMD_SHADER_DEFINE = 1059, 66 SVGA_3D_CMD_SHADER_DESTROY = 1060, 67 SVGA_3D_CMD_SET_SHADER = 1061, 68 SVGA_3D_CMD_SET_SHADER_CONST = 1062, 69 SVGA_3D_CMD_DRAW_PRIMITIVES = 1063, 70 SVGA_3D_CMD_SETSCISSORRECT = 1064, 71 SVGA_3D_CMD_BEGIN_QUERY = 1065, 72 SVGA_3D_CMD_END_QUERY = 1066, 73 SVGA_3D_CMD_WAIT_FOR_QUERY = 1067, 74 SVGA_3D_CMD_PRESENT_READBACK = 1068, 75 SVGA_3D_CMD_BLIT_SURFACE_TO_SCREEN = 1069, 76 SVGA_3D_CMD_SURFACE_DEFINE_V2 = 1070, 77 SVGA_3D_CMD_GENERATE_MIPMAPS = 1071, 78 SVGA_3D_CMD_DEAD4 = 1072, 79 SVGA_3D_CMD_DEAD5 = 1073, 80 SVGA_3D_CMD_DEAD6 = 1074, 81 SVGA_3D_CMD_DEAD7 = 1075, 82 SVGA_3D_CMD_DEAD8 = 1076, 83 SVGA_3D_CMD_DEAD9 = 1077, 84 SVGA_3D_CMD_DEAD10 = 1078, 85 SVGA_3D_CMD_DEAD11 = 1079, 86 SVGA_3D_CMD_ACTIVATE_SURFACE = 1080, 87 SVGA_3D_CMD_DEACTIVATE_SURFACE = 1081, 88 SVGA_3D_CMD_SCREEN_DMA = 1082, 89 SVGA_3D_CMD_DEAD1 = 1083, 90 SVGA_3D_CMD_DEAD2 = 1084, 91 92 SVGA_3D_CMD_DEAD12 = 1085, 93 SVGA_3D_CMD_DEAD13 = 1086, 94 SVGA_3D_CMD_DEAD14 = 1087, 95 SVGA_3D_CMD_DEAD15 = 1088, 96 SVGA_3D_CMD_DEAD16 = 1089, 97 SVGA_3D_CMD_DEAD17 = 1090, 98 99 SVGA_3D_CMD_SET_OTABLE_BASE = 1091, 100 SVGA_3D_CMD_READBACK_OTABLE = 1092, 101 102 SVGA_3D_CMD_DEFINE_GB_MOB = 1093, 103 SVGA_3D_CMD_DESTROY_GB_MOB = 1094, 104 SVGA_3D_CMD_DEAD3 = 1095, 105 SVGA_3D_CMD_UPDATE_GB_MOB_MAPPING = 1096, 106 107 SVGA_3D_CMD_DEFINE_GB_SURFACE = 1097, 108 SVGA_3D_CMD_DESTROY_GB_SURFACE = 1098, 109 SVGA_3D_CMD_BIND_GB_SURFACE = 1099, 110 SVGA_3D_CMD_COND_BIND_GB_SURFACE = 1100, 111 SVGA_3D_CMD_UPDATE_GB_IMAGE = 1101, 112 SVGA_3D_CMD_UPDATE_GB_SURFACE = 1102, 113 SVGA_3D_CMD_READBACK_GB_IMAGE = 1103, 114 SVGA_3D_CMD_READBACK_GB_SURFACE = 1104, 115 SVGA_3D_CMD_INVALIDATE_GB_IMAGE = 1105, 116 SVGA_3D_CMD_INVALIDATE_GB_SURFACE = 1106, 117 118 SVGA_3D_CMD_DEFINE_GB_CONTEXT = 1107, 119 SVGA_3D_CMD_DESTROY_GB_CONTEXT = 1108, 120 SVGA_3D_CMD_BIND_GB_CONTEXT = 1109, 121 SVGA_3D_CMD_READBACK_GB_CONTEXT = 1110, 122 SVGA_3D_CMD_INVALIDATE_GB_CONTEXT = 1111, 123 124 SVGA_3D_CMD_DEFINE_GB_SHADER = 1112, 125 SVGA_3D_CMD_DESTROY_GB_SHADER = 1113, 126 SVGA_3D_CMD_BIND_GB_SHADER = 1114, 127 128 SVGA_3D_CMD_SET_OTABLE_BASE64 = 1115, 129 130 SVGA_3D_CMD_BEGIN_GB_QUERY = 1116, 131 SVGA_3D_CMD_END_GB_QUERY = 1117, 132 SVGA_3D_CMD_WAIT_FOR_GB_QUERY = 1118, 133 134 SVGA_3D_CMD_NOP = 1119, 135 136 SVGA_3D_CMD_ENABLE_GART = 1120, 137 SVGA_3D_CMD_DISABLE_GART = 1121, 138 SVGA_3D_CMD_MAP_MOB_INTO_GART = 1122, 139 SVGA_3D_CMD_UNMAP_GART_RANGE = 1123, 140 141 SVGA_3D_CMD_DEFINE_GB_SCREENTARGET = 1124, 142 SVGA_3D_CMD_DESTROY_GB_SCREENTARGET = 1125, 143 SVGA_3D_CMD_BIND_GB_SCREENTARGET = 1126, 144 SVGA_3D_CMD_UPDATE_GB_SCREENTARGET = 1127, 145 146 SVGA_3D_CMD_READBACK_GB_IMAGE_PARTIAL = 1128, 147 SVGA_3D_CMD_INVALIDATE_GB_IMAGE_PARTIAL = 1129, 148 149 SVGA_3D_CMD_SET_GB_SHADERCONSTS_INLINE = 1130, 150 151 SVGA_3D_CMD_GB_SCREEN_DMA = 1131, 152 SVGA_3D_CMD_BIND_GB_SURFACE_WITH_PITCH = 1132, 153 SVGA_3D_CMD_GB_MOB_FENCE = 1133, 154 SVGA_3D_CMD_DEFINE_GB_SURFACE_V2 = 1134, 155 SVGA_3D_CMD_DEFINE_GB_MOB64 = 1135, 156 SVGA_3D_CMD_REDEFINE_GB_MOB64 = 1136, 157 SVGA_3D_CMD_NOP_ERROR = 1137, 158 159 SVGA_3D_CMD_SET_VERTEX_STREAMS = 1138, 160 SVGA_3D_CMD_SET_VERTEX_DECLS = 1139, 161 SVGA_3D_CMD_SET_VERTEX_DIVISORS = 1140, 162 SVGA_3D_CMD_DRAW = 1141, 163 SVGA_3D_CMD_DRAW_INDEXED = 1142, 164 165 SVGA_3D_CMD_DX_MIN = 1143, 166 SVGA_3D_CMD_DX_DEFINE_CONTEXT = 1143, 167 SVGA_3D_CMD_DX_DESTROY_CONTEXT = 1144, 168 SVGA_3D_CMD_DX_BIND_CONTEXT = 1145, 169 SVGA_3D_CMD_DX_READBACK_CONTEXT = 1146, 170 SVGA_3D_CMD_DX_INVALIDATE_CONTEXT = 1147, 171 SVGA_3D_CMD_DX_SET_SINGLE_CONSTANT_BUFFER = 1148, 172 SVGA_3D_CMD_DX_SET_SHADER_RESOURCES = 1149, 173 SVGA_3D_CMD_DX_SET_SHADER = 1150, 174 SVGA_3D_CMD_DX_SET_SAMPLERS = 1151, 175 SVGA_3D_CMD_DX_DRAW = 1152, 176 SVGA_3D_CMD_DX_DRAW_INDEXED = 1153, 177 SVGA_3D_CMD_DX_DRAW_INSTANCED = 1154, 178 SVGA_3D_CMD_DX_DRAW_INDEXED_INSTANCED = 1155, 179 SVGA_3D_CMD_DX_DRAW_AUTO = 1156, 180 SVGA_3D_CMD_DX_SET_INPUT_LAYOUT = 1157, 181 SVGA_3D_CMD_DX_SET_VERTEX_BUFFERS = 1158, 182 SVGA_3D_CMD_DX_SET_INDEX_BUFFER = 1159, 183 SVGA_3D_CMD_DX_SET_TOPOLOGY = 1160, 184 SVGA_3D_CMD_DX_SET_RENDERTARGETS = 1161, 185 SVGA_3D_CMD_DX_SET_BLEND_STATE = 1162, 186 SVGA_3D_CMD_DX_SET_DEPTHSTENCIL_STATE = 1163, 187 SVGA_3D_CMD_DX_SET_RASTERIZER_STATE = 1164, 188 SVGA_3D_CMD_DX_DEFINE_QUERY = 1165, 189 SVGA_3D_CMD_DX_DESTROY_QUERY = 1166, 190 SVGA_3D_CMD_DX_BIND_QUERY = 1167, 191 SVGA_3D_CMD_DX_SET_QUERY_OFFSET = 1168, 192 SVGA_3D_CMD_DX_BEGIN_QUERY = 1169, 193 SVGA_3D_CMD_DX_END_QUERY = 1170, 194 SVGA_3D_CMD_DX_READBACK_QUERY = 1171, 195 SVGA_3D_CMD_DX_SET_PREDICATION = 1172, 196 SVGA_3D_CMD_DX_SET_SOTARGETS = 1173, 197 SVGA_3D_CMD_DX_SET_VIEWPORTS = 1174, 198 SVGA_3D_CMD_DX_SET_SCISSORRECTS = 1175, 199 SVGA_3D_CMD_DX_CLEAR_RENDERTARGET_VIEW = 1176, 200 SVGA_3D_CMD_DX_CLEAR_DEPTHSTENCIL_VIEW = 1177, 201 SVGA_3D_CMD_DX_PRED_COPY_REGION = 1178, 202 SVGA_3D_CMD_DX_PRED_COPY = 1179, 203 SVGA_3D_CMD_DX_PRESENTBLT = 1180, 204 SVGA_3D_CMD_DX_GENMIPS = 1181, 205 SVGA_3D_CMD_DX_UPDATE_SUBRESOURCE = 1182, 206 SVGA_3D_CMD_DX_READBACK_SUBRESOURCE = 1183, 207 SVGA_3D_CMD_DX_INVALIDATE_SUBRESOURCE = 1184, 208 SVGA_3D_CMD_DX_DEFINE_SHADERRESOURCE_VIEW = 1185, 209 SVGA_3D_CMD_DX_DESTROY_SHADERRESOURCE_VIEW = 1186, 210 SVGA_3D_CMD_DX_DEFINE_RENDERTARGET_VIEW = 1187, 211 SVGA_3D_CMD_DX_DESTROY_RENDERTARGET_VIEW = 1188, 212 SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_VIEW = 1189, 213 SVGA_3D_CMD_DX_DESTROY_DEPTHSTENCIL_VIEW = 1190, 214 SVGA_3D_CMD_DX_DEFINE_ELEMENTLAYOUT = 1191, 215 SVGA_3D_CMD_DX_DESTROY_ELEMENTLAYOUT = 1192, 216 SVGA_3D_CMD_DX_DEFINE_BLEND_STATE = 1193, 217 SVGA_3D_CMD_DX_DESTROY_BLEND_STATE = 1194, 218 SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_STATE = 1195, 219 SVGA_3D_CMD_DX_DESTROY_DEPTHSTENCIL_STATE = 1196, 220 SVGA_3D_CMD_DX_DEFINE_RASTERIZER_STATE = 1197, 221 SVGA_3D_CMD_DX_DESTROY_RASTERIZER_STATE = 1198, 222 SVGA_3D_CMD_DX_DEFINE_SAMPLER_STATE = 1199, 223 SVGA_3D_CMD_DX_DESTROY_SAMPLER_STATE = 1200, 224 SVGA_3D_CMD_DX_DEFINE_SHADER = 1201, 225 SVGA_3D_CMD_DX_DESTROY_SHADER = 1202, 226 SVGA_3D_CMD_DX_BIND_SHADER = 1203, 227 SVGA_3D_CMD_DX_DEFINE_STREAMOUTPUT = 1204, 228 SVGA_3D_CMD_DX_DESTROY_STREAMOUTPUT = 1205, 229 SVGA_3D_CMD_DX_SET_STREAMOUTPUT = 1206, 230 SVGA_3D_CMD_DX_SET_COTABLE = 1207, 231 SVGA_3D_CMD_DX_READBACK_COTABLE = 1208, 232 SVGA_3D_CMD_DX_BUFFER_COPY = 1209, 233 SVGA_3D_CMD_DX_TRANSFER_FROM_BUFFER = 1210, 234 SVGA_3D_CMD_DX_SURFACE_COPY_AND_READBACK = 1211, 235 SVGA_3D_CMD_DX_MOVE_QUERY = 1212, 236 SVGA_3D_CMD_DX_BIND_ALL_QUERY = 1213, 237 SVGA_3D_CMD_DX_READBACK_ALL_QUERY = 1214, 238 SVGA_3D_CMD_DX_PRED_TRANSFER_FROM_BUFFER = 1215, 239 SVGA_3D_CMD_DX_MOB_FENCE_64 = 1216, 240 SVGA_3D_CMD_DX_BIND_ALL_SHADER = 1217, 241 SVGA_3D_CMD_DX_HINT = 1218, 242 SVGA_3D_CMD_DX_BUFFER_UPDATE = 1219, 243 SVGA_3D_CMD_DX_SET_VS_CONSTANT_BUFFER_OFFSET = 1220, 244 SVGA_3D_CMD_DX_SET_PS_CONSTANT_BUFFER_OFFSET = 1221, 245 SVGA_3D_CMD_DX_SET_GS_CONSTANT_BUFFER_OFFSET = 1222, 246 SVGA_3D_CMD_DX_SET_HS_CONSTANT_BUFFER_OFFSET = 1223, 247 SVGA_3D_CMD_DX_SET_DS_CONSTANT_BUFFER_OFFSET = 1224, 248 SVGA_3D_CMD_DX_SET_CS_CONSTANT_BUFFER_OFFSET = 1225, 249 250 SVGA_3D_CMD_DX_COND_BIND_ALL_SHADER = 1226, 251 SVGA_3D_CMD_DX_MAX = 1227, 252 253 SVGA_3D_CMD_SCREEN_COPY = 1227, 254 255 SVGA_3D_CMD_RESERVED1 = 1228, 256 SVGA_3D_CMD_RESERVED2 = 1229, 257 SVGA_3D_CMD_RESERVED3 = 1230, 258 SVGA_3D_CMD_RESERVED4 = 1231, 259 SVGA_3D_CMD_RESERVED5 = 1232, 260 SVGA_3D_CMD_RESERVED6 = 1233, 261 SVGA_3D_CMD_RESERVED7 = 1234, 262 SVGA_3D_CMD_RESERVED8 = 1235, 263 264 SVGA_3D_CMD_GROW_OTABLE = 1236, 265 SVGA_3D_CMD_DX_GROW_COTABLE = 1237, 266 SVGA_3D_CMD_INTRA_SURFACE_COPY = 1238, 267 268 SVGA_3D_CMD_DEFINE_GB_SURFACE_V3 = 1239, 269 270 SVGA_3D_CMD_DX_RESOLVE_COPY = 1240, 271 SVGA_3D_CMD_DX_PRED_RESOLVE_COPY = 1241, 272 SVGA_3D_CMD_DX_PRED_CONVERT_REGION = 1242, 273 SVGA_3D_CMD_DX_PRED_CONVERT = 1243, 274 SVGA_3D_CMD_WHOLE_SURFACE_COPY = 1244, 275 276 SVGA_3D_CMD_DX_DEFINE_UA_VIEW = 1245, 277 SVGA_3D_CMD_DX_DESTROY_UA_VIEW = 1246, 278 SVGA_3D_CMD_DX_CLEAR_UA_VIEW_UINT = 1247, 279 SVGA_3D_CMD_DX_CLEAR_UA_VIEW_FLOAT = 1248, 280 SVGA_3D_CMD_DX_COPY_STRUCTURE_COUNT = 1249, 281 SVGA_3D_CMD_DX_SET_UA_VIEWS = 1250, 282 283 SVGA_3D_CMD_DX_DRAW_INDEXED_INSTANCED_INDIRECT = 1251, 284 SVGA_3D_CMD_DX_DRAW_INSTANCED_INDIRECT = 1252, 285 SVGA_3D_CMD_DX_DISPATCH = 1253, 286 SVGA_3D_CMD_DX_DISPATCH_INDIRECT = 1254, 287 288 SVGA_3D_CMD_WRITE_ZERO_SURFACE = 1255, 289 SVGA_3D_CMD_UPDATE_ZERO_SURFACE = 1256, 290 SVGA_3D_CMD_DX_TRANSFER_TO_BUFFER = 1257, 291 SVGA_3D_CMD_DX_SET_STRUCTURE_COUNT = 1258, 292 293 SVGA_3D_CMD_LOGICOPS_BITBLT = 1259, 294 SVGA_3D_CMD_LOGICOPS_TRANSBLT = 1260, 295 SVGA_3D_CMD_LOGICOPS_STRETCHBLT = 1261, 296 SVGA_3D_CMD_LOGICOPS_COLORFILL = 1262, 297 SVGA_3D_CMD_LOGICOPS_ALPHABLEND = 1263, 298 SVGA_3D_CMD_LOGICOPS_CLEARTYPEBLEND = 1264, 299 300 SVGA_3D_CMD_DX_COPY_COTABLE_INTO_MOB = 1265, 301 302 SVGA_3D_CMD_UPDATE_GB_SCREENTARGET_V2 = 1266, 303 304 SVGA_3D_CMD_DEFINE_GB_SURFACE_V4 = 1267, 305 SVGA_3D_CMD_DX_SET_CS_UA_VIEWS = 1268, 306 SVGA_3D_CMD_DX_SET_MIN_LOD = 1269, 307 308 SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_VIEW_V2 = 1272, 309 SVGA_3D_CMD_DX_DEFINE_STREAMOUTPUT_WITH_MOB = 1273, 310 SVGA_3D_CMD_DX_SET_SHADER_IFACE = 1274, 311 SVGA_3D_CMD_DX_BIND_STREAMOUTPUT = 1275, 312 SVGA_3D_CMD_SURFACE_STRETCHBLT_NON_MS_TO_MS = 1276, 313 SVGA_3D_CMD_DX_BIND_SHADER_IFACE = 1277, 314 315 SVGA_3D_CMD_UPDATE_GB_SCREENTARGET_MOVE = 1278, 316 317 SVGA_3D_CMD_DX_PRED_STAGING_COPY = 1281, 318 SVGA_3D_CMD_DX_STAGING_COPY = 1282, 319 SVGA_3D_CMD_DX_PRED_STAGING_COPY_REGION = 1283, 320 SVGA_3D_CMD_DX_SET_VERTEX_BUFFERS_V2 = 1284, 321 SVGA_3D_CMD_DX_SET_INDEX_BUFFER_V2 = 1285, 322 SVGA_3D_CMD_DX_SET_VERTEX_BUFFERS_OFFSET_AND_SIZE = 1286, 323 SVGA_3D_CMD_DX_SET_INDEX_BUFFER_OFFSET_AND_SIZE = 1287, 324 SVGA_3D_CMD_DX_DEFINE_RASTERIZER_STATE_V2 = 1288, 325 SVGA_3D_CMD_DX_PRED_STAGING_CONVERT_REGION = 1289, 326 SVGA_3D_CMD_DX_PRED_STAGING_CONVERT = 1290, 327 SVGA_3D_CMD_DX_STAGING_BUFFER_COPY = 1291, 328 329 SVGA_3D_CMD_MAX = 1303, 330 SVGA_3D_CMD_FUTURE_MAX = 3000 331 } SVGAFifo3dCmdId; 332 333 #define SVGA_NUM_3D_CMD (SVGA_3D_CMD_MAX - SVGA_3D_CMD_BASE) 334 335 #pragma pack(push, 1) 336 typedef struct { 337 uint32 id; 338 uint32 size; 339 } SVGA3dCmdHeader; 340 #pragma pack(pop) 341 342 #pragma pack(push, 1) 343 typedef struct { 344 uint32 numMipLevels; 345 } SVGA3dSurfaceFace; 346 #pragma pack(pop) 347 348 #pragma pack(push, 1) 349 typedef struct { 350 uint32 sid; 351 SVGA3dSurface1Flags surfaceFlags; 352 SVGA3dSurfaceFormat format; 353 354 SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES]; 355 356 } SVGA3dCmdDefineSurface; 357 #pragma pack(pop) 358 359 #pragma pack(push, 1) 360 typedef struct { 361 uint32 sid; 362 SVGA3dSurface1Flags surfaceFlags; 363 SVGA3dSurfaceFormat format; 364 365 SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES]; 366 uint32 multisampleCount; 367 SVGA3dTextureFilter autogenFilter; 368 369 } SVGA3dCmdDefineSurface_v2; 370 #pragma pack(pop) 371 372 #pragma pack(push, 1) 373 typedef struct { 374 uint32 sid; 375 } SVGA3dCmdDestroySurface; 376 #pragma pack(pop) 377 378 #pragma pack(push, 1) 379 typedef struct { 380 uint32 cid; 381 } SVGA3dCmdDefineContext; 382 #pragma pack(pop) 383 384 #pragma pack(push, 1) 385 typedef struct { 386 uint32 cid; 387 } SVGA3dCmdDestroyContext; 388 #pragma pack(pop) 389 390 #pragma pack(push, 1) 391 typedef struct { 392 uint32 cid; 393 SVGA3dClearFlag clearFlag; 394 uint32 color; 395 float depth; 396 uint32 stencil; 397 398 } SVGA3dCmdClear; 399 #pragma pack(pop) 400 401 #pragma pack(push, 1) 402 typedef struct { 403 SVGA3dLightType type; 404 SVGA3dBool inWorldSpace; 405 float diffuse[4]; 406 float specular[4]; 407 float ambient[4]; 408 float position[4]; 409 float direction[4]; 410 float range; 411 float falloff; 412 float attenuation0; 413 float attenuation1; 414 float attenuation2; 415 float theta; 416 float phi; 417 } SVGA3dLightData; 418 #pragma pack(pop) 419 420 #pragma pack(push, 1) 421 typedef struct { 422 uint32 sid; 423 424 } SVGA3dCmdPresent; 425 #pragma pack(pop) 426 427 #pragma pack(push, 1) 428 typedef struct { 429 SVGA3dRenderStateName state; 430 union { 431 uint32 uintValue; 432 float floatValue; 433 }; 434 } SVGA3dRenderState; 435 #pragma pack(pop) 436 437 #pragma pack(push, 1) 438 typedef struct { 439 uint32 cid; 440 441 } SVGA3dCmdSetRenderState; 442 #pragma pack(pop) 443 444 #pragma pack(push, 1) 445 typedef struct { 446 uint32 cid; 447 SVGA3dRenderTargetType type; 448 SVGA3dSurfaceImageId target; 449 } SVGA3dCmdSetRenderTarget; 450 #pragma pack(pop) 451 452 #pragma pack(push, 1) 453 typedef struct { 454 SVGA3dSurfaceImageId src; 455 SVGA3dSurfaceImageId dest; 456 457 } SVGA3dCmdSurfaceCopy; 458 #pragma pack(pop) 459 460 #pragma pack(push, 1) 461 typedef struct { 462 SVGA3dSurfaceImageId surface; 463 SVGA3dCopyBox box; 464 } SVGA3dCmdIntraSurfaceCopy; 465 #pragma pack(pop) 466 467 #pragma pack(push, 1) 468 typedef struct { 469 uint32 srcSid; 470 uint32 destSid; 471 } SVGA3dCmdWholeSurfaceCopy; 472 #pragma pack(pop) 473 474 #pragma pack(push, 1) 475 typedef struct { 476 SVGA3dSurfaceImageId src; 477 SVGA3dSurfaceImageId dest; 478 SVGA3dBox boxSrc; 479 SVGA3dBox boxDest; 480 } SVGA3dCmdSurfaceStretchBltNonMSToMS; 481 #pragma pack(pop) 482 483 #pragma pack(push, 1) 484 typedef struct { 485 SVGA3dSurfaceImageId src; 486 SVGA3dSurfaceImageId dest; 487 SVGA3dBox boxSrc; 488 SVGA3dBox boxDest; 489 SVGA3dStretchBltMode mode; 490 } SVGA3dCmdSurfaceStretchBlt; 491 #pragma pack(pop) 492 493 #pragma pack(push, 1) 494 typedef struct { 495 uint32 discard : 1; 496 497 uint32 unsynchronized : 1; 498 499 uint32 reserved : 30; 500 } SVGA3dSurfaceDMAFlags; 501 #pragma pack(pop) 502 503 #pragma pack(push, 1) 504 typedef struct { 505 SVGAGuestImage guest; 506 SVGA3dSurfaceImageId host; 507 SVGA3dTransferType transfer; 508 509 } SVGA3dCmdSurfaceDMA; 510 #pragma pack(pop) 511 512 #pragma pack(push, 1) 513 typedef struct { 514 uint32 suffixSize; 515 516 uint32 maximumOffset; 517 518 SVGA3dSurfaceDMAFlags flags; 519 } SVGA3dCmdSurfaceDMASuffix; 520 #pragma pack(pop) 521 522 #pragma pack(push, 1) 523 typedef struct { 524 uint32 first; 525 uint32 last; 526 } SVGA3dArrayRangeHint; 527 #pragma pack(pop) 528 529 #pragma pack(push, 1) 530 typedef struct { 531 uint32 surfaceId; 532 uint32 offset; 533 uint32 stride; 534 } SVGA3dArray; 535 #pragma pack(pop) 536 537 #pragma pack(push, 1) 538 typedef struct { 539 SVGA3dDeclType type; 540 SVGA3dDeclMethod method; 541 SVGA3dDeclUsage usage; 542 uint32 usageIndex; 543 } SVGA3dVertexArrayIdentity; 544 #pragma pack(pop) 545 546 #pragma pack(push, 1) 547 typedef struct SVGA3dVertexDecl { 548 SVGA3dVertexArrayIdentity identity; 549 SVGA3dArray array; 550 SVGA3dArrayRangeHint rangeHint; 551 } SVGA3dVertexDecl; 552 #pragma pack(pop) 553 554 #pragma pack(push, 1) 555 typedef struct SVGA3dPrimitiveRange { 556 SVGA3dPrimitiveType primType; 557 uint32 primitiveCount; 558 559 SVGA3dArray indexArray; 560 uint32 indexWidth; 561 562 int32 indexBias; 563 } SVGA3dPrimitiveRange; 564 #pragma pack(pop) 565 566 #pragma pack(push, 1) 567 typedef struct { 568 uint32 cid; 569 uint32 numVertexDecls; 570 uint32 numRanges; 571 572 } SVGA3dCmdDrawPrimitives; 573 #pragma pack(pop) 574 575 #pragma pack(push, 1) 576 typedef struct { 577 uint32 cid; 578 579 uint32 primitiveCount; 580 uint32 startVertexLocation; 581 582 uint8 primitiveType; 583 uint8 padding[3]; 584 } SVGA3dCmdDraw; 585 #pragma pack(pop) 586 587 #pragma pack(push, 1) 588 typedef struct { 589 uint32 cid; 590 591 uint8 primitiveType; 592 593 uint32 indexBufferSid; 594 uint32 indexBufferOffset; 595 596 uint8 indexBufferStride; 597 598 int32 baseVertexLocation; 599 600 uint32 primitiveCount; 601 uint32 pad0; 602 uint16 pad1; 603 } SVGA3dCmdDrawIndexed; 604 #pragma pack(pop) 605 606 #pragma pack(push, 1) 607 typedef struct { 608 uint16 streamOffset; 609 uint8 stream; 610 uint8 type; 611 uint8 method; 612 uint8 usage; 613 uint8 usageIndex; 614 uint8 padding; 615 616 } SVGA3dVertexElement; 617 #pragma pack(pop) 618 619 #define SVGA3D_VERTEX_ELEMENT_RESPECT_STREAM (1 << 7) 620 621 #pragma pack(push, 1) 622 typedef struct { 623 uint32 cid; 624 625 uint32 numElements; 626 627 } SVGA3dCmdSetVertexDecls; 628 #pragma pack(pop) 629 630 #pragma pack(push, 1) 631 typedef struct { 632 uint32 sid; 633 uint32 stride; 634 uint32 offset; 635 } SVGA3dVertexStream; 636 #pragma pack(pop) 637 638 #pragma pack(push, 1) 639 typedef struct { 640 uint32 cid; 641 642 uint32 numStreams; 643 644 } SVGA3dCmdSetVertexStreams; 645 #pragma pack(pop) 646 647 #pragma pack(push, 1) 648 typedef struct { 649 uint32 cid; 650 uint32 numDivisors; 651 } SVGA3dCmdSetVertexDivisors; 652 #pragma pack(pop) 653 654 #pragma pack(push, 1) 655 typedef struct { 656 uint32 stage; 657 SVGA3dTextureStateName name; 658 union { 659 uint32 value; 660 float floatValue; 661 }; 662 } SVGA3dTextureState; 663 #pragma pack(pop) 664 665 #pragma pack(push, 1) 666 typedef struct { 667 uint32 cid; 668 669 } SVGA3dCmdSetTextureState; 670 #pragma pack(pop) 671 672 #pragma pack(push, 1) 673 typedef struct { 674 uint32 cid; 675 SVGA3dTransformType type; 676 float matrix[16]; 677 } SVGA3dCmdSetTransform; 678 #pragma pack(pop) 679 680 #pragma pack(push, 1) 681 typedef struct { 682 float min; 683 float max; 684 } SVGA3dZRange; 685 #pragma pack(pop) 686 687 #pragma pack(push, 1) 688 typedef struct { 689 uint32 cid; 690 SVGA3dZRange zRange; 691 } SVGA3dCmdSetZRange; 692 #pragma pack(pop) 693 694 #pragma pack(push, 1) 695 typedef struct { 696 float diffuse[4]; 697 float ambient[4]; 698 float specular[4]; 699 float emissive[4]; 700 float shininess; 701 } SVGA3dMaterial; 702 #pragma pack(pop) 703 704 #pragma pack(push, 1) 705 typedef struct { 706 uint32 cid; 707 SVGA3dFace face; 708 SVGA3dMaterial material; 709 } SVGA3dCmdSetMaterial; 710 #pragma pack(pop) 711 712 #pragma pack(push, 1) 713 typedef struct { 714 uint32 cid; 715 uint32 index; 716 SVGA3dLightData data; 717 } SVGA3dCmdSetLightData; 718 #pragma pack(pop) 719 720 #pragma pack(push, 1) 721 typedef struct { 722 uint32 cid; 723 uint32 index; 724 uint32 enabled; 725 } SVGA3dCmdSetLightEnabled; 726 #pragma pack(pop) 727 728 #pragma pack(push, 1) 729 typedef struct { 730 uint32 cid; 731 SVGA3dRect rect; 732 } SVGA3dCmdSetViewport; 733 #pragma pack(pop) 734 735 #pragma pack(push, 1) 736 typedef struct { 737 uint32 cid; 738 SVGA3dRect rect; 739 } SVGA3dCmdSetScissorRect; 740 #pragma pack(pop) 741 742 #pragma pack(push, 1) 743 typedef struct { 744 uint32 cid; 745 uint32 index; 746 float plane[4]; 747 } SVGA3dCmdSetClipPlane; 748 #pragma pack(pop) 749 750 #pragma pack(push, 1) 751 typedef struct { 752 uint32 cid; 753 uint32 shid; 754 SVGA3dShaderType type; 755 756 } SVGA3dCmdDefineShader; 757 #pragma pack(pop) 758 759 #pragma pack(push, 1) 760 typedef struct { 761 uint32 cid; 762 uint32 shid; 763 SVGA3dShaderType type; 764 } SVGA3dCmdDestroyShader; 765 #pragma pack(pop) 766 767 #pragma pack(push, 1) 768 typedef struct { 769 uint32 cid; 770 uint32 reg; 771 SVGA3dShaderType type; 772 SVGA3dShaderConstType ctype; 773 uint32 values[4]; 774 775 } SVGA3dCmdSetShaderConst; 776 #pragma pack(pop) 777 778 #pragma pack(push, 1) 779 typedef struct { 780 uint32 cid; 781 SVGA3dShaderType type; 782 uint32 shid; 783 } SVGA3dCmdSetShader; 784 #pragma pack(pop) 785 786 #pragma pack(push, 1) 787 typedef struct { 788 uint32 cid; 789 SVGA3dQueryType type; 790 } SVGA3dCmdBeginQuery; 791 #pragma pack(pop) 792 793 #pragma pack(push, 1) 794 typedef struct { 795 uint32 cid; 796 SVGA3dQueryType type; 797 SVGAGuestPtr guestResult; 798 } SVGA3dCmdEndQuery; 799 #pragma pack(pop) 800 801 #pragma pack(push, 1) 802 typedef struct { 803 uint32 cid; 804 SVGA3dQueryType type; 805 SVGAGuestPtr guestResult; 806 } SVGA3dCmdWaitForQuery; 807 #pragma pack(pop) 808 809 #pragma pack(push, 1) 810 typedef struct { 811 uint32 totalSize; 812 SVGA3dQueryState state; 813 union { 814 uint32 result32; 815 uint32 queryCookie; 816 }; 817 } SVGA3dQueryResult; 818 #pragma pack(pop) 819 820 #pragma pack(push, 1) 821 typedef struct { 822 SVGA3dSurfaceImageId srcImage; 823 SVGASignedRect srcRect; 824 uint32 destScreenId; 825 SVGASignedRect destRect; 826 827 } SVGA3dCmdBlitSurfaceToScreen; 828 #pragma pack(pop) 829 830 #pragma pack(push, 1) 831 typedef struct { 832 uint32 sid; 833 SVGA3dTextureFilter filter; 834 } SVGA3dCmdGenerateMipmaps; 835 #pragma pack(pop) 836 837 #pragma pack(push, 1) 838 typedef struct { 839 uint32 sid; 840 } SVGA3dCmdActivateSurface; 841 #pragma pack(pop) 842 843 #pragma pack(push, 1) 844 typedef struct { 845 uint32 sid; 846 } SVGA3dCmdDeactivateSurface; 847 #pragma pack(pop) 848 849 #pragma pack(push, 1) 850 typedef struct SVGA3dCmdScreenDMA { 851 uint32 screenId; 852 SVGAGuestImage refBuffer; 853 SVGAGuestImage destBuffer; 854 SVGAGuestImage changeMap; 855 } SVGA3dCmdScreenDMA; 856 #pragma pack(pop) 857 858 #define SVGA3D_LOTRANSBLT_HONORALPHA (0x01) 859 #define SVGA3D_LOSTRETCHBLT_MIRRORX (0x01) 860 #define SVGA3D_LOSTRETCHBLT_MIRRORY (0x02) 861 #define SVGA3D_LOALPHABLEND_SRCHASALPHA (0x01) 862 863 #pragma pack(push, 1) 864 typedef struct SVGA3dCmdLogicOpsBitBlt { 865 SVGA3dSurfaceImageId src; 866 SVGA3dSurfaceImageId dst; 867 SVGA3dLogicOp logicOp; 868 SVGA3dLogicOpRop3 logicOpRop3; 869 870 } SVGA3dCmdLogicOpsBitBlt; 871 #pragma pack(pop) 872 873 #pragma pack(push, 1) 874 typedef struct SVGA3dCmdLogicOpsTransBlt { 875 SVGA3dSurfaceImageId src; 876 SVGA3dSurfaceImageId dst; 877 uint32 color; 878 uint32 flags; 879 SVGA3dBox srcBox; 880 SVGA3dSignedBox dstBox; 881 SVGA3dBox clipBox; 882 } SVGA3dCmdLogicOpsTransBlt; 883 #pragma pack(pop) 884 885 #pragma pack(push, 1) 886 typedef struct SVGA3dCmdLogicOpsStretchBlt { 887 SVGA3dSurfaceImageId src; 888 SVGA3dSurfaceImageId dst; 889 uint16 mode; 890 uint16 flags; 891 SVGA3dBox srcBox; 892 SVGA3dSignedBox dstBox; 893 SVGA3dBox clipBox; 894 } SVGA3dCmdLogicOpsStretchBlt; 895 #pragma pack(pop) 896 897 #pragma pack(push, 1) 898 typedef struct SVGA3dCmdLogicOpsColorFill { 899 SVGA3dSurfaceImageId dst; 900 uint32 color; 901 SVGA3dLogicOp logicOp; 902 SVGA3dLogicOpRop3 logicOpRop3; 903 904 } SVGA3dCmdLogicOpsColorFill; 905 #pragma pack(pop) 906 907 #pragma pack(push, 1) 908 typedef struct SVGA3dCmdLogicOpsAlphaBlend { 909 SVGA3dSurfaceImageId src; 910 SVGA3dSurfaceImageId dst; 911 uint32 alphaVal; 912 uint32 flags; 913 SVGA3dBox srcBox; 914 SVGA3dSignedBox dstBox; 915 SVGA3dBox clipBox; 916 } SVGA3dCmdLogicOpsAlphaBlend; 917 #pragma pack(pop) 918 919 #define SVGA3D_CLEARTYPE_INVALID_GAMMA_INDEX 0xFFFFFFFF 920 921 #define SVGA3D_CLEARTYPE_GAMMA_WIDTH 512 922 #define SVGA3D_CLEARTYPE_GAMMA_HEIGHT 16 923 924 #pragma pack(push, 1) 925 typedef struct SVGA3dCmdLogicOpsClearTypeBlend { 926 SVGA3dSurfaceImageId tmp; 927 SVGA3dSurfaceImageId dst; 928 SVGA3dSurfaceImageId gammaSurf; 929 SVGA3dSurfaceImageId alphaSurf; 930 uint32 gamma; 931 uint32 color; 932 uint32 color2; 933 int32 alphaOffsetX; 934 int32 alphaOffsetY; 935 936 } SVGA3dCmdLogicOpsClearTypeBlend; 937 #pragma pack(pop) 938 939 #pragma pack(push, 1) 940 typedef struct { 941 SVGAMobFormat ptDepth; 942 uint32 sizeInBytes; 943 PPN64 base; 944 } SVGAOTableMobEntry; 945 #pragma pack(pop) 946 947 #pragma pack(push, 1) 948 typedef struct { 949 SVGA3dSurfaceFormat format; 950 SVGA3dSurface1Flags surface1Flags; 951 uint32 numMipLevels; 952 uint32 multisampleCount; 953 SVGA3dTextureFilter autogenFilter; 954 SVGA3dSize size; 955 SVGAMobId mobid; 956 uint32 arraySize; 957 uint32 mobPitch; 958 SVGA3dSurface2Flags surface2Flags; 959 uint8 multisamplePattern; 960 uint8 qualityLevel; 961 uint16 bufferByteStride; 962 float minLOD; 963 uint32 pad0[2]; 964 } SVGAOTableSurfaceEntry; 965 #pragma pack(pop) 966 967 #pragma pack(push, 1) 968 typedef struct { 969 uint32 cid; 970 SVGAMobId mobid; 971 } SVGAOTableContextEntry; 972 #pragma pack(pop) 973 974 #pragma pack(push, 1) 975 typedef struct { 976 SVGA3dShaderType type; 977 uint32 sizeInBytes; 978 uint32 offsetInBytes; 979 SVGAMobId mobid; 980 } SVGAOTableShaderEntry; 981 #pragma pack(pop) 982 983 #define SVGA_STFLAG_PRIMARY (1 << 0) 984 #define SVGA_STFLAG_RESERVED (1 << 1) 985 typedef uint32 SVGAScreenTargetFlags; 986 987 #pragma pack(push, 1) 988 typedef struct { 989 SVGA3dSurfaceImageId image; 990 uint32 width; 991 uint32 height; 992 int32 xRoot; 993 int32 yRoot; 994 SVGAScreenTargetFlags flags; 995 uint32 dpi; 996 uint32 pad[7]; 997 } SVGAOTableScreenTargetEntry; 998 #pragma pack(pop) 999 1000 #pragma pack(push, 1) 1001 typedef struct { 1002 float value[4]; 1003 } SVGA3dShaderConstFloat; 1004 #pragma pack(pop) 1005 1006 #pragma pack(push, 1) 1007 typedef struct { 1008 int32 value[4]; 1009 } SVGA3dShaderConstInt; 1010 #pragma pack(pop) 1011 1012 #pragma pack(push, 1) 1013 typedef struct { 1014 uint32 value; 1015 } SVGA3dShaderConstBool; 1016 #pragma pack(pop) 1017 1018 #pragma pack(push, 1) 1019 typedef struct { 1020 uint16 streamOffset; 1021 uint8 stream; 1022 uint8 type; 1023 uint8 methodUsage; 1024 uint8 usageIndex; 1025 } SVGAGBVertexElement; 1026 #pragma pack(pop) 1027 1028 #pragma pack(push, 1) 1029 typedef struct { 1030 uint32 sid; 1031 uint16 stride; 1032 uint32 offset; 1033 } SVGAGBVertexStream; 1034 #pragma pack(pop) 1035 #pragma pack(push, 1) 1036 typedef struct { 1037 SVGA3dRect viewport; 1038 SVGA3dRect scissorRect; 1039 SVGA3dZRange zRange; 1040 1041 SVGA3dSurfaceImageId renderTargets[SVGA3D_RT_MAX]; 1042 SVGAGBVertexElement decl1[4]; 1043 1044 uint32 renderStates[SVGA3D_RS_MAX]; 1045 SVGAGBVertexElement decl2[18]; 1046 uint32 pad0[2]; 1047 1048 struct { 1049 SVGA3dFace face; 1050 SVGA3dMaterial material; 1051 } material; 1052 1053 float clipPlanes[SVGA3D_MAX_CLIP_PLANES][4]; 1054 float matrices[SVGA3D_TRANSFORM_MAX][16]; 1055 1056 SVGA3dBool lightEnabled[SVGA3D_NUM_LIGHTS]; 1057 SVGA3dLightData lightData[SVGA3D_NUM_LIGHTS]; 1058 1059 uint32 shaders[SVGA3D_NUM_SHADERTYPE_PREDX]; 1060 SVGAGBVertexElement decl3[10]; 1061 uint32 pad1[3]; 1062 1063 uint32 occQueryActive; 1064 uint32 occQueryValue; 1065 1066 SVGA3dShaderConstInt pShaderIValues[SVGA3D_CONSTINTREG_MAX]; 1067 SVGA3dShaderConstInt vShaderIValues[SVGA3D_CONSTINTREG_MAX]; 1068 uint16 pShaderBValues; 1069 uint16 vShaderBValues; 1070 1071 SVGAGBVertexStream streams[SVGA3D_MAX_VERTEX_ARRAYS]; 1072 SVGA3dVertexDivisor divisors[SVGA3D_MAX_VERTEX_ARRAYS]; 1073 uint32 numVertexDecls; 1074 uint32 numVertexStreams; 1075 uint32 numVertexDivisors; 1076 uint32 pad2[30]; 1077 1078 uint32 tsColorKey[SVGA3D_NUM_TEXTURE_UNITS]; 1079 uint32 textureStages[SVGA3D_NUM_TEXTURE_UNITS][SVGA3D_TS_CONSTANT + 1]; 1080 uint32 tsColorKeyEnable[SVGA3D_NUM_TEXTURE_UNITS]; 1081 1082 SVGA3dShaderConstFloat pShaderFValues[SVGA3D_CONSTREG_MAX]; 1083 SVGA3dShaderConstFloat vShaderFValues[SVGA3D_CONSTREG_MAX]; 1084 } SVGAGBContextData; 1085 #pragma pack(pop) 1086 1087 #pragma pack(push, 1) 1088 typedef struct { 1089 SVGAOTableType type; 1090 PPN32 baseAddress; 1091 uint32 sizeInBytes; 1092 uint32 validSizeInBytes; 1093 SVGAMobFormat ptDepth; 1094 } SVGA3dCmdSetOTableBase; 1095 #pragma pack(pop) 1096 1097 #pragma pack(push, 1) 1098 typedef struct { 1099 SVGAOTableType type; 1100 PPN64 baseAddress; 1101 uint32 sizeInBytes; 1102 uint32 validSizeInBytes; 1103 SVGAMobFormat ptDepth; 1104 } SVGA3dCmdSetOTableBase64; 1105 #pragma pack(pop) 1106 1107 #pragma pack(push, 1) 1108 typedef struct { 1109 SVGAOTableType type; 1110 PPN64 baseAddress; 1111 uint32 sizeInBytes; 1112 uint32 validSizeInBytes; 1113 SVGAMobFormat ptDepth; 1114 } SVGA3dCmdGrowOTable; 1115 #pragma pack(pop) 1116 1117 #pragma pack(push, 1) 1118 typedef struct { 1119 SVGAOTableType type; 1120 } SVGA3dCmdReadbackOTable; 1121 #pragma pack(pop) 1122 1123 #pragma pack(push, 1) 1124 typedef struct SVGA3dCmdDefineGBMob { 1125 SVGAMobId mobid; 1126 SVGAMobFormat ptDepth; 1127 PPN32 base; 1128 uint32 sizeInBytes; 1129 } SVGA3dCmdDefineGBMob; 1130 #pragma pack(pop) 1131 1132 #pragma pack(push, 1) 1133 typedef struct SVGA3dCmdDestroyGBMob { 1134 SVGAMobId mobid; 1135 } SVGA3dCmdDestroyGBMob; 1136 #pragma pack(pop) 1137 1138 #pragma pack(push, 1) 1139 typedef struct SVGA3dCmdDefineGBMob64 { 1140 SVGAMobId mobid; 1141 SVGAMobFormat ptDepth; 1142 PPN64 base; 1143 uint32 sizeInBytes; 1144 } SVGA3dCmdDefineGBMob64; 1145 #pragma pack(pop) 1146 1147 #pragma pack(push, 1) 1148 typedef struct SVGA3dCmdRedefineGBMob64 { 1149 SVGAMobId mobid; 1150 SVGAMobFormat ptDepth; 1151 PPN64 base; 1152 uint32 sizeInBytes; 1153 } SVGA3dCmdRedefineGBMob64; 1154 #pragma pack(pop) 1155 1156 #pragma pack(push, 1) 1157 typedef struct SVGA3dCmdUpdateGBMobMapping { 1158 SVGAMobId mobid; 1159 } SVGA3dCmdUpdateGBMobMapping; 1160 #pragma pack(pop) 1161 1162 #pragma pack(push, 1) 1163 typedef struct SVGA3dCmdDefineGBSurface { 1164 uint32 sid; 1165 SVGA3dSurface1Flags surfaceFlags; 1166 SVGA3dSurfaceFormat format; 1167 uint32 numMipLevels; 1168 uint32 multisampleCount; 1169 SVGA3dTextureFilter autogenFilter; 1170 SVGA3dSize size; 1171 } SVGA3dCmdDefineGBSurface; 1172 #pragma pack(pop) 1173 1174 #pragma pack(push, 1) 1175 typedef struct SVGA3dCmdDefineGBSurface_v2 { 1176 uint32 sid; 1177 SVGA3dSurface1Flags surfaceFlags; 1178 SVGA3dSurfaceFormat format; 1179 uint32 numMipLevels; 1180 uint32 multisampleCount; 1181 SVGA3dTextureFilter autogenFilter; 1182 SVGA3dSize size; 1183 uint32 arraySize; 1184 uint32 pad; 1185 } SVGA3dCmdDefineGBSurface_v2; 1186 #pragma pack(pop) 1187 1188 #pragma pack(push, 1) 1189 typedef struct SVGA3dCmdDefineGBSurface_v3 { 1190 uint32 sid; 1191 SVGA3dSurfaceAllFlags surfaceFlags; 1192 SVGA3dSurfaceFormat format; 1193 uint32 numMipLevels; 1194 uint32 multisampleCount; 1195 SVGA3dMSPattern multisamplePattern; 1196 SVGA3dMSQualityLevel qualityLevel; 1197 SVGA3dTextureFilter autogenFilter; 1198 SVGA3dSize size; 1199 uint32 arraySize; 1200 } SVGA3dCmdDefineGBSurface_v3; 1201 #pragma pack(pop) 1202 1203 #pragma pack(push, 1) 1204 typedef struct SVGA3dCmdDefineGBSurface_v4 { 1205 uint32 sid; 1206 SVGA3dSurfaceAllFlags surfaceFlags; 1207 SVGA3dSurfaceFormat format; 1208 uint32 numMipLevels; 1209 uint32 multisampleCount; 1210 SVGA3dMSPattern multisamplePattern; 1211 SVGA3dMSQualityLevel qualityLevel; 1212 SVGA3dTextureFilter autogenFilter; 1213 SVGA3dSize size; 1214 uint32 arraySize; 1215 uint32 bufferByteStride; 1216 } SVGA3dCmdDefineGBSurface_v4; 1217 #pragma pack(pop) 1218 1219 #pragma pack(push, 1) 1220 typedef struct SVGA3dCmdDestroyGBSurface { 1221 uint32 sid; 1222 } SVGA3dCmdDestroyGBSurface; 1223 #pragma pack(pop) 1224 1225 #pragma pack(push, 1) 1226 typedef struct SVGA3dCmdBindGBSurface { 1227 uint32 sid; 1228 SVGAMobId mobid; 1229 } SVGA3dCmdBindGBSurface; 1230 #pragma pack(pop) 1231 1232 #pragma pack(push, 1) 1233 typedef struct SVGA3dCmdBindGBSurfaceWithPitch { 1234 uint32 sid; 1235 SVGAMobId mobid; 1236 uint32 baseLevelPitch; 1237 } SVGA3dCmdBindGBSurfaceWithPitch; 1238 #pragma pack(pop) 1239 1240 #define SVGA3D_COND_BIND_GB_SURFACE_FLAG_READBACK (1 << 0) 1241 #define SVGA3D_COND_BIND_GB_SURFACE_FLAG_UPDATE (1 << 1) 1242 1243 #pragma pack(push, 1) 1244 typedef struct SVGA3dCmdCondBindGBSurface { 1245 uint32 sid; 1246 SVGAMobId testMobid; 1247 SVGAMobId mobid; 1248 uint32 flags; 1249 } SVGA3dCmdCondBindGBSurface; 1250 #pragma pack(pop) 1251 1252 #pragma pack(push, 1) 1253 typedef struct SVGA3dCmdUpdateGBImage { 1254 SVGA3dSurfaceImageId image; 1255 SVGA3dBox box; 1256 } SVGA3dCmdUpdateGBImage; 1257 #pragma pack(pop) 1258 1259 #pragma pack(push, 1) 1260 typedef struct SVGA3dCmdUpdateGBSurface { 1261 uint32 sid; 1262 } SVGA3dCmdUpdateGBSurface; 1263 #pragma pack(pop) 1264 1265 #pragma pack(push, 1) 1266 typedef struct SVGA3dCmdReadbackGBImage { 1267 SVGA3dSurfaceImageId image; 1268 } SVGA3dCmdReadbackGBImage; 1269 #pragma pack(pop) 1270 1271 #pragma pack(push, 1) 1272 typedef struct SVGA3dCmdReadbackGBSurface { 1273 uint32 sid; 1274 } SVGA3dCmdReadbackGBSurface; 1275 #pragma pack(pop) 1276 1277 #pragma pack(push, 1) 1278 typedef struct SVGA3dCmdReadbackGBImagePartial { 1279 SVGA3dSurfaceImageId image; 1280 SVGA3dBox box; 1281 uint32 invertBox; 1282 } SVGA3dCmdReadbackGBImagePartial; 1283 #pragma pack(pop) 1284 1285 #pragma pack(push, 1) 1286 typedef struct SVGA3dCmdInvalidateGBImage { 1287 SVGA3dSurfaceImageId image; 1288 } SVGA3dCmdInvalidateGBImage; 1289 #pragma pack(pop) 1290 1291 #pragma pack(push, 1) 1292 typedef struct SVGA3dCmdInvalidateGBSurface { 1293 uint32 sid; 1294 } SVGA3dCmdInvalidateGBSurface; 1295 #pragma pack(pop) 1296 1297 #pragma pack(push, 1) 1298 typedef struct SVGA3dCmdInvalidateGBImagePartial { 1299 SVGA3dSurfaceImageId image; 1300 SVGA3dBox box; 1301 uint32 invertBox; 1302 } SVGA3dCmdInvalidateGBImagePartial; 1303 #pragma pack(pop) 1304 1305 #pragma pack(push, 1) 1306 typedef struct SVGA3dCmdDefineGBContext { 1307 uint32 cid; 1308 } SVGA3dCmdDefineGBContext; 1309 #pragma pack(pop) 1310 1311 #pragma pack(push, 1) 1312 typedef struct SVGA3dCmdDestroyGBContext { 1313 uint32 cid; 1314 } SVGA3dCmdDestroyGBContext; 1315 #pragma pack(pop) 1316 1317 #pragma pack(push, 1) 1318 typedef struct SVGA3dCmdBindGBContext { 1319 uint32 cid; 1320 SVGAMobId mobid; 1321 uint32 validContents; 1322 } SVGA3dCmdBindGBContext; 1323 #pragma pack(pop) 1324 1325 #pragma pack(push, 1) 1326 typedef struct SVGA3dCmdReadbackGBContext { 1327 uint32 cid; 1328 } SVGA3dCmdReadbackGBContext; 1329 #pragma pack(pop) 1330 1331 #pragma pack(push, 1) 1332 typedef struct SVGA3dCmdInvalidateGBContext { 1333 uint32 cid; 1334 } SVGA3dCmdInvalidateGBContext; 1335 #pragma pack(pop) 1336 1337 #pragma pack(push, 1) 1338 typedef struct SVGA3dCmdDefineGBShader { 1339 uint32 shid; 1340 SVGA3dShaderType type; 1341 uint32 sizeInBytes; 1342 } SVGA3dCmdDefineGBShader; 1343 #pragma pack(pop) 1344 1345 #pragma pack(push, 1) 1346 typedef struct SVGA3dCmdBindGBShader { 1347 uint32 shid; 1348 SVGAMobId mobid; 1349 uint32 offsetInBytes; 1350 } SVGA3dCmdBindGBShader; 1351 #pragma pack(pop) 1352 1353 #pragma pack(push, 1) 1354 typedef struct SVGA3dCmdDestroyGBShader { 1355 uint32 shid; 1356 } SVGA3dCmdDestroyGBShader; 1357 #pragma pack(pop) 1358 1359 #pragma pack(push, 1) 1360 typedef struct { 1361 uint32 cid; 1362 uint32 regStart; 1363 SVGA3dShaderType shaderType; 1364 SVGA3dShaderConstType constType; 1365 1366 } SVGA3dCmdSetGBShaderConstInline; 1367 #pragma pack(pop) 1368 1369 #pragma pack(push, 1) 1370 typedef struct { 1371 uint32 cid; 1372 SVGA3dQueryType type; 1373 } SVGA3dCmdBeginGBQuery; 1374 #pragma pack(pop) 1375 1376 #pragma pack(push, 1) 1377 typedef struct { 1378 uint32 cid; 1379 SVGA3dQueryType type; 1380 SVGAMobId mobid; 1381 uint32 offset; 1382 } SVGA3dCmdEndGBQuery; 1383 #pragma pack(pop) 1384 1385 #pragma pack(push, 1) 1386 typedef struct { 1387 uint32 cid; 1388 SVGA3dQueryType type; 1389 SVGAMobId mobid; 1390 uint32 offset; 1391 } SVGA3dCmdWaitForGBQuery; 1392 #pragma pack(pop) 1393 1394 #pragma pack(push, 1) 1395 typedef struct { 1396 SVGAMobId mobid; 1397 uint32 mustBeZero; 1398 uint32 initialized; 1399 } SVGA3dCmdEnableGart; 1400 #pragma pack(pop) 1401 1402 #pragma pack(push, 1) 1403 typedef struct { 1404 SVGAMobId mobid; 1405 uint32 gartOffset; 1406 } SVGA3dCmdMapMobIntoGart; 1407 #pragma pack(pop) 1408 1409 #pragma pack(push, 1) 1410 typedef struct { 1411 uint32 gartOffset; 1412 uint32 numPages; 1413 } SVGA3dCmdUnmapGartRange; 1414 #pragma pack(pop) 1415 1416 #pragma pack(push, 1) 1417 typedef struct { 1418 uint32 stid; 1419 uint32 width; 1420 uint32 height; 1421 int32 xRoot; 1422 int32 yRoot; 1423 SVGAScreenTargetFlags flags; 1424 1425 uint32 dpi; 1426 } SVGA3dCmdDefineGBScreenTarget; 1427 #pragma pack(pop) 1428 1429 #pragma pack(push, 1) 1430 typedef struct { 1431 uint32 stid; 1432 } SVGA3dCmdDestroyGBScreenTarget; 1433 #pragma pack(pop) 1434 1435 #pragma pack(push, 1) 1436 typedef struct { 1437 uint32 stid; 1438 SVGA3dSurfaceImageId image; 1439 } SVGA3dCmdBindGBScreenTarget; 1440 #pragma pack(pop) 1441 1442 #pragma pack(push, 1) 1443 typedef struct { 1444 uint32 stid; 1445 SVGA3dRect rect; 1446 } SVGA3dCmdUpdateGBScreenTarget; 1447 #pragma pack(pop) 1448 1449 #pragma pack(push, 1) 1450 typedef struct { 1451 uint32 stid; 1452 SVGA3dRect rect; 1453 SVGA3dFrameUpdateType type; 1454 } SVGA3dCmdUpdateGBScreenTarget_v2; 1455 #pragma pack(pop) 1456 1457 #pragma pack(push, 1) 1458 typedef struct { 1459 uint32 stid; 1460 SVGA3dRect rect; 1461 SVGA3dFrameUpdateType type; 1462 SVGAUnsignedPoint srcPoint; 1463 } SVGA3dCmdUpdateGBScreenTargetMove; 1464 #pragma pack(pop) 1465 1466 #pragma pack(push, 1) 1467 typedef struct SVGA3dCmdGBScreenDMA { 1468 uint32 screenId; 1469 uint32 dead; 1470 SVGAMobId destMobID; 1471 uint32 destPitch; 1472 SVGAMobId changeMapMobID; 1473 } SVGA3dCmdGBScreenDMA; 1474 #pragma pack(pop) 1475 1476 #pragma pack(push, 1) 1477 typedef struct { 1478 uint32 value; 1479 uint32 mobId; 1480 uint32 mobOffset; 1481 } SVGA3dCmdGBMobFence; 1482 #pragma pack(pop) 1483 1484 #pragma pack(push, 1) 1485 typedef struct { 1486 uint32 stid; 1487 SVGA3dSurfaceImageId dest; 1488 1489 uint32 statusMobId; 1490 uint32 statusMobOffset; 1491 1492 uint32 mustBeInvalidId; 1493 uint32 mustBeZero; 1494 } SVGA3dCmdScreenCopy; 1495 #pragma pack(pop) 1496 1497 #define SVGA_SCREEN_COPY_STATUS_FAILURE 0x00 1498 #define SVGA_SCREEN_COPY_STATUS_SUCCESS 0x01 1499 #define SVGA_SCREEN_COPY_STATUS_INVALID 0xFFFFFFFF 1500 1501 #pragma pack(push, 1) 1502 typedef struct { 1503 uint32 sid; 1504 } SVGA3dCmdWriteZeroSurface; 1505 #pragma pack(pop) 1506 1507 #pragma pack(push, 1) 1508 typedef struct { 1509 uint32 sid; 1510 } SVGA3dCmdUpdateZeroSurface; 1511 #pragma pack(pop) 1512 1513 #endif 1514