1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33#ifndef _SVGA3D_CMD_H_
34#define _SVGA3D_CMD_H_
35
36#define INCLUDE_ALLOW_MODULE
37#define INCLUDE_ALLOW_USERLEVEL
38#define INCLUDE_ALLOW_VMCORE
39
40#include "includeCheck.h"
41#include "svga3d_types.h"
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57typedef enum {
58 SVGA_3D_CMD_LEGACY_BASE = 1000,
59 SVGA_3D_CMD_BASE = 1040,
60
61 SVGA_3D_CMD_SURFACE_DEFINE = 1040,
62 SVGA_3D_CMD_SURFACE_DESTROY = 1041,
63 SVGA_3D_CMD_SURFACE_COPY = 1042,
64 SVGA_3D_CMD_SURFACE_STRETCHBLT = 1043,
65 SVGA_3D_CMD_SURFACE_DMA = 1044,
66 SVGA_3D_CMD_CONTEXT_DEFINE = 1045,
67 SVGA_3D_CMD_CONTEXT_DESTROY = 1046,
68 SVGA_3D_CMD_SETTRANSFORM = 1047,
69 SVGA_3D_CMD_SETZRANGE = 1048,
70 SVGA_3D_CMD_SETRENDERSTATE = 1049,
71 SVGA_3D_CMD_SETRENDERTARGET = 1050,
72 SVGA_3D_CMD_SETTEXTURESTATE = 1051,
73 SVGA_3D_CMD_SETMATERIAL = 1052,
74 SVGA_3D_CMD_SETLIGHTDATA = 1053,
75 SVGA_3D_CMD_SETLIGHTENABLED = 1054,
76 SVGA_3D_CMD_SETVIEWPORT = 1055,
77 SVGA_3D_CMD_SETCLIPPLANE = 1056,
78 SVGA_3D_CMD_CLEAR = 1057,
79 SVGA_3D_CMD_PRESENT = 1058,
80 SVGA_3D_CMD_SHADER_DEFINE = 1059,
81 SVGA_3D_CMD_SHADER_DESTROY = 1060,
82 SVGA_3D_CMD_SET_SHADER = 1061,
83 SVGA_3D_CMD_SET_SHADER_CONST = 1062,
84 SVGA_3D_CMD_DRAW_PRIMITIVES = 1063,
85 SVGA_3D_CMD_SETSCISSORRECT = 1064,
86 SVGA_3D_CMD_BEGIN_QUERY = 1065,
87 SVGA_3D_CMD_END_QUERY = 1066,
88 SVGA_3D_CMD_WAIT_FOR_QUERY = 1067,
89 SVGA_3D_CMD_PRESENT_READBACK = 1068,
90 SVGA_3D_CMD_BLIT_SURFACE_TO_SCREEN = 1069,
91 SVGA_3D_CMD_SURFACE_DEFINE_V2 = 1070,
92 SVGA_3D_CMD_GENERATE_MIPMAPS = 1071,
93 SVGA_3D_CMD_DEAD4 = 1072,
94 SVGA_3D_CMD_DEAD5 = 1073,
95 SVGA_3D_CMD_DEAD6 = 1074,
96 SVGA_3D_CMD_DEAD7 = 1075,
97 SVGA_3D_CMD_DEAD8 = 1076,
98 SVGA_3D_CMD_DEAD9 = 1077,
99 SVGA_3D_CMD_DEAD10 = 1078,
100 SVGA_3D_CMD_DEAD11 = 1079,
101 SVGA_3D_CMD_ACTIVATE_SURFACE = 1080,
102 SVGA_3D_CMD_DEACTIVATE_SURFACE = 1081,
103 SVGA_3D_CMD_SCREEN_DMA = 1082,
104 SVGA_3D_CMD_DEAD1 = 1083,
105 SVGA_3D_CMD_DEAD2 = 1084,
106
107 SVGA_3D_CMD_DEAD12 = 1085,
108 SVGA_3D_CMD_DEAD13 = 1086,
109 SVGA_3D_CMD_DEAD14 = 1087,
110 SVGA_3D_CMD_DEAD15 = 1088,
111 SVGA_3D_CMD_DEAD16 = 1089,
112 SVGA_3D_CMD_DEAD17 = 1090,
113
114 SVGA_3D_CMD_SET_OTABLE_BASE = 1091,
115 SVGA_3D_CMD_READBACK_OTABLE = 1092,
116
117 SVGA_3D_CMD_DEFINE_GB_MOB = 1093,
118 SVGA_3D_CMD_DESTROY_GB_MOB = 1094,
119 SVGA_3D_CMD_DEAD3 = 1095,
120 SVGA_3D_CMD_UPDATE_GB_MOB_MAPPING = 1096,
121
122 SVGA_3D_CMD_DEFINE_GB_SURFACE = 1097,
123 SVGA_3D_CMD_DESTROY_GB_SURFACE = 1098,
124 SVGA_3D_CMD_BIND_GB_SURFACE = 1099,
125 SVGA_3D_CMD_COND_BIND_GB_SURFACE = 1100,
126 SVGA_3D_CMD_UPDATE_GB_IMAGE = 1101,
127 SVGA_3D_CMD_UPDATE_GB_SURFACE = 1102,
128 SVGA_3D_CMD_READBACK_GB_IMAGE = 1103,
129 SVGA_3D_CMD_READBACK_GB_SURFACE = 1104,
130 SVGA_3D_CMD_INVALIDATE_GB_IMAGE = 1105,
131 SVGA_3D_CMD_INVALIDATE_GB_SURFACE = 1106,
132
133 SVGA_3D_CMD_DEFINE_GB_CONTEXT = 1107,
134 SVGA_3D_CMD_DESTROY_GB_CONTEXT = 1108,
135 SVGA_3D_CMD_BIND_GB_CONTEXT = 1109,
136 SVGA_3D_CMD_READBACK_GB_CONTEXT = 1110,
137 SVGA_3D_CMD_INVALIDATE_GB_CONTEXT = 1111,
138
139 SVGA_3D_CMD_DEFINE_GB_SHADER = 1112,
140 SVGA_3D_CMD_DESTROY_GB_SHADER = 1113,
141 SVGA_3D_CMD_BIND_GB_SHADER = 1114,
142
143 SVGA_3D_CMD_SET_OTABLE_BASE64 = 1115,
144
145 SVGA_3D_CMD_BEGIN_GB_QUERY = 1116,
146 SVGA_3D_CMD_END_GB_QUERY = 1117,
147 SVGA_3D_CMD_WAIT_FOR_GB_QUERY = 1118,
148
149 SVGA_3D_CMD_NOP = 1119,
150
151 SVGA_3D_CMD_ENABLE_GART = 1120,
152 SVGA_3D_CMD_DISABLE_GART = 1121,
153 SVGA_3D_CMD_MAP_MOB_INTO_GART = 1122,
154 SVGA_3D_CMD_UNMAP_GART_RANGE = 1123,
155
156 SVGA_3D_CMD_DEFINE_GB_SCREENTARGET = 1124,
157 SVGA_3D_CMD_DESTROY_GB_SCREENTARGET = 1125,
158 SVGA_3D_CMD_BIND_GB_SCREENTARGET = 1126,
159 SVGA_3D_CMD_UPDATE_GB_SCREENTARGET = 1127,
160
161 SVGA_3D_CMD_READBACK_GB_IMAGE_PARTIAL = 1128,
162 SVGA_3D_CMD_INVALIDATE_GB_IMAGE_PARTIAL = 1129,
163
164 SVGA_3D_CMD_SET_GB_SHADERCONSTS_INLINE = 1130,
165
166 SVGA_3D_CMD_GB_SCREEN_DMA = 1131,
167 SVGA_3D_CMD_BIND_GB_SURFACE_WITH_PITCH = 1132,
168 SVGA_3D_CMD_GB_MOB_FENCE = 1133,
169 SVGA_3D_CMD_DEFINE_GB_SURFACE_V2 = 1134,
170 SVGA_3D_CMD_DEFINE_GB_MOB64 = 1135,
171 SVGA_3D_CMD_REDEFINE_GB_MOB64 = 1136,
172 SVGA_3D_CMD_NOP_ERROR = 1137,
173
174 SVGA_3D_CMD_SET_VERTEX_STREAMS = 1138,
175 SVGA_3D_CMD_SET_VERTEX_DECLS = 1139,
176 SVGA_3D_CMD_SET_VERTEX_DIVISORS = 1140,
177 SVGA_3D_CMD_DRAW = 1141,
178 SVGA_3D_CMD_DRAW_INDEXED = 1142,
179
180
181
182
183 SVGA_3D_CMD_DX_MIN = 1143,
184 SVGA_3D_CMD_DX_DEFINE_CONTEXT = 1143,
185 SVGA_3D_CMD_DX_DESTROY_CONTEXT = 1144,
186 SVGA_3D_CMD_DX_BIND_CONTEXT = 1145,
187 SVGA_3D_CMD_DX_READBACK_CONTEXT = 1146,
188 SVGA_3D_CMD_DX_INVALIDATE_CONTEXT = 1147,
189 SVGA_3D_CMD_DX_SET_SINGLE_CONSTANT_BUFFER = 1148,
190 SVGA_3D_CMD_DX_SET_SHADER_RESOURCES = 1149,
191 SVGA_3D_CMD_DX_SET_SHADER = 1150,
192 SVGA_3D_CMD_DX_SET_SAMPLERS = 1151,
193 SVGA_3D_CMD_DX_DRAW = 1152,
194 SVGA_3D_CMD_DX_DRAW_INDEXED = 1153,
195 SVGA_3D_CMD_DX_DRAW_INSTANCED = 1154,
196 SVGA_3D_CMD_DX_DRAW_INDEXED_INSTANCED = 1155,
197 SVGA_3D_CMD_DX_DRAW_AUTO = 1156,
198 SVGA_3D_CMD_DX_SET_INPUT_LAYOUT = 1157,
199 SVGA_3D_CMD_DX_SET_VERTEX_BUFFERS = 1158,
200 SVGA_3D_CMD_DX_SET_INDEX_BUFFER = 1159,
201 SVGA_3D_CMD_DX_SET_TOPOLOGY = 1160,
202 SVGA_3D_CMD_DX_SET_RENDERTARGETS = 1161,
203 SVGA_3D_CMD_DX_SET_BLEND_STATE = 1162,
204 SVGA_3D_CMD_DX_SET_DEPTHSTENCIL_STATE = 1163,
205 SVGA_3D_CMD_DX_SET_RASTERIZER_STATE = 1164,
206 SVGA_3D_CMD_DX_DEFINE_QUERY = 1165,
207 SVGA_3D_CMD_DX_DESTROY_QUERY = 1166,
208 SVGA_3D_CMD_DX_BIND_QUERY = 1167,
209 SVGA_3D_CMD_DX_SET_QUERY_OFFSET = 1168,
210 SVGA_3D_CMD_DX_BEGIN_QUERY = 1169,
211 SVGA_3D_CMD_DX_END_QUERY = 1170,
212 SVGA_3D_CMD_DX_READBACK_QUERY = 1171,
213 SVGA_3D_CMD_DX_SET_PREDICATION = 1172,
214 SVGA_3D_CMD_DX_SET_SOTARGETS = 1173,
215 SVGA_3D_CMD_DX_SET_VIEWPORTS = 1174,
216 SVGA_3D_CMD_DX_SET_SCISSORRECTS = 1175,
217 SVGA_3D_CMD_DX_CLEAR_RENDERTARGET_VIEW = 1176,
218 SVGA_3D_CMD_DX_CLEAR_DEPTHSTENCIL_VIEW = 1177,
219 SVGA_3D_CMD_DX_PRED_COPY_REGION = 1178,
220 SVGA_3D_CMD_DX_PRED_COPY = 1179,
221 SVGA_3D_CMD_DX_PRESENTBLT = 1180,
222 SVGA_3D_CMD_DX_GENMIPS = 1181,
223 SVGA_3D_CMD_DX_UPDATE_SUBRESOURCE = 1182,
224 SVGA_3D_CMD_DX_READBACK_SUBRESOURCE = 1183,
225 SVGA_3D_CMD_DX_INVALIDATE_SUBRESOURCE = 1184,
226 SVGA_3D_CMD_DX_DEFINE_SHADERRESOURCE_VIEW = 1185,
227 SVGA_3D_CMD_DX_DESTROY_SHADERRESOURCE_VIEW = 1186,
228 SVGA_3D_CMD_DX_DEFINE_RENDERTARGET_VIEW = 1187,
229 SVGA_3D_CMD_DX_DESTROY_RENDERTARGET_VIEW = 1188,
230 SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_VIEW = 1189,
231 SVGA_3D_CMD_DX_DESTROY_DEPTHSTENCIL_VIEW = 1190,
232 SVGA_3D_CMD_DX_DEFINE_ELEMENTLAYOUT = 1191,
233 SVGA_3D_CMD_DX_DESTROY_ELEMENTLAYOUT = 1192,
234 SVGA_3D_CMD_DX_DEFINE_BLEND_STATE = 1193,
235 SVGA_3D_CMD_DX_DESTROY_BLEND_STATE = 1194,
236 SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_STATE = 1195,
237 SVGA_3D_CMD_DX_DESTROY_DEPTHSTENCIL_STATE = 1196,
238 SVGA_3D_CMD_DX_DEFINE_RASTERIZER_STATE = 1197,
239 SVGA_3D_CMD_DX_DESTROY_RASTERIZER_STATE = 1198,
240 SVGA_3D_CMD_DX_DEFINE_SAMPLER_STATE = 1199,
241 SVGA_3D_CMD_DX_DESTROY_SAMPLER_STATE = 1200,
242 SVGA_3D_CMD_DX_DEFINE_SHADER = 1201,
243 SVGA_3D_CMD_DX_DESTROY_SHADER = 1202,
244 SVGA_3D_CMD_DX_BIND_SHADER = 1203,
245 SVGA_3D_CMD_DX_DEFINE_STREAMOUTPUT = 1204,
246 SVGA_3D_CMD_DX_DESTROY_STREAMOUTPUT = 1205,
247 SVGA_3D_CMD_DX_SET_STREAMOUTPUT = 1206,
248 SVGA_3D_CMD_DX_SET_COTABLE = 1207,
249 SVGA_3D_CMD_DX_READBACK_COTABLE = 1208,
250 SVGA_3D_CMD_DX_BUFFER_COPY = 1209,
251 SVGA_3D_CMD_DX_TRANSFER_FROM_BUFFER = 1210,
252 SVGA_3D_CMD_DX_SURFACE_COPY_AND_READBACK = 1211,
253 SVGA_3D_CMD_DX_MOVE_QUERY = 1212,
254 SVGA_3D_CMD_DX_BIND_ALL_QUERY = 1213,
255 SVGA_3D_CMD_DX_READBACK_ALL_QUERY = 1214,
256 SVGA_3D_CMD_DX_PRED_TRANSFER_FROM_BUFFER = 1215,
257 SVGA_3D_CMD_DX_MOB_FENCE_64 = 1216,
258 SVGA_3D_CMD_DX_BIND_ALL_SHADER = 1217,
259 SVGA_3D_CMD_DX_HINT = 1218,
260 SVGA_3D_CMD_DX_BUFFER_UPDATE = 1219,
261 SVGA_3D_CMD_DX_SET_VS_CONSTANT_BUFFER_OFFSET = 1220,
262 SVGA_3D_CMD_DX_SET_PS_CONSTANT_BUFFER_OFFSET = 1221,
263 SVGA_3D_CMD_DX_SET_GS_CONSTANT_BUFFER_OFFSET = 1222,
264 SVGA_3D_CMD_DX_SET_HS_CONSTANT_BUFFER_OFFSET = 1223,
265 SVGA_3D_CMD_DX_SET_DS_CONSTANT_BUFFER_OFFSET = 1224,
266 SVGA_3D_CMD_DX_SET_CS_CONSTANT_BUFFER_OFFSET = 1225,
267
268 SVGA_3D_CMD_DX_COND_BIND_ALL_SHADER = 1226,
269 SVGA_3D_CMD_DX_MAX = 1227,
270
271 SVGA_3D_CMD_SCREEN_COPY = 1227,
272
273 SVGA_3D_CMD_RESERVED1 = 1228,
274 SVGA_3D_CMD_RESERVED2 = 1229,
275 SVGA_3D_CMD_RESERVED3 = 1230,
276 SVGA_3D_CMD_RESERVED4 = 1231,
277 SVGA_3D_CMD_RESERVED5 = 1232,
278 SVGA_3D_CMD_RESERVED6 = 1233,
279 SVGA_3D_CMD_RESERVED7 = 1234,
280 SVGA_3D_CMD_RESERVED8 = 1235,
281
282 SVGA_3D_CMD_GROW_OTABLE = 1236,
283 SVGA_3D_CMD_DX_GROW_COTABLE = 1237,
284 SVGA_3D_CMD_INTRA_SURFACE_COPY = 1238,
285
286 SVGA_3D_CMD_DEFINE_GB_SURFACE_V3 = 1239,
287
288 SVGA_3D_CMD_DX_RESOLVE_COPY = 1240,
289 SVGA_3D_CMD_DX_PRED_RESOLVE_COPY = 1241,
290 SVGA_3D_CMD_DX_PRED_CONVERT_REGION = 1242,
291 SVGA_3D_CMD_DX_PRED_CONVERT = 1243,
292 SVGA_3D_CMD_WHOLE_SURFACE_COPY = 1244,
293
294 SVGA_3D_CMD_DX_DEFINE_UA_VIEW = 1245,
295 SVGA_3D_CMD_DX_DESTROY_UA_VIEW = 1246,
296 SVGA_3D_CMD_DX_CLEAR_UA_VIEW_UINT = 1247,
297 SVGA_3D_CMD_DX_CLEAR_UA_VIEW_FLOAT = 1248,
298 SVGA_3D_CMD_DX_COPY_STRUCTURE_COUNT = 1249,
299 SVGA_3D_CMD_DX_SET_UA_VIEWS = 1250,
300
301 SVGA_3D_CMD_DX_DRAW_INDEXED_INSTANCED_INDIRECT = 1251,
302 SVGA_3D_CMD_DX_DRAW_INSTANCED_INDIRECT = 1252,
303 SVGA_3D_CMD_DX_DISPATCH = 1253,
304 SVGA_3D_CMD_DX_DISPATCH_INDIRECT = 1254,
305
306 SVGA_3D_CMD_WRITE_ZERO_SURFACE = 1255,
307 SVGA_3D_CMD_HINT_ZERO_SURFACE = 1256,
308 SVGA_3D_CMD_DX_TRANSFER_TO_BUFFER = 1257,
309 SVGA_3D_CMD_DX_SET_STRUCTURE_COUNT = 1258,
310
311 SVGA_3D_CMD_LOGICOPS_BITBLT = 1259,
312 SVGA_3D_CMD_LOGICOPS_TRANSBLT = 1260,
313 SVGA_3D_CMD_LOGICOPS_STRETCHBLT = 1261,
314 SVGA_3D_CMD_LOGICOPS_COLORFILL = 1262,
315 SVGA_3D_CMD_LOGICOPS_ALPHABLEND = 1263,
316 SVGA_3D_CMD_LOGICOPS_CLEARTYPEBLEND = 1264,
317
318 SVGA_3D_CMD_RESERVED2_1 = 1265,
319
320 SVGA_3D_CMD_RESERVED2_2 = 1266,
321 SVGA_3D_CMD_DEFINE_GB_SURFACE_V4 = 1267,
322 SVGA_3D_CMD_DX_SET_CS_UA_VIEWS = 1268,
323 SVGA_3D_CMD_DX_SET_MIN_LOD = 1269,
324 SVGA_3D_CMD_RESERVED2_3 = 1270,
325 SVGA_3D_CMD_RESERVED2_4 = 1271,
326 SVGA_3D_CMD_DX_DEFINE_DEPTHSTENCIL_VIEW_V2 = 1272,
327 SVGA_3D_CMD_DX_DEFINE_STREAMOUTPUT_WITH_MOB = 1273,
328 SVGA_3D_CMD_DX_SET_SHADER_IFACE = 1274,
329 SVGA_3D_CMD_DX_BIND_STREAMOUTPUT = 1275,
330 SVGA_3D_CMD_SURFACE_STRETCHBLT_NON_MS_TO_MS = 1276,
331 SVGA_3D_CMD_DX_BIND_SHADER_IFACE = 1277,
332
333 SVGA_3D_CMD_MAX = 1278,
334 SVGA_3D_CMD_FUTURE_MAX = 3000
335} SVGAFifo3dCmdId;
336
337#define SVGA_NUM_3D_CMD (SVGA_3D_CMD_MAX - SVGA_3D_CMD_BASE)
338
339
340
341
342
343
344
345
346typedef
347#include "vmware_pack_begin.h"
348struct {
349 uint32 id;
350 uint32 size;
351}
352#include "vmware_pack_end.h"
353SVGA3dCmdHeader;
354
355typedef
356#include "vmware_pack_begin.h"
357struct {
358 uint32 numMipLevels;
359}
360#include "vmware_pack_end.h"
361SVGA3dSurfaceFace;
362
363typedef
364#include "vmware_pack_begin.h"
365struct {
366 uint32 sid;
367 SVGA3dSurface1Flags surfaceFlags;
368 SVGA3dSurfaceFormat format;
369
370
371
372
373
374
375
376 SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES];
377
378
379
380
381
382
383
384
385
386
387}
388#include "vmware_pack_end.h"
389SVGA3dCmdDefineSurface;
390
391typedef
392#include "vmware_pack_begin.h"
393struct {
394 uint32 sid;
395 SVGA3dSurface1Flags surfaceFlags;
396 SVGA3dSurfaceFormat format;
397
398
399
400
401
402
403
404 SVGA3dSurfaceFace face[SVGA3D_MAX_SURFACE_FACES];
405 uint32 multisampleCount;
406 SVGA3dTextureFilter autogenFilter;
407
408
409
410
411
412
413
414
415
416
417}
418#include "vmware_pack_end.h"
419SVGA3dCmdDefineSurface_v2;
420
421typedef
422#include "vmware_pack_begin.h"
423struct {
424 uint32 sid;
425}
426#include "vmware_pack_end.h"
427SVGA3dCmdDestroySurface;
428
429typedef
430#include "vmware_pack_begin.h"
431struct {
432 uint32 cid;
433}
434#include "vmware_pack_end.h"
435SVGA3dCmdDefineContext;
436
437typedef
438#include "vmware_pack_begin.h"
439struct {
440 uint32 cid;
441}
442#include "vmware_pack_end.h"
443SVGA3dCmdDestroyContext;
444
445typedef
446#include "vmware_pack_begin.h"
447struct {
448 uint32 cid;
449 SVGA3dClearFlag clearFlag;
450 uint32 color;
451 float depth;
452 uint32 stencil;
453
454}
455#include "vmware_pack_end.h"
456SVGA3dCmdClear;
457
458typedef
459#include "vmware_pack_begin.h"
460struct {
461 SVGA3dLightType type;
462 SVGA3dBool inWorldSpace;
463 float diffuse[4];
464 float specular[4];
465 float ambient[4];
466 float position[4];
467 float direction[4];
468 float range;
469 float falloff;
470 float attenuation0;
471 float attenuation1;
472 float attenuation2;
473 float theta;
474 float phi;
475}
476#include "vmware_pack_end.h"
477SVGA3dLightData;
478
479typedef
480#include "vmware_pack_begin.h"
481struct {
482 uint32 sid;
483
484}
485#include "vmware_pack_end.h"
486SVGA3dCmdPresent;
487
488typedef
489#include "vmware_pack_begin.h"
490struct {
491 SVGA3dRenderStateName state;
492 union {
493 uint32 uintValue;
494 float floatValue;
495 };
496}
497#include "vmware_pack_end.h"
498SVGA3dRenderState;
499
500typedef
501#include "vmware_pack_begin.h"
502struct {
503 uint32 cid;
504
505}
506#include "vmware_pack_end.h"
507SVGA3dCmdSetRenderState;
508
509typedef
510#include "vmware_pack_begin.h"
511struct {
512 uint32 cid;
513 SVGA3dRenderTargetType type;
514 SVGA3dSurfaceImageId target;
515}
516#include "vmware_pack_end.h"
517SVGA3dCmdSetRenderTarget;
518
519typedef
520#include "vmware_pack_begin.h"
521struct {
522 SVGA3dSurfaceImageId src;
523 SVGA3dSurfaceImageId dest;
524
525}
526#include "vmware_pack_end.h"
527SVGA3dCmdSurfaceCopy;
528
529
530
531
532
533typedef
534#include "vmware_pack_begin.h"
535struct {
536 SVGA3dSurfaceImageId surface;
537 SVGA3dCopyBox box;
538}
539#include "vmware_pack_end.h"
540SVGA3dCmdIntraSurfaceCopy;
541
542typedef
543#include "vmware_pack_begin.h"
544struct {
545 uint32 srcSid;
546 uint32 destSid;
547}
548#include "vmware_pack_end.h"
549SVGA3dCmdWholeSurfaceCopy;
550
551typedef
552#include "vmware_pack_begin.h"
553struct {
554 SVGA3dSurfaceImageId src;
555 SVGA3dSurfaceImageId dest;
556 SVGA3dBox boxSrc;
557 SVGA3dBox boxDest;
558}
559#include "vmware_pack_end.h"
560SVGA3dCmdSurfaceStretchBltNonMSToMS;
561
562
563typedef
564#include "vmware_pack_begin.h"
565struct {
566 SVGA3dSurfaceImageId src;
567 SVGA3dSurfaceImageId dest;
568 SVGA3dBox boxSrc;
569 SVGA3dBox boxDest;
570 SVGA3dStretchBltMode mode;
571}
572#include "vmware_pack_end.h"
573SVGA3dCmdSurfaceStretchBlt;
574
575typedef
576#include "vmware_pack_begin.h"
577struct {
578
579
580
581
582
583 uint32 discard : 1;
584
585
586
587
588
589 uint32 unsynchronized : 1;
590
591
592
593
594
595 uint32 reserved : 30;
596}
597#include "vmware_pack_end.h"
598SVGA3dSurfaceDMAFlags;
599
600typedef
601#include "vmware_pack_begin.h"
602struct {
603 SVGAGuestImage guest;
604 SVGA3dSurfaceImageId host;
605 SVGA3dTransferType transfer;
606
607
608
609
610
611
612
613
614
615
616
617
618}
619#include "vmware_pack_end.h"
620SVGA3dCmdSurfaceDMA;
621
622
623
624
625
626
627
628
629
630
631
632typedef
633#include "vmware_pack_begin.h"
634struct {
635 uint32 suffixSize;
636
637
638
639
640
641
642
643
644
645 uint32 maximumOffset;
646
647
648
649
650
651
652
653
654 SVGA3dSurfaceDMAFlags flags;
655}
656#include "vmware_pack_end.h"
657SVGA3dCmdSurfaceDMASuffix;
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676typedef
677#include "vmware_pack_begin.h"
678struct {
679
680
681
682
683
684
685
686
687
688 uint32 first;
689 uint32 last;
690}
691#include "vmware_pack_end.h"
692SVGA3dArrayRangeHint;
693
694typedef
695#include "vmware_pack_begin.h"
696struct {
697
698
699
700
701
702
703
704
705
706
707
708 uint32 surfaceId;
709 uint32 offset;
710 uint32 stride;
711}
712#include "vmware_pack_end.h"
713SVGA3dArray;
714
715typedef
716#include "vmware_pack_begin.h"
717struct {
718
719
720
721
722
723
724 SVGA3dDeclType type;
725 SVGA3dDeclMethod method;
726 SVGA3dDeclUsage usage;
727 uint32 usageIndex;
728}
729#include "vmware_pack_end.h"
730SVGA3dVertexArrayIdentity;
731
732typedef
733#include "vmware_pack_begin.h"
734struct SVGA3dVertexDecl {
735 SVGA3dVertexArrayIdentity identity;
736 SVGA3dArray array;
737 SVGA3dArrayRangeHint rangeHint;
738}
739#include "vmware_pack_end.h"
740SVGA3dVertexDecl;
741
742typedef
743#include "vmware_pack_begin.h"
744struct SVGA3dPrimitiveRange {
745
746
747
748
749
750
751 SVGA3dPrimitiveType primType;
752 uint32 primitiveCount;
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767 SVGA3dArray indexArray;
768 uint32 indexWidth;
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790 int32 indexBias;
791}
792#include "vmware_pack_end.h"
793SVGA3dPrimitiveRange;
794
795typedef
796#include "vmware_pack_begin.h"
797struct {
798 uint32 cid;
799 uint32 numVertexDecls;
800 uint32 numRanges;
801
802
803
804
805
806
807
808
809
810
811
812
813
814}
815#include "vmware_pack_end.h"
816SVGA3dCmdDrawPrimitives;
817
818typedef
819#include "vmware_pack_begin.h"
820struct {
821 uint32 cid;
822
823 uint32 primitiveCount;
824 uint32 startVertexLocation;
825
826 uint8 primitiveType;
827 uint8 padding[3];
828}
829#include "vmware_pack_end.h"
830SVGA3dCmdDraw;
831
832typedef
833#include "vmware_pack_begin.h"
834struct {
835 uint32 cid;
836
837 uint8 primitiveType;
838
839 uint32 indexBufferSid;
840 uint32 indexBufferOffset;
841
842
843
844 uint8 indexBufferStride;
845
846 int32 baseVertexLocation;
847
848
849 uint32 primitiveCount;
850 uint32 pad0;
851 uint16 pad1;
852}
853#include "vmware_pack_end.h"
854SVGA3dCmdDrawIndexed;
855
856typedef
857#include "vmware_pack_begin.h"
858struct {
859
860
861
862
863
864
865 uint16 streamOffset;
866 uint8 stream;
867 uint8 type;
868 uint8 method;
869 uint8 usage;
870 uint8 usageIndex;
871 uint8 padding;
872
873}
874#include "vmware_pack_end.h"
875SVGA3dVertexElement;
876
877
878
879
880
881
882
883
884
885
886#define SVGA3D_VERTEX_ELEMENT_RESPECT_STREAM (1 << 7)
887
888typedef
889#include "vmware_pack_begin.h"
890struct {
891 uint32 cid;
892
893 uint32 numElements;
894
895
896
897
898
899
900
901}
902#include "vmware_pack_end.h"
903SVGA3dCmdSetVertexDecls;
904
905typedef
906#include "vmware_pack_begin.h"
907struct {
908 uint32 sid;
909 uint32 stride;
910 uint32 offset;
911}
912#include "vmware_pack_end.h"
913SVGA3dVertexStream;
914
915typedef
916#include "vmware_pack_begin.h"
917struct {
918 uint32 cid;
919
920 uint32 numStreams;
921
922
923
924
925
926
927}
928#include "vmware_pack_end.h"
929SVGA3dCmdSetVertexStreams;
930
931typedef
932#include "vmware_pack_begin.h"
933struct {
934 uint32 cid;
935 uint32 numDivisors;
936}
937#include "vmware_pack_end.h"
938SVGA3dCmdSetVertexDivisors;
939
940typedef
941#include "vmware_pack_begin.h"
942struct {
943 uint32 stage;
944 SVGA3dTextureStateName name;
945 union {
946 uint32 value;
947 float floatValue;
948 };
949}
950#include "vmware_pack_end.h"
951SVGA3dTextureState;
952
953typedef
954#include "vmware_pack_begin.h"
955struct {
956 uint32 cid;
957
958}
959#include "vmware_pack_end.h"
960SVGA3dCmdSetTextureState;
961
962typedef
963#include "vmware_pack_begin.h"
964struct {
965 uint32 cid;
966 SVGA3dTransformType type;
967 float matrix[16];
968}
969#include "vmware_pack_end.h"
970SVGA3dCmdSetTransform;
971
972typedef
973#include "vmware_pack_begin.h"
974struct {
975 float min;
976 float max;
977}
978#include "vmware_pack_end.h"
979SVGA3dZRange;
980
981typedef
982#include "vmware_pack_begin.h"
983struct {
984 uint32 cid;
985 SVGA3dZRange zRange;
986}
987#include "vmware_pack_end.h"
988SVGA3dCmdSetZRange;
989
990typedef
991#include "vmware_pack_begin.h"
992struct {
993 float diffuse[4];
994 float ambient[4];
995 float specular[4];
996 float emissive[4];
997 float shininess;
998}
999#include "vmware_pack_end.h"
1000SVGA3dMaterial;
1001
1002typedef
1003#include "vmware_pack_begin.h"
1004struct {
1005 uint32 cid;
1006 SVGA3dFace face;
1007 SVGA3dMaterial material;
1008}
1009#include "vmware_pack_end.h"
1010SVGA3dCmdSetMaterial;
1011
1012typedef
1013#include "vmware_pack_begin.h"
1014struct {
1015 uint32 cid;
1016 uint32 index;
1017 SVGA3dLightData data;
1018}
1019#include "vmware_pack_end.h"
1020SVGA3dCmdSetLightData;
1021
1022typedef
1023#include "vmware_pack_begin.h"
1024struct {
1025 uint32 cid;
1026 uint32 index;
1027 uint32 enabled;
1028}
1029#include "vmware_pack_end.h"
1030SVGA3dCmdSetLightEnabled;
1031
1032typedef
1033#include "vmware_pack_begin.h"
1034struct {
1035 uint32 cid;
1036 SVGA3dRect rect;
1037}
1038#include "vmware_pack_end.h"
1039SVGA3dCmdSetViewport;
1040
1041typedef
1042#include "vmware_pack_begin.h"
1043struct {
1044 uint32 cid;
1045 SVGA3dRect rect;
1046}
1047#include "vmware_pack_end.h"
1048SVGA3dCmdSetScissorRect;
1049
1050typedef
1051#include "vmware_pack_begin.h"
1052struct {
1053 uint32 cid;
1054 uint32 index;
1055 float plane[4];
1056}
1057#include "vmware_pack_end.h"
1058SVGA3dCmdSetClipPlane;
1059
1060typedef
1061#include "vmware_pack_begin.h"
1062struct {
1063 uint32 cid;
1064 uint32 shid;
1065 SVGA3dShaderType type;
1066
1067}
1068#include "vmware_pack_end.h"
1069SVGA3dCmdDefineShader;
1070
1071typedef
1072#include "vmware_pack_begin.h"
1073struct {
1074 uint32 cid;
1075 uint32 shid;
1076 SVGA3dShaderType type;
1077}
1078#include "vmware_pack_end.h"
1079SVGA3dCmdDestroyShader;
1080
1081typedef
1082#include "vmware_pack_begin.h"
1083struct {
1084 uint32 cid;
1085 uint32 reg;
1086 SVGA3dShaderType type;
1087 SVGA3dShaderConstType ctype;
1088 uint32 values[4];
1089
1090
1091
1092
1093}
1094#include "vmware_pack_end.h"
1095SVGA3dCmdSetShaderConst;
1096
1097typedef
1098#include "vmware_pack_begin.h"
1099struct {
1100 uint32 cid;
1101 SVGA3dShaderType type;
1102 uint32 shid;
1103}
1104#include "vmware_pack_end.h"
1105SVGA3dCmdSetShader;
1106
1107typedef
1108#include "vmware_pack_begin.h"
1109struct {
1110 uint32 cid;
1111 SVGA3dQueryType type;
1112}
1113#include "vmware_pack_end.h"
1114SVGA3dCmdBeginQuery;
1115
1116typedef
1117#include "vmware_pack_begin.h"
1118struct {
1119 uint32 cid;
1120 SVGA3dQueryType type;
1121 SVGAGuestPtr guestResult;
1122}
1123#include "vmware_pack_end.h"
1124SVGA3dCmdEndQuery;
1125
1126
1127
1128
1129
1130
1131
1132
1133
1134
1135
1136
1137
1138
1139
1140
1141
1142
1143
1144
1145
1146
1147
1148typedef
1149#include "vmware_pack_begin.h"
1150struct {
1151 uint32 cid;
1152 SVGA3dQueryType type;
1153 SVGAGuestPtr guestResult;
1154}
1155#include "vmware_pack_end.h"
1156SVGA3dCmdWaitForQuery;
1157
1158typedef
1159#include "vmware_pack_begin.h"
1160struct {
1161 uint32 totalSize;
1162 SVGA3dQueryState state;
1163 union {
1164 uint32 result32;
1165 uint32 queryCookie;
1166
1167 };
1168}
1169#include "vmware_pack_end.h"
1170SVGA3dQueryResult;
1171
1172
1173
1174
1175
1176
1177
1178
1179
1180
1181
1182
1183
1184
1185
1186
1187
1188
1189
1190
1191
1192
1193
1194
1195
1196
1197typedef
1198#include "vmware_pack_begin.h"
1199struct {
1200 SVGA3dSurfaceImageId srcImage;
1201 SVGASignedRect srcRect;
1202 uint32 destScreenId;
1203 SVGASignedRect destRect;
1204
1205}
1206#include "vmware_pack_end.h"
1207SVGA3dCmdBlitSurfaceToScreen;
1208
1209typedef
1210#include "vmware_pack_begin.h"
1211struct {
1212 uint32 sid;
1213 SVGA3dTextureFilter filter;
1214}
1215#include "vmware_pack_end.h"
1216SVGA3dCmdGenerateMipmaps;
1217
1218typedef
1219#include "vmware_pack_begin.h"
1220struct {
1221 uint32 sid;
1222}
1223#include "vmware_pack_end.h"
1224SVGA3dCmdActivateSurface;
1225
1226typedef
1227#include "vmware_pack_begin.h"
1228struct {
1229 uint32 sid;
1230}
1231#include "vmware_pack_end.h"
1232SVGA3dCmdDeactivateSurface;
1233
1234
1235
1236
1237
1238
1239
1240
1241
1242
1243
1244
1245
1246
1247
1248
1249typedef
1250#include "vmware_pack_begin.h"
1251struct SVGA3dCmdScreenDMA {
1252 uint32 screenId;
1253 SVGAGuestImage refBuffer;
1254 SVGAGuestImage destBuffer;
1255 SVGAGuestImage changeMap;
1256}
1257#include "vmware_pack_end.h"
1258SVGA3dCmdScreenDMA;
1259
1260
1261
1262
1263
1264#define SVGA3D_LOTRANSBLT_HONORALPHA (0x01)
1265#define SVGA3D_LOSTRETCHBLT_MIRRORX (0x01)
1266#define SVGA3D_LOSTRETCHBLT_MIRRORY (0x02)
1267#define SVGA3D_LOALPHABLEND_SRCHASALPHA (0x01)
1268
1269typedef
1270#include "vmware_pack_begin.h"
1271struct SVGA3dCmdLogicOpsBitBlt {
1272
1273
1274
1275
1276
1277 SVGA3dSurfaceImageId src;
1278 SVGA3dSurfaceImageId dst;
1279 SVGA3dLogicOp logicOp;
1280 SVGA3dLogicOpRop3 logicOpRop3;
1281
1282}
1283#include "vmware_pack_end.h"
1284SVGA3dCmdLogicOpsBitBlt;
1285
1286
1287typedef
1288#include "vmware_pack_begin.h"
1289struct SVGA3dCmdLogicOpsTransBlt {
1290
1291
1292
1293
1294
1295 SVGA3dSurfaceImageId src;
1296 SVGA3dSurfaceImageId dst;
1297 uint32 color;
1298 uint32 flags;
1299 SVGA3dBox srcBox;
1300 SVGA3dSignedBox dstBox;
1301 SVGA3dBox clipBox;
1302}
1303#include "vmware_pack_end.h"
1304SVGA3dCmdLogicOpsTransBlt;
1305
1306
1307typedef
1308#include "vmware_pack_begin.h"
1309struct SVGA3dCmdLogicOpsStretchBlt {
1310
1311
1312
1313
1314
1315 SVGA3dSurfaceImageId src;
1316 SVGA3dSurfaceImageId dst;
1317 uint16 mode;
1318 uint16 flags;
1319 SVGA3dBox srcBox;
1320 SVGA3dSignedBox dstBox;
1321 SVGA3dBox clipBox;
1322}
1323#include "vmware_pack_end.h"
1324SVGA3dCmdLogicOpsStretchBlt;
1325
1326
1327typedef
1328#include "vmware_pack_begin.h"
1329struct SVGA3dCmdLogicOpsColorFill {
1330
1331
1332
1333
1334
1335 SVGA3dSurfaceImageId dst;
1336 uint32 color;
1337 SVGA3dLogicOp logicOp;
1338 SVGA3dLogicOpRop3 logicOpRop3;
1339
1340}
1341#include "vmware_pack_end.h"
1342SVGA3dCmdLogicOpsColorFill;
1343
1344
1345typedef
1346#include "vmware_pack_begin.h"
1347struct SVGA3dCmdLogicOpsAlphaBlend {
1348
1349
1350
1351
1352
1353 SVGA3dSurfaceImageId src;
1354 SVGA3dSurfaceImageId dst;
1355 uint32 alphaVal;
1356 uint32 flags;
1357 SVGA3dBox srcBox;
1358 SVGA3dSignedBox dstBox;
1359 SVGA3dBox clipBox;
1360}
1361#include "vmware_pack_end.h"
1362SVGA3dCmdLogicOpsAlphaBlend;
1363
1364#define SVGA3D_CLEARTYPE_INVALID_GAMMA_INDEX 0xFFFFFFFF
1365
1366#define SVGA3D_CLEARTYPE_GAMMA_WIDTH 512
1367#define SVGA3D_CLEARTYPE_GAMMA_HEIGHT 16
1368
1369typedef
1370#include "vmware_pack_begin.h"
1371struct SVGA3dCmdLogicOpsClearTypeBlend {
1372
1373
1374
1375
1376
1377 SVGA3dSurfaceImageId tmp;
1378 SVGA3dSurfaceImageId dst;
1379 SVGA3dSurfaceImageId gammaSurf;
1380 SVGA3dSurfaceImageId alphaSurf;
1381 uint32 gamma;
1382 uint32 color;
1383 uint32 color2;
1384 int32 alphaOffsetX;
1385 int32 alphaOffsetY;
1386
1387}
1388#include "vmware_pack_end.h"
1389SVGA3dCmdLogicOpsClearTypeBlend;
1390
1391
1392
1393
1394
1395
1396typedef
1397#include "vmware_pack_begin.h"
1398struct {
1399 SVGAMobFormat ptDepth;
1400 uint32 sizeInBytes;
1401 PPN64 base;
1402}
1403#include "vmware_pack_end.h"
1404SVGAOTableMobEntry;
1405#define SVGA3D_OTABLE_MOB_ENTRY_SIZE (sizeof(SVGAOTableMobEntry))
1406
1407typedef
1408#include "vmware_pack_begin.h"
1409struct {
1410 SVGA3dSurfaceFormat format;
1411 SVGA3dSurface1Flags surface1Flags;
1412 uint32 numMipLevels;
1413 uint32 multisampleCount;
1414 SVGA3dTextureFilter autogenFilter;
1415 SVGA3dSize size;
1416 SVGAMobId mobid;
1417 uint32 arraySize;
1418 uint32 mobPitch;
1419 SVGA3dSurface2Flags surface2Flags;
1420 uint8 multisamplePattern;
1421 uint8 qualityLevel;
1422 uint16 bufferByteStride;
1423 float minLOD;
1424 uint32 pad0[2];
1425}
1426#include "vmware_pack_end.h"
1427SVGAOTableSurfaceEntry;
1428#define SVGA3D_OTABLE_SURFACE_ENTRY_SIZE (sizeof(SVGAOTableSurfaceEntry))
1429
1430typedef
1431#include "vmware_pack_begin.h"
1432struct {
1433 uint32 cid;
1434 SVGAMobId mobid;
1435}
1436#include "vmware_pack_end.h"
1437SVGAOTableContextEntry;
1438#define SVGA3D_OTABLE_CONTEXT_ENTRY_SIZE (sizeof(SVGAOTableContextEntry))
1439
1440typedef
1441#include "vmware_pack_begin.h"
1442struct {
1443 SVGA3dShaderType type;
1444 uint32 sizeInBytes;
1445 uint32 offsetInBytes;
1446 SVGAMobId mobid;
1447}
1448#include "vmware_pack_end.h"
1449SVGAOTableShaderEntry;
1450#define SVGA3D_OTABLE_SHADER_ENTRY_SIZE (sizeof(SVGAOTableShaderEntry))
1451
1452#define SVGA_STFLAG_PRIMARY (1 << 0)
1453#define SVGA_STFLAG_RESERVED (1 << 1)
1454typedef uint32 SVGAScreenTargetFlags;
1455
1456typedef
1457#include "vmware_pack_begin.h"
1458struct {
1459 SVGA3dSurfaceImageId image;
1460 uint32 width;
1461 uint32 height;
1462 int32 xRoot;
1463 int32 yRoot;
1464 SVGAScreenTargetFlags flags;
1465 uint32 dpi;
1466 uint32 pad[7];
1467}
1468#include "vmware_pack_end.h"
1469SVGAOTableScreenTargetEntry;
1470#define SVGA3D_OTABLE_SCREEN_TARGET_ENTRY_SIZE \
1471 (sizeof(SVGAOTableScreenTargetEntry))
1472
1473typedef
1474#include "vmware_pack_begin.h"
1475struct {
1476 float value[4];
1477}
1478#include "vmware_pack_end.h"
1479SVGA3dShaderConstFloat;
1480
1481typedef
1482#include "vmware_pack_begin.h"
1483struct {
1484 int32 value[4];
1485}
1486#include "vmware_pack_end.h"
1487SVGA3dShaderConstInt;
1488
1489typedef
1490#include "vmware_pack_begin.h"
1491struct {
1492 uint32 value;
1493}
1494#include "vmware_pack_end.h"
1495SVGA3dShaderConstBool;
1496
1497typedef
1498#include "vmware_pack_begin.h"
1499struct {
1500 uint16 streamOffset;
1501 uint8 stream;
1502 uint8 type;
1503 uint8 methodUsage;
1504 uint8 usageIndex;
1505}
1506#include "vmware_pack_end.h"
1507SVGAGBVertexElement;
1508
1509typedef
1510#include "vmware_pack_begin.h"
1511struct {
1512 uint32 sid;
1513 uint16 stride;
1514 uint32 offset;
1515}
1516#include "vmware_pack_end.h"
1517SVGAGBVertexStream;
1518typedef
1519#include "vmware_pack_begin.h"
1520struct {
1521 SVGA3dRect viewport;
1522 SVGA3dRect scissorRect;
1523 SVGA3dZRange zRange;
1524
1525 SVGA3dSurfaceImageId renderTargets[SVGA3D_RT_MAX];
1526 SVGAGBVertexElement decl1[4];
1527
1528 uint32 renderStates[SVGA3D_RS_MAX];
1529 SVGAGBVertexElement decl2[18];
1530 uint32 pad0[2];
1531
1532 struct {
1533 SVGA3dFace face;
1534 SVGA3dMaterial material;
1535 } material;
1536
1537 float clipPlanes[SVGA3D_NUM_CLIPPLANES][4];
1538 float matrices[SVGA3D_TRANSFORM_MAX][16];
1539
1540 SVGA3dBool lightEnabled[SVGA3D_NUM_LIGHTS];
1541 SVGA3dLightData lightData[SVGA3D_NUM_LIGHTS];
1542
1543
1544
1545
1546 uint32 shaders[SVGA3D_NUM_SHADERTYPE_PREDX];
1547 SVGAGBVertexElement decl3[10];
1548 uint32 pad1[3];
1549
1550 uint32 occQueryActive;
1551 uint32 occQueryValue;
1552
1553
1554
1555
1556 SVGA3dShaderConstInt pShaderIValues[SVGA3D_CONSTINTREG_MAX];
1557 SVGA3dShaderConstInt vShaderIValues[SVGA3D_CONSTINTREG_MAX];
1558 uint16 pShaderBValues;
1559 uint16 vShaderBValues;
1560
1561
1562 SVGAGBVertexStream streams[SVGA3D_MAX_VERTEX_ARRAYS];
1563 SVGA3dVertexDivisor divisors[SVGA3D_MAX_VERTEX_ARRAYS];
1564 uint32 numVertexDecls;
1565 uint32 numVertexStreams;
1566 uint32 numVertexDivisors;
1567 uint32 pad2[30];
1568
1569
1570
1571
1572
1573
1574
1575
1576 uint32 tsColorKey[SVGA3D_NUM_TEXTURE_UNITS];
1577 uint32 textureStages[SVGA3D_NUM_TEXTURE_UNITS][SVGA3D_TS_CONSTANT + 1];
1578 uint32 tsColorKeyEnable[SVGA3D_NUM_TEXTURE_UNITS];
1579
1580
1581
1582
1583 SVGA3dShaderConstFloat pShaderFValues[SVGA3D_CONSTREG_MAX];
1584 SVGA3dShaderConstFloat vShaderFValues[SVGA3D_CONSTREG_MAX];
1585}
1586#include "vmware_pack_end.h"
1587SVGAGBContextData;
1588#define SVGA3D_CONTEXT_DATA_SIZE (sizeof(SVGAGBContextData))
1589
1590
1591
1592
1593
1594
1595
1596
1597typedef
1598#include "vmware_pack_begin.h"
1599struct {
1600 SVGAOTableType type;
1601 PPN32 baseAddress;
1602 uint32 sizeInBytes;
1603 uint32 validSizeInBytes;
1604 SVGAMobFormat ptDepth;
1605}
1606#include "vmware_pack_end.h"
1607SVGA3dCmdSetOTableBase;
1608
1609typedef
1610#include "vmware_pack_begin.h"
1611struct {
1612 SVGAOTableType type;
1613 PPN64 baseAddress;
1614 uint32 sizeInBytes;
1615 uint32 validSizeInBytes;
1616 SVGAMobFormat ptDepth;
1617}
1618#include "vmware_pack_end.h"
1619SVGA3dCmdSetOTableBase64;
1620
1621
1622
1623
1624
1625
1626
1627
1628typedef
1629#include "vmware_pack_begin.h"
1630struct {
1631 SVGAOTableType type;
1632 PPN64 baseAddress;
1633 uint32 sizeInBytes;
1634 uint32 validSizeInBytes;
1635 SVGAMobFormat ptDepth;
1636}
1637#include "vmware_pack_end.h"
1638SVGA3dCmdGrowOTable;
1639
1640typedef
1641#include "vmware_pack_begin.h"
1642struct {
1643 SVGAOTableType type;
1644}
1645#include "vmware_pack_end.h"
1646SVGA3dCmdReadbackOTable;
1647
1648
1649
1650
1651
1652typedef
1653#include "vmware_pack_begin.h"
1654struct SVGA3dCmdDefineGBMob {
1655 SVGAMobId mobid;
1656 SVGAMobFormat ptDepth;
1657 PPN32 base;
1658 uint32 sizeInBytes;
1659}
1660#include "vmware_pack_end.h"
1661SVGA3dCmdDefineGBMob;
1662
1663
1664
1665
1666
1667
1668typedef
1669#include "vmware_pack_begin.h"
1670struct SVGA3dCmdDestroyGBMob {
1671 SVGAMobId mobid;
1672}
1673#include "vmware_pack_end.h"
1674SVGA3dCmdDestroyGBMob;
1675
1676
1677
1678
1679
1680typedef
1681#include "vmware_pack_begin.h"
1682struct SVGA3dCmdDefineGBMob64 {
1683 SVGAMobId mobid;
1684 SVGAMobFormat ptDepth;
1685 PPN64 base;
1686 uint32 sizeInBytes;
1687}
1688#include "vmware_pack_end.h"
1689SVGA3dCmdDefineGBMob64;
1690
1691
1692
1693
1694
1695typedef
1696#include "vmware_pack_begin.h"
1697struct SVGA3dCmdRedefineGBMob64 {
1698 SVGAMobId mobid;
1699 SVGAMobFormat ptDepth;
1700 PPN64 base;
1701 uint32 sizeInBytes;
1702}
1703#include "vmware_pack_end.h"
1704SVGA3dCmdRedefineGBMob64;
1705
1706
1707
1708
1709
1710typedef
1711#include "vmware_pack_begin.h"
1712struct SVGA3dCmdUpdateGBMobMapping {
1713 SVGAMobId mobid;
1714}
1715#include "vmware_pack_end.h"
1716SVGA3dCmdUpdateGBMobMapping;
1717
1718
1719
1720
1721
1722typedef
1723#include "vmware_pack_begin.h"
1724struct SVGA3dCmdDefineGBSurface {
1725 uint32 sid;
1726 SVGA3dSurface1Flags surfaceFlags;
1727 SVGA3dSurfaceFormat format;
1728 uint32 numMipLevels;
1729 uint32 multisampleCount;
1730 SVGA3dTextureFilter autogenFilter;
1731 SVGA3dSize size;
1732}
1733#include "vmware_pack_end.h"
1734SVGA3dCmdDefineGBSurface;
1735
1736
1737
1738
1739typedef
1740#include "vmware_pack_begin.h"
1741struct SVGA3dCmdDefineGBSurface_v2 {
1742 uint32 sid;
1743 SVGA3dSurface1Flags surfaceFlags;
1744 SVGA3dSurfaceFormat format;
1745 uint32 numMipLevels;
1746 uint32 multisampleCount;
1747 SVGA3dTextureFilter autogenFilter;
1748 SVGA3dSize size;
1749 uint32 arraySize;
1750 uint32 pad;
1751}
1752#include "vmware_pack_end.h"
1753SVGA3dCmdDefineGBSurface_v2;
1754
1755
1756
1757
1758typedef
1759#include "vmware_pack_begin.h"
1760struct SVGA3dCmdDefineGBSurface_v3 {
1761 uint32 sid;
1762 SVGA3dSurfaceAllFlags surfaceFlags;
1763 SVGA3dSurfaceFormat format;
1764 uint32 numMipLevels;
1765 uint32 multisampleCount;
1766 SVGA3dMSPattern multisamplePattern;
1767 SVGA3dMSQualityLevel qualityLevel;
1768 SVGA3dTextureFilter autogenFilter;
1769 SVGA3dSize size;
1770 uint32 arraySize;
1771}
1772#include "vmware_pack_end.h"
1773SVGA3dCmdDefineGBSurface_v3;
1774
1775
1776
1777
1778typedef
1779#include "vmware_pack_begin.h"
1780struct SVGA3dCmdDefineGBSurface_v4 {
1781 uint32 sid;
1782 SVGA3dSurfaceAllFlags surfaceFlags;
1783 SVGA3dSurfaceFormat format;
1784 uint32 numMipLevels;
1785 uint32 multisampleCount;
1786 SVGA3dMSPattern multisamplePattern;
1787 SVGA3dMSQualityLevel qualityLevel;
1788 SVGA3dTextureFilter autogenFilter;
1789 SVGA3dSize size;
1790 uint32 arraySize;
1791 uint32 bufferByteStride;
1792}
1793#include "vmware_pack_end.h"
1794SVGA3dCmdDefineGBSurface_v4;
1795
1796
1797
1798
1799
1800typedef
1801#include "vmware_pack_begin.h"
1802struct SVGA3dCmdDestroyGBSurface {
1803 uint32 sid;
1804}
1805#include "vmware_pack_end.h"
1806SVGA3dCmdDestroyGBSurface;
1807
1808
1809
1810
1811
1812typedef
1813#include "vmware_pack_begin.h"
1814struct SVGA3dCmdBindGBSurface {
1815 uint32 sid;
1816 SVGAMobId mobid;
1817}
1818#include "vmware_pack_end.h"
1819SVGA3dCmdBindGBSurface;
1820
1821typedef
1822#include "vmware_pack_begin.h"
1823struct SVGA3dCmdBindGBSurfaceWithPitch {
1824 uint32 sid;
1825 SVGAMobId mobid;
1826 uint32 baseLevelPitch;
1827}
1828#include "vmware_pack_end.h"
1829SVGA3dCmdBindGBSurfaceWithPitch;
1830
1831
1832
1833
1834
1835
1836
1837
1838#define SVGA3D_COND_BIND_GB_SURFACE_FLAG_READBACK (1 << 0)
1839#define SVGA3D_COND_BIND_GB_SURFACE_FLAG_UPDATE (1 << 1)
1840
1841typedef
1842#include "vmware_pack_begin.h"
1843struct SVGA3dCmdCondBindGBSurface {
1844 uint32 sid;
1845 SVGAMobId testMobid;
1846 SVGAMobId mobid;
1847 uint32 flags;
1848}
1849#include "vmware_pack_end.h"
1850SVGA3dCmdCondBindGBSurface;
1851
1852
1853
1854
1855
1856
1857typedef
1858#include "vmware_pack_begin.h"
1859struct SVGA3dCmdUpdateGBImage {
1860 SVGA3dSurfaceImageId image;
1861 SVGA3dBox box;
1862}
1863#include "vmware_pack_end.h"
1864SVGA3dCmdUpdateGBImage;
1865
1866
1867
1868
1869
1870
1871typedef
1872#include "vmware_pack_begin.h"
1873struct SVGA3dCmdUpdateGBSurface {
1874 uint32 sid;
1875}
1876#include "vmware_pack_end.h"
1877SVGA3dCmdUpdateGBSurface;
1878
1879
1880
1881
1882
1883
1884typedef
1885#include "vmware_pack_begin.h"
1886struct SVGA3dCmdReadbackGBImage {
1887 SVGA3dSurfaceImageId image;
1888}
1889#include "vmware_pack_end.h"
1890SVGA3dCmdReadbackGBImage;
1891
1892
1893
1894
1895
1896
1897typedef
1898#include "vmware_pack_begin.h"
1899struct SVGA3dCmdReadbackGBSurface {
1900 uint32 sid;
1901}
1902#include "vmware_pack_end.h"
1903SVGA3dCmdReadbackGBSurface;
1904
1905
1906
1907
1908
1909
1910
1911
1912typedef
1913#include "vmware_pack_begin.h"
1914struct SVGA3dCmdReadbackGBImagePartial {
1915 SVGA3dSurfaceImageId image;
1916 SVGA3dBox box;
1917 uint32 invertBox;
1918}
1919#include "vmware_pack_end.h"
1920SVGA3dCmdReadbackGBImagePartial;
1921
1922
1923
1924
1925
1926
1927
1928typedef
1929#include "vmware_pack_begin.h"
1930struct SVGA3dCmdInvalidateGBImage {
1931 SVGA3dSurfaceImageId image;
1932}
1933#include "vmware_pack_end.h"
1934SVGA3dCmdInvalidateGBImage;
1935
1936
1937
1938
1939
1940
1941typedef
1942#include "vmware_pack_begin.h"
1943struct SVGA3dCmdInvalidateGBSurface {
1944 uint32 sid;
1945}
1946#include "vmware_pack_end.h"
1947SVGA3dCmdInvalidateGBSurface;
1948
1949
1950
1951
1952
1953
1954
1955
1956typedef
1957#include "vmware_pack_begin.h"
1958struct SVGA3dCmdInvalidateGBImagePartial {
1959 SVGA3dSurfaceImageId image;
1960 SVGA3dBox box;
1961 uint32 invertBox;
1962}
1963#include "vmware_pack_end.h"
1964SVGA3dCmdInvalidateGBImagePartial;
1965
1966
1967
1968
1969
1970
1971typedef
1972#include "vmware_pack_begin.h"
1973struct SVGA3dCmdDefineGBContext {
1974 uint32 cid;
1975}
1976#include "vmware_pack_end.h"
1977SVGA3dCmdDefineGBContext;
1978
1979
1980
1981
1982
1983typedef
1984#include "vmware_pack_begin.h"
1985struct SVGA3dCmdDestroyGBContext {
1986 uint32 cid;
1987}
1988#include "vmware_pack_end.h"
1989SVGA3dCmdDestroyGBContext;
1990
1991
1992
1993
1994
1995
1996
1997
1998
1999
2000
2001
2002
2003typedef
2004#include "vmware_pack_begin.h"
2005struct SVGA3dCmdBindGBContext {
2006 uint32 cid;
2007 SVGAMobId mobid;
2008 uint32 validContents;
2009}
2010#include "vmware_pack_end.h"
2011SVGA3dCmdBindGBContext;
2012
2013
2014
2015
2016
2017
2018typedef
2019#include "vmware_pack_begin.h"
2020struct SVGA3dCmdReadbackGBContext {
2021 uint32 cid;
2022}
2023#include "vmware_pack_end.h"
2024SVGA3dCmdReadbackGBContext;
2025
2026
2027
2028
2029typedef
2030#include "vmware_pack_begin.h"
2031struct SVGA3dCmdInvalidateGBContext {
2032 uint32 cid;
2033}
2034#include "vmware_pack_end.h"
2035SVGA3dCmdInvalidateGBContext;
2036
2037
2038
2039
2040
2041typedef
2042#include "vmware_pack_begin.h"
2043struct SVGA3dCmdDefineGBShader {
2044 uint32 shid;
2045 SVGA3dShaderType type;
2046 uint32 sizeInBytes;
2047}
2048#include "vmware_pack_end.h"
2049SVGA3dCmdDefineGBShader;
2050
2051
2052
2053
2054
2055typedef
2056#include "vmware_pack_begin.h"
2057struct SVGA3dCmdBindGBShader {
2058 uint32 shid;
2059 SVGAMobId mobid;
2060 uint32 offsetInBytes;
2061}
2062#include "vmware_pack_end.h"
2063SVGA3dCmdBindGBShader;
2064
2065
2066
2067
2068
2069typedef
2070#include "vmware_pack_begin.h"
2071struct SVGA3dCmdDestroyGBShader {
2072 uint32 shid;
2073}
2074#include "vmware_pack_end.h"
2075SVGA3dCmdDestroyGBShader;
2076
2077typedef
2078#include "vmware_pack_begin.h"
2079struct {
2080 uint32 cid;
2081 uint32 regStart;
2082 SVGA3dShaderType shaderType;
2083 SVGA3dShaderConstType constType;
2084
2085
2086
2087
2088
2089
2090
2091}
2092#include "vmware_pack_end.h"
2093SVGA3dCmdSetGBShaderConstInline;
2094
2095
2096typedef
2097#include "vmware_pack_begin.h"
2098struct {
2099 uint32 cid;
2100 SVGA3dQueryType type;
2101}
2102#include "vmware_pack_end.h"
2103SVGA3dCmdBeginGBQuery;
2104
2105typedef
2106#include "vmware_pack_begin.h"
2107struct {
2108 uint32 cid;
2109 SVGA3dQueryType type;
2110 SVGAMobId mobid;
2111 uint32 offset;
2112}
2113#include "vmware_pack_end.h"
2114SVGA3dCmdEndGBQuery;
2115
2116
2117
2118
2119
2120
2121
2122
2123
2124
2125typedef
2126#include "vmware_pack_begin.h"
2127struct {
2128 uint32 cid;
2129 SVGA3dQueryType type;
2130 SVGAMobId mobid;
2131 uint32 offset;
2132}
2133#include "vmware_pack_end.h"
2134SVGA3dCmdWaitForGBQuery;
2135
2136
2137typedef
2138#include "vmware_pack_begin.h"
2139struct {
2140 SVGAMobId mobid;
2141 uint32 mustBeZero;
2142 uint32 initialized;
2143}
2144#include "vmware_pack_end.h"
2145SVGA3dCmdEnableGart;
2146
2147typedef
2148#include "vmware_pack_begin.h"
2149struct {
2150 SVGAMobId mobid;
2151 uint32 gartOffset;
2152}
2153#include "vmware_pack_end.h"
2154SVGA3dCmdMapMobIntoGart;
2155
2156
2157typedef
2158#include "vmware_pack_begin.h"
2159struct {
2160 uint32 gartOffset;
2161 uint32 numPages;
2162}
2163#include "vmware_pack_end.h"
2164SVGA3dCmdUnmapGartRange;
2165
2166
2167
2168
2169
2170
2171typedef
2172#include "vmware_pack_begin.h"
2173struct {
2174 uint32 stid;
2175 uint32 width;
2176 uint32 height;
2177 int32 xRoot;
2178 int32 yRoot;
2179 SVGAScreenTargetFlags flags;
2180
2181
2182
2183
2184
2185
2186 uint32 dpi;
2187}
2188#include "vmware_pack_end.h"
2189SVGA3dCmdDefineGBScreenTarget;
2190
2191typedef
2192#include "vmware_pack_begin.h"
2193struct {
2194 uint32 stid;
2195}
2196#include "vmware_pack_end.h"
2197SVGA3dCmdDestroyGBScreenTarget;
2198
2199typedef
2200#include "vmware_pack_begin.h"
2201struct {
2202 uint32 stid;
2203 SVGA3dSurfaceImageId image;
2204}
2205#include "vmware_pack_end.h"
2206SVGA3dCmdBindGBScreenTarget;
2207
2208typedef
2209#include "vmware_pack_begin.h"
2210struct {
2211 uint32 stid;
2212 SVGA3dRect rect;
2213}
2214#include "vmware_pack_end.h"
2215SVGA3dCmdUpdateGBScreenTarget;
2216
2217typedef
2218#include "vmware_pack_begin.h"
2219struct SVGA3dCmdGBScreenDMA {
2220 uint32 screenId;
2221 uint32 dead;
2222 SVGAMobId destMobID;
2223 uint32 destPitch;
2224 SVGAMobId changeMapMobID;
2225}
2226#include "vmware_pack_end.h"
2227SVGA3dCmdGBScreenDMA;
2228
2229typedef
2230#include "vmware_pack_begin.h"
2231struct {
2232 uint32 value;
2233 uint32 mobId;
2234 uint32 mobOffset;
2235}
2236#include "vmware_pack_end.h"
2237SVGA3dCmdGBMobFence;
2238
2239typedef
2240#include "vmware_pack_begin.h"
2241struct {
2242 uint32 stid;
2243 SVGA3dSurfaceImageId dest;
2244
2245 uint32 statusMobId;
2246 uint32 statusMobOffset;
2247
2248
2249 uint32 mustBeInvalidId;
2250 uint32 mustBeZero;
2251}
2252#include "vmware_pack_end.h"
2253SVGA3dCmdScreenCopy;
2254
2255#define SVGA_SCREEN_COPY_STATUS_FAILURE 0x00
2256#define SVGA_SCREEN_COPY_STATUS_SUCCESS 0x01
2257#define SVGA_SCREEN_COPY_STATUS_INVALID 0xFFFFFFFF
2258
2259typedef
2260#include "vmware_pack_begin.h"
2261struct {
2262 uint32 sid;
2263}
2264#include "vmware_pack_end.h"
2265SVGA3dCmdWriteZeroSurface;
2266
2267typedef
2268#include "vmware_pack_begin.h"
2269struct {
2270 uint32 sid;
2271}
2272#include "vmware_pack_end.h"
2273SVGA3dCmdHintZeroSurface;
2274
2275#endif
2276