| /* 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 (0x01) |
| #define SVGA3D_LOSTRETCHBLT_MIRRORX (0x01) |
| #define SVGA3D_LOSTRETCHBLT_MIRRORY (0x02) |
| #define SVGA3D_LOALPHABLEND_SRCHASALPHA (0x01) |
| |
| #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 0xFFFFFFFF |
| |
| #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 0x00 |
| #define SVGA_SCREEN_COPY_STATUS_SUCCESS 0x01 |
| #define SVGA_SCREEN_COPY_STATUS_INVALID 0xFFFFFFFF |
| |
| #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 |