VirtualBox

source: vbox/trunk/src/VBox/HostServices/SharedOpenGL/crserverlib/server.h@ 65381

最後變更 在這個檔案從65381是 65381,由 vboxsync 提交於 8 年 前

bugref:8282: Additions/linux: submit DRM driver to the Linux kernel: move all graphics device-related header files to a separate sub-directory and add that to the include path where they are needed. The intention is too be able to remove the VBox/ include folder in the DRM driver package.

  • 屬性 svn:eol-style 設為 native
  • 屬性 svn:keywords 設為 Id
檔案大小: 32.7 KB
 
1/* Copyright (c) 2001, Stanford University
2 * All rights reserved.
3 *
4 * See the file LICENSE.txt for information on redistributing this software.
5 */
6
7#ifndef CR_SERVER_H
8#define CR_SERVER_H
9
10#include "cr_protocol.h"
11#include "cr_glstate.h"
12#include "spu_dispatch_table.h"
13
14#include "state/cr_currentpointers.h"
15
16#include "cr_server.h"
17#include <cr_htable.h>
18#include <cr_compositor.h>
19
20#ifdef VBOX_WITH_CRHGSMI
21# include <VBoxVideo.h>
22
23#include <iprt/cdefs.h>
24
25RT_C_DECLS_BEGIN
26
27extern uint8_t* g_pvVRamBase;
28extern uint32_t g_cbVRam;
29extern PPDMLED g_pLed;
30extern HCRHGSMICMDCOMPLETION g_hCrHgsmiCompletion;
31extern PFNCRHGSMICMDCOMPLETION g_pfnCrHgsmiCompletion;
32
33#define VBOXCRHGSMI_PTR(_off, _t) ((_t*)(g_pvVRamBase + (_off)))
34#define VBOXCRHGSMI_PTR_SAFE(_off, _cb, _t) ((_t*)crServerCrHgsmiPtrGet(_off, _cb))
35
36DECLINLINE(void*) crServerCrHgsmiPtrGet(VBOXVIDEOOFFSET offBuffer, uint32_t cbBuffer)
37{
38 return ((offBuffer) + (cbBuffer) <= g_cbVRam ? VBOXCRHGSMI_PTR(offBuffer, void) : NULL);
39}
40
41DECLINLINE(void) crServerCrHgsmiCmdComplete(struct VBOXVDMACMD_CHROMIUM_CMD *pCmd, int cmdProcessingRc)
42{
43 g_pfnCrHgsmiCompletion(g_hCrHgsmiCompletion, pCmd, cmdProcessingRc);
44}
45
46#define VBOXCRHGSMI_CMD_COMPLETE(_pData, _rc) do { \
47 CRVBOXHGSMI_CMDDATA_ASSERT_ISSET(_pData); \
48 CRVBOXHGSMI_CMDDATA_RC(_pData, _rc); \
49 if (CRVBOXHGSMI_CMDDATA_IS_HGSMICMD(_pData)) { \
50 Assert(CRVBOXHGSMI_CMDDATA_IS_HGSMICMD(_pData)); \
51 crServerCrHgsmiCmdComplete((_pData)->pHgsmiCmd, VINF_SUCCESS); \
52 } \
53 } while (0)
54
55#define VBOXCRHGSMI_CMD_CHECK_COMPLETE(_pData, _rc) do { \
56 if (CRVBOXHGSMI_CMDDATA_IS_SET(_pData)) {\
57 VBOXCRHGSMI_CMD_COMPLETE(_pData, _rc); \
58 } \
59 } while (0)
60
61#endif
62
63/*
64 * This is the base number for window and context IDs
65 */
66#define MAGIC_OFFSET 5000
67
68extern CRServer cr_server;
69
70/* Semaphore wait queue node */
71typedef struct _wqnode {
72 RunQueue *q;
73 struct _wqnode *next;
74} wqnode;
75
76typedef struct {
77 GLuint count;
78 GLuint num_waiting;
79 RunQueue **waiting;
80} CRServerBarrier;
81
82typedef struct {
83 GLuint count;
84 wqnode *waiting, *tail;
85} CRServerSemaphore;
86
87typedef struct {
88 GLuint id;
89 GLint projParamStart;
90 GLfloat projMat[16]; /* projection matrix, accumulated via calls to */
91 /* glProgramLocalParameterARB, glProgramParameterNV */
92} CRServerProgram;
93
94void crServerSetVBoxConfiguration();
95void crServerSetVBoxConfigurationHGCM();
96void crServerInitDispatch(void);
97void crServerReturnValue( const void *payload, unsigned int payload_len );
98void crServerWriteback(void);
99int crServerRecv( CRConnection *conn, CRMessage *msg, unsigned int len );
100void crServerSerializeRemoteStreams(void);
101void crServerAddToRunQueue( CRClient *client );
102void crServerDeleteClient( CRClient *client );
103
104
105void crServerApplyBaseProjection( const CRmatrix *baseProj );
106void crServerApplyViewMatrix( const CRmatrix *view );
107void crServerSetOutputBounds( const CRMuralInfo *mural, int extNum );
108void crServerComputeViewportBounds( const CRViewportState *v, CRMuralInfo *mural );
109
110GLboolean crServerInitializeBucketing(CRMuralInfo *mural);
111
112void crComputeOverlapGeom(double *quads, int nquad, CRPoly ***res);
113void crComputeKnockoutGeom(double *quads, int nquad, int my_quad_idx, CRPoly **res);
114
115int crServerGetCurrentEye(void);
116
117GLboolean crServerClientInBeginEnd(const CRClient *client);
118
119GLint crServerDispatchCreateContextEx(const char *dpyName, GLint visualBits, GLint shareCtx, GLint preloadCtxID, int32_t internalID);
120GLint crServerDispatchWindowCreateEx(const char *dpyName, GLint visBits, GLint preloadWinID);
121GLint crServerMuralInit(CRMuralInfo *mural, GLboolean fGuestWindow, GLint visBits, GLint preloadWinID);
122void crServerMuralTerm(CRMuralInfo *mural);
123GLboolean crServerMuralSize(CRMuralInfo *mural, GLint width, GLint height);
124void crServerMuralPosition(CRMuralInfo *mural, GLint x, GLint y);
125void crServerMuralVisibleRegion( CRMuralInfo *mural, GLint cRects, const GLint *pRects );
126void crServerMuralShow( CRMuralInfo *mural, GLint state );
127
128GLint crServerGenerateID(GLint *pCounter);
129
130GLint crServerSPUWindowID(GLint serverWindow);
131
132GLuint crServerTranslateProgramID(GLuint id);
133
134CRMuralInfo * crServerGetDummyMural(GLint visualBits);
135
136void crServerCheckMuralGeometry(CRMuralInfo *mural);
137void crServerCheckAllMuralGeometry(CRMuralInfo *pMI);
138GLboolean crServerSupportRedirMuralFBO(void);
139
140void crVBoxServerMuralFbResizeBegin(HCR_FRAMEBUFFER hFb);
141void crVBoxServerMuralFbResizeEnd(HCR_FRAMEBUFFER hFb);
142
143void crVBoxServerNotifyEvent(int32_t idScreen, uint32_t uEvent, void* pvData, uint32_t cbData);
144
145void crServerRedirMuralFbClear(CRMuralInfo *mural);
146
147void crServerWindowReparent(CRMuralInfo *pMural);
148
149void crServerRedirMuralFBO(CRMuralInfo *mural, bool fEnabled);
150void crServerDeleteMuralFBO(CRMuralInfo *mural);
151void crServerPresentFBO(CRMuralInfo *mural);
152GLboolean crServerIsRedirectedToFBO();
153GLint crServerMuralFBOIdxFromBufferName(CRMuralInfo *mural, GLenum buffer);
154void crServerMuralFBOSwapBuffers(CRMuralInfo *mural);
155
156HCR_FRAMEBUFFER CrPMgrFbGetFirstEnabled();
157HCR_FRAMEBUFFER CrPMgrFbGetNextEnabled(HCR_FRAMEBUFFER hFb);
158HCR_FRAMEBUFFER CrPMgrFbGetFirstInitialized();
159HCR_FRAMEBUFFER CrPMgrFbGetNextInitialized(HCR_FRAMEBUFFER hFb);
160
161int CrFbRegionsClear(HCR_FRAMEBUFFER hFb);
162
163
164#define CR_SERVER_FBO_BB_IDX(_mural) ((_mural)->iBbBuffer)
165#define CR_SERVER_FBO_FB_IDX(_mural) (((_mural)->iBbBuffer + 1) % ((_mural)->cBuffers))
166/* returns a valid index to be used for negative _idx, i.e. for GL_NONE cases */
167//#define CR_SERVER_FBO_ADJUST_IDX(_mural, _idx) ((_idx) >= 0 ? (_idx) : CR_SERVER_FBO_BB_IDX(_mural))
168/* just a helper that uses CR_SERVER_FBO_ADJUST_IDX for getting mural's FBO id for buffer index*/
169//#define CR_SERVER_FBO_FOR_IDX(_mural, _idx) ((_mural)->aidFBOs[CR_SERVER_FBO_ADJUST_IDX((_mural), (_idx))])
170//#define CR_SERVER_FBO_TEX_FOR_IDX(_mural, _idx) ((_mural)->aidColorTexs[CR_SERVER_FBO_ADJUST_IDX((_mural), (_idx))])
171#define CR_SERVER_FBO_FOR_IDX(_mural, _idx) ((_idx) >= 0 ? (_mural)->aidFBOs[(_idx)] : 0)
172#define CR_SERVER_FBO_TEX_FOR_IDX(_mural, _idx) ((_idx) >= 0 ? (_mural)->aidColorTexs[(_idx)] : 0)
173
174int32_t crVBoxServerInternalClientRead(CRClient *pClient, uint8_t *pBuffer, uint32_t *pcbBuffer);
175
176void crServerPerformMakeCurrent( CRMuralInfo *mural, CRContextInfo *ctxInfo );
177
178PCR_BLITTER crServerVBoxBlitterGet();
179PCR_BLITTER crServerVBoxBlitterGetInitialized();
180
181DECLINLINE(void) crServerVBoxBlitterWinInit(CR_BLITTER_WINDOW *win, CRMuralInfo *mural)
182{
183 win->Base.id = mural->spuWindow;
184 win->Base.visualBits = mural->CreateInfo.realVisualBits;
185 win->width = mural->width;
186 win->height = mural->height;
187}
188
189DECLINLINE(void) crServerVBoxBlitterCtxInit(CR_BLITTER_CONTEXT *ctx, CRContextInfo *ctxInfo)
190{
191 ctx->Base.id = ctxInfo->SpuContext;
192 if (ctx->Base.id < 0)
193 ctx->Base.id = cr_server.MainContextInfo.SpuContext;
194 ctx->Base.visualBits = cr_server.curClient->currentCtxInfo->CreateInfo.realVisualBits;
195}
196
197/* display worker thread.
198 * see comments for CR_SERVER_RPW struct definition in cr_server.h */
199DECLINLINE(void) crServerXchgI8(int8_t *pu8Val1, int8_t *pu8Val2)
200{
201 int8_t tmp;
202 tmp = *pu8Val1;
203 *pu8Val1 = *pu8Val2;
204 *pu8Val2 = tmp;
205}
206
207#ifdef DEBUG
208# define CR_GLERR_CHECK(_op) do { \
209 GLenum status; \
210 while ((status = cr_server.head_spu->dispatch_table.GetError()) != GL_NO_ERROR) {/*Assert(0);*/} \
211 _op \
212 while ((status = cr_server.head_spu->dispatch_table.GetError()) != GL_NO_ERROR) {Assert(0);} \
213 } while (0)
214#else
215# define CR_GLERR_CHECK(_op) do { \
216 _op \
217 } while (0)
218#endif
219
220#ifdef DEBUG_misha
221# define CR_SERVER_RPW_DEBUG
222#endif
223/* *
224 * _name : Draw, Submitted, Worker, Gpu
225 */
226
227#ifdef CR_SERVER_RPW_DEBUG
228# define crServerRpwEntryDbgVerify(_pE) crServerRpwEntryDbgDoVerify(_pE)
229#else
230# define crServerRpwEntryDbgVerify(_pE) do {} while (0)
231#endif
232
233
234#define CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _name) ((_pEntry)->iTex##_name > 0)
235
236#define CR_SERVER_RPW_ENTRY_TEX_INVALIDATE(_pEntry, _name) do { \
237 crServerRpwEntryDbgVerify(_pEntry); \
238 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _name)); \
239 (_pEntry)->iTex##_name = -(_pEntry)->iTex##_name; \
240 crServerRpwEntryDbgVerify(_pEntry); \
241 } while (0)
242
243#define CR_SERVER_RPW_ENTRY_TEX_PROMOTE(_pEntry, _fromName, _toName) do { \
244 crServerRpwEntryDbgVerify(_pEntry); \
245 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
246 Assert(!CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
247 crServerXchgI8(&(_pEntry)->iTex##_fromName, &(_pEntry)->iTex##_toName); \
248 crServerRpwEntryDbgVerify(_pEntry); \
249 } while (0)
250
251#define CR_SERVER_RPW_ENTRY_TEX_XCHG_VALID(_pEntry, _fromName, _toName) do { \
252 crServerRpwEntryDbgVerify(_pEntry); \
253 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
254 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
255 crServerXchgI8(&(_pEntry)->iTex##_fromName, &(_pEntry)->iTex##_toName); \
256 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
257 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
258 crServerRpwEntryDbgVerify(_pEntry); \
259 } while (0)
260
261
262#define CR_SERVER_RPW_ENTRY_TEX_PROMOTE_KEEPVALID(_pEntry, _fromName, _toName) do { \
263 crServerRpwEntryDbgVerify(_pEntry); \
264 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
265 Assert(!CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
266 crServerXchgI8(&(_pEntry)->iTex##_fromName, &(_pEntry)->iTex##_toName); \
267 (_pEntry)->iTex##_fromName = -(_pEntry)->iTex##_fromName; \
268 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
269 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
270 crServerRpwEntryDbgVerify(_pEntry); \
271 } while (0)
272
273#define CR_SERVER_RPW_ENTRY_TEX(_pEntry, _name) ((_pEntry)->aidWorkerTexs[(_pEntry)->iTex##_name - 1])
274
275#define CR_SERVER_RPW_ENTRY_PBO_NEXT_ID(_i) (((_i) + 1) % 2)
276#define CR_SERVER_RPW_ENTRY_PBO_IS_ACTIVE(_pEntry) ((_pEntry)->iCurPBO >= 0)
277#define CR_SERVER_RPW_ENTRY_PBO_CUR(_pEntry) ((_pEntry)->aidPBOs[(_pEntry)->iCurPBO])
278#define CR_SERVER_RPW_ENTRY_PBO_COMPLETED(_pEntry) ((_pEntry)->aidPBOs[CR_SERVER_RPW_ENTRY_PBO_NEXT_ID((_pEntry)->iCurPBO)])
279#define CR_SERVER_RPW_ENTRY_PBO_FLIP(_pEntry) do { \
280 (_pEntry)->iCurPBO = CR_SERVER_RPW_ENTRY_PBO_NEXT_ID((_pEntry)->iCurPBO); \
281 } while (0)
282
283#ifdef CR_SERVER_RPW_DEBUG
284DECLINLINE(void) crServerRpwEntryDbgDoVerify(CR_SERVER_RPW_ENTRY *pEntry)
285{
286 int tstMask = 0;
287 int8_t iVal;
288 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(pEntry, Draw));
289
290#define CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(_v) do { \
291 iVal = RT_ABS(_v); \
292 Assert(iVal > 0); \
293 Assert(iVal < 5); \
294 Assert(!(tstMask & (1 << iVal))); \
295 tstMask |= (1 << iVal); \
296 } while (0)
297
298 CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(pEntry->iTexDraw);
299 CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(pEntry->iTexSubmitted);
300 CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(pEntry->iTexWorker);
301 CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(pEntry->iTexGpu);
302 Assert(tstMask == 0x1E);
303}
304#endif
305
306DECLINLINE(bool) crServerRpwIsInitialized(const CR_SERVER_RPW *pWorker)
307{
308 return !!pWorker->ctxId;
309}
310int crServerRpwInit(CR_SERVER_RPW *pWorker);
311int crServerRpwTerm(CR_SERVER_RPW *pWorker);
312DECLINLINE(bool) crServerRpwEntryIsInitialized(const CR_SERVER_RPW_ENTRY *pEntry)
313{
314 return !!pEntry->pfnData;
315}
316int crServerRpwEntryInit(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry, uint32_t width, uint32_t height, PFNCR_SERVER_RPW_DATA pfnData);
317int crServerRpwEntryCleanup(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry);
318int crServerRpwEntryResize(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry, uint32_t width, uint32_t height);
319int crServerRpwEntrySubmit(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry);
320int crServerRpwEntryWaitComplete(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry);
321int crServerRpwEntryCancel(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry);
322DECLINLINE(void) crServerRpwEntryDrawSettingsToTex(const CR_SERVER_RPW_ENTRY *pEntry, VBOXVR_TEXTURE *pTex)
323{
324 pTex->width = pEntry->Size.cx;
325 pTex->height = pEntry->Size.cy;
326 pTex->target = GL_TEXTURE_2D;
327 Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(pEntry, Draw));
328 pTex->hwid = CR_SERVER_RPW_ENTRY_TEX(pEntry, Draw);
329}
330/**/
331
332typedef struct CR_SERVER_CTX_SWITCH
333{
334 GLuint idDrawFBO, idReadFBO;
335 CRContext *pNewCtx;
336 CRContext *pOldCtx;
337} CR_SERVER_CTX_SWITCH;
338
339DECLINLINE(void) crServerCtxSwitchPrepare(CR_SERVER_CTX_SWITCH *pData, CRContext *pNewCtx)
340{
341 CRMuralInfo *pCurrentMural = cr_server.currentMural;
342 CRContextInfo *pCurCtxInfo = cr_server.currentCtxInfo;
343 GLuint idDrawFBO, idReadFBO;
344 CRContext *pCurCtx = pCurCtxInfo ? pCurCtxInfo->pContext : NULL;
345
346 CRASSERT(pCurCtx == crStateGetCurrent());
347
348 if (pCurrentMural)
349 {
350 idDrawFBO = CR_SERVER_FBO_FOR_IDX(pCurrentMural, pCurrentMural->iCurDrawBuffer);
351 idReadFBO = CR_SERVER_FBO_FOR_IDX(pCurrentMural, pCurrentMural->iCurReadBuffer);
352 }
353 else
354 {
355 idDrawFBO = 0;
356 idReadFBO = 0;
357 }
358
359 crStateSwitchPrepare(pNewCtx, pCurCtx, idDrawFBO, idReadFBO);
360
361 pData->idDrawFBO = idDrawFBO;
362 pData->idReadFBO = idReadFBO;
363 pData->pNewCtx = pNewCtx;
364 pData->pOldCtx = pCurCtx;
365}
366
367DECLINLINE(void) crServerCtxSwitchPostprocess(CR_SERVER_CTX_SWITCH *pData)
368{
369 crStateSwitchPostprocess(pData->pOldCtx, pData->pNewCtx, pData->idDrawFBO, pData->idReadFBO);
370}
371
372void crServerInitTmpCtxDispatch();
373
374typedef struct CR_FBMAP
375{
376 uint8_t Map[(CR_MAX_GUEST_MONITORS+7)/8];
377} CR_FBMAP;
378
379DECLINLINE(void) CrFBmInit(CR_FBMAP *pMap)
380{
381 memset(pMap, 0, sizeof (*pMap));
382}
383
384DECLINLINE(bool) CrFBmIsSet(CR_FBMAP *pMap, uint32_t i)
385{
386 return ASMBitTest(&pMap->Map, i);
387}
388
389DECLINLINE(void) CrFBmSet(CR_FBMAP *pMap, uint32_t i)
390{
391 ASMBitSet(&pMap->Map, i);
392}
393
394DECLINLINE(void) CrFBmSetAtomic(CR_FBMAP *pMap, uint32_t i)
395{
396 ASMAtomicBitSet(&pMap->Map, i);
397}
398
399DECLINLINE(void) CrFBmClear(CR_FBMAP *pMap, uint32_t i)
400{
401 ASMBitClear(&pMap->Map, i);
402}
403
404/*helper function that calls CrFbUpdateBegin for all enabled framebuffers */
405int CrPMgrHlpGlblUpdateBegin(CR_FBMAP *pMap);
406/*helper function that calls CrFbUpdateEnd for all framebuffers being updated */
407void CrPMgrHlpGlblUpdateEnd(CR_FBMAP *pMap);
408HCR_FRAMEBUFFER CrPMgrFbGetFirstEnabled();
409HCR_FRAMEBUFFER CrPMgrFbGetNextEnabled(HCR_FRAMEBUFFER hFb);
410HCR_FRAMEBUFFER CrPMgrFbGetEnabled(uint32_t idFb);
411HCR_FRAMEBUFFER CrPMgrFbGetEnabledForScreen(uint32_t idScreen);
412int CrPMgrModeVrdp(bool fEnable);
413int CrPMgrModeRootVr(bool fEnable);
414int CrPMgrModeWinVisible(bool fEnable);
415int CrPMgrRootVrUpdate();
416int CrPMgrViewportUpdate(uint32_t idScreen);
417int CrPMgrScreenChanged(uint32_t idScreen);
418int CrPMgrResize(const struct VBVAINFOSCREEN *pScreen, void *pvVRAM, const uint32_t *pTargetMap);
419int CrPMgrSaveState(PSSMHANDLE pSSM);
420int CrPMgrLoadState(PSSMHANDLE pSSM, uint32_t version);
421HCR_FRAMEBUFFER CrPMgrFbGet(uint32_t idScreen);
422int CrPMgrClearRegionsGlobal();
423/*cleanup stuff*/
424
425
426int CrPMgrInit();
427void CrPMgrTerm();
428int CrPMgrDisable();
429int CrPMgrEnable();
430
431typedef DECLCALLBACKPTR(bool, PFNCR_FRAMEBUFFER_ENTRIES_VISITOR_CB)(HCR_FRAMEBUFFER hFb, HCR_FRAMEBUFFER_ENTRY hEntry, void *pvContext);
432
433bool CrFbHas3DData(HCR_FRAMEBUFFER hFb);
434void CrFbVisitCreatedEntries(HCR_FRAMEBUFFER hFb, PFNCR_FRAMEBUFFER_ENTRIES_VISITOR_CB pfnVisitorCb, void *pvContext);
435int CrFbResize(HCR_FRAMEBUFFER hFb, const struct VBVAINFOSCREEN * pScreen, void *pvVRAM);
436int CrFbBltGetContentsEx(HCR_FRAMEBUFFER hFb, const RTRECTSIZE *pSrcRectSize, const RTRECT *pDstRect, uint32_t cRects, const RTRECT *pRects, CR_BLITTER_IMG *pImg);
437bool CrFbIsEnabled(HCR_FRAMEBUFFER hFb);
438int CrFbEntryCreateForTexId(HCR_FRAMEBUFFER hFb, GLuint idTex, uint32_t fFlags, HCR_FRAMEBUFFER_ENTRY *phEntry);
439int CrFbEntryCreateForTexData(HCR_FRAMEBUFFER hFb, struct CR_TEXDATA *pTex, uint32_t fFlags, HCR_FRAMEBUFFER_ENTRY *phEntry);
440void CrFbEntryAddRef(HCR_FRAMEBUFFER hFb, HCR_FRAMEBUFFER_ENTRY hEntry);
441void CrFbEntryRelease(HCR_FRAMEBUFFER hFb, HCR_FRAMEBUFFER_ENTRY hEntry);
442const struct VBVAINFOSCREEN* CrFbGetScreenInfo(HCR_FRAMEBUFFER hFb);
443void* CrFbGetVRAM(HCR_FRAMEBUFFER hFb);
444const struct VBOXVR_SCR_COMPOSITOR* CrFbGetCompositor(HCR_FRAMEBUFFER hFb);
445const struct VBOXVR_SCR_COMPOSITOR_ENTRY* CrFbEntryGetCompositorEntry(HCR_FRAMEBUFFER_ENTRY hEntry);
446
447/* start doing modifications to the framebuffer */
448int CrFbUpdateBegin(HCR_FRAMEBUFFER hFb);
449/*below commands can only be used in Framebuffer update mode, i.e. after the CrFbUpdateBegin succeeded */
450int CrFbEntryRegions(HCR_FRAMEBUFFER hFb, HCR_FRAMEBUFFER_ENTRY hEntry);
451
452/* complete doing modifications to the framebuffer */
453void CrFbUpdateEnd(HCR_FRAMEBUFFER hFb);
454
455int CrFbEntryRegionsAdd(HCR_FRAMEBUFFER hFb, HCR_FRAMEBUFFER_ENTRY pEntry, const RTPOINT *pPos, uint32_t cRegions, const RTRECT *paRegions, bool fPosRelated);
456int CrFbEntryRegionsSet(HCR_FRAMEBUFFER hFb, HCR_FRAMEBUFFER_ENTRY pEntry, const RTPOINT *pPos, uint32_t cRegions, const RTRECT *paRegions, bool fPosRelated);
457
458int CrFbEntryTexDataUpdate(HCR_FRAMEBUFFER hFb, HCR_FRAMEBUFFER_ENTRY pEntry, struct CR_TEXDATA *pTex);
459
460CRHTABLE_HANDLE CrFbDDataAllocSlot(HCR_FRAMEBUFFER hFb);
461
462typedef DECLCALLBACKPTR(void, PFNCR_FRAMEBUFFER_SLOT_RELEASE_CB)(HCR_FRAMEBUFFER hFb, HCR_FRAMEBUFFER_ENTRY hEntry, void *pvContext);
463
464void CrFbDDataReleaseSlot(HCR_FRAMEBUFFER hFb, CRHTABLE_HANDLE hSlot, PFNCR_FRAMEBUFFER_SLOT_RELEASE_CB pfnReleaseCb, void *pvContext);
465int CrFbDDataEntryPut(HCR_FRAMEBUFFER_ENTRY hEntry, CRHTABLE_HANDLE hSlot, void *pvData);
466void* CrFbDDataEntryClear(HCR_FRAMEBUFFER_ENTRY hEntry, CRHTABLE_HANDLE hSlot);
467void* CrFbDDataEntryGet(HCR_FRAMEBUFFER_ENTRY hEntry, CRHTABLE_HANDLE hSlot);
468
469CR_TEXDATA* CrFbTexDataCreate(const VBOXVR_TEXTURE *pTex);
470void CrFbTexDataInit(CR_TEXDATA* pFbTex, const VBOXVR_TEXTURE *pTex, PFNCRTEXDATA_RELEASED pfnTextureReleased);
471
472int8_t crVBoxServerCrCmdBltProcess(const VBOXCMDVBVA_BLT_HDR *pCmd, uint32_t cbCmd);
473int8_t crVBoxServerCrCmdClrFillProcess(const VBOXCMDVBVA_CLRFILL_HDR *pCmd, uint32_t cbCmd);
474int8_t crVBoxServerCrCmdFlipProcess(const VBOXCMDVBVA_FLIP *pFlip, uint32_t cbCmd);
475
476
477int32_t crVBoxServerClientGet(uint32_t u32ClientID, CRClient **ppClient);
478
479int crServerPendSaveState(PSSMHANDLE pSSM);
480int crServerPendLoadState(PSSMHANDLE pSSM, uint32_t u32Version);
481
482//#define VBOX_WITH_CRSERVER_DUMPER
483#ifdef VBOX_WITH_CRSERVER_DUMPER
484void crServerDumpCheckTerm();
485int crServerDumpCheckInit();
486void crServerDumpBuffer(int idx);
487void crServerDumpTextures();
488void crServerDumpTexture(const VBOXVR_TEXTURE *pTex);
489void crServerDumpShader(GLint id);
490void crServerDumpProgram(GLint id);
491void crServerDumpCurrentProgram();
492void crServerDumpRecompileDumpCurrentProgram();
493void crServerRecompileCurrentProgram();
494void crServerDumpCurrentProgramUniforms();
495void crServerDumpCurrentProgramAttribs();
496void crServerDumpFramesCheck();
497void crServerDumpState();
498void crServerDumpDrawel(const char*pszFormat, ...);
499void crServerDumpDrawelv(GLuint idx, const char*pszElFormat, uint32_t cbEl, const void *pvVal, uint32_t cVal);
500
501extern int64_t g_CrDbgDumpPid;
502extern unsigned long g_CrDbgDumpEnabled;
503extern unsigned long g_CrDbgDumpDraw;
504extern unsigned long g_CrDbgDumpDrawFramesSettings;
505extern unsigned long g_CrDbgDumpDrawFramesAppliedSettings;
506extern unsigned long g_CrDbgDumpDrawFramesCount;
507
508extern uint32_t g_CrDbgDumpVertattrFixupOn;
509
510bool crServerDumpFilterDmp(unsigned long event, CR_DUMPER *pDumper);
511bool crServerDumpFilterOpEnter(unsigned long event, CR_DUMPER *pDumper);
512void crServerDumpFilterOpLeave(unsigned long event, CR_DUMPER *pDumper);
513
514//#define CR_SERVER_DUMP_MASK_OP 0x0000fffc
515//#define CR_SERVER_DUMP_OFF_OP 2
516//
517//#define CR_SERVER_DUMP_MASK_DIR 0x00000003
518//#define CR_SERVER_DUMP_OFF_DIR 0
519//
520//#define CR_SERVER_DUMP_MASK_DMP 0xffff0000
521//#define CR_SERVER_DUMP_OFF_DMP 16
522//
523//#define CR_SERVER_DUMP_MAKE_OP(_v) (1 << ((_v) + CR_SERVER_DUMP_OFF_OP))
524//#define CR_SERVER_DUMP_MAKE_DIR(_v) (1 << ((_v) + CR_SERVER_DUMP_OFF_DIR))
525//#define CR_SERVER_DUMP_MAKE_DMP(_v) (1 << ((_v) + CR_SERVER_DUMP_OFF_DMP))
526//
527//#define CR_SERVER_DUMP_GET_OP(_v) ((_v) & CR_SERVER_DUMP_MASK_OP)
528//#define CR_SERVER_DUMP_GET_DMP(_v) ((_v) & CR_SERVER_DUMP_MASK_DMP)
529//#define CR_SERVER_DUMP_GET_DIR(_v) ((_v) & CR_SERVER_DUMP_MASK_DIR)
530//
531//#define CR_SERVER_DUMP_ISANY_OP(_v1, _v2) (!!(CR_SERVER_DUMP_GET_OP(_v1) & CR_SERVER_DUMP_GET_OP(_v2)))
532//#define CR_SERVER_DUMP_ISANY_DIR(_v1, _v2) (!!(CR_SERVER_DUMP_GET_DIR(_v1) & CR_SERVER_DUMP_GET_DIR(_v2)))
533//#define CR_SERVER_DUMP_ISANY_DMP(_v1, _v2) (!!(CR_SERVER_DUMP_GET_DMP(_v1) & CR_SERVER_DUMP_GET_DMP(_v2)))
534//
535//#define CR_SERVER_DUMP_ISANY_OP(_v1, _v2) ((CR_SERVER_DUMP_GET_OP(_v1) & CR_SERVER_DUMP_GET_OP(_v2)) == CR_SERVER_DUMP_GET_OP(_v2))
536//#define CR_SERVER_DUMP_ISANY_DIR(_v1, _v2) ((CR_SERVER_DUMP_GET_DIR(_v1) & CR_SERVER_DUMP_GET_DIR(_v2)) == CR_SERVER_DUMP_GET_DIR(_v2))
537//#define CR_SERVER_DUMP_ISANY_DMP(_v1, _v2) ((CR_SERVER_DUMP_GET_DMP(_v1) & CR_SERVER_DUMP_GET_DMP(_v2)) == CR_SERVER_DUMP_GET_DMP(_v2))
538//
539//#define CR_SERVER_DUMP_F_DIR_ENTER CR_SERVER_DUMP_MAKE_DIR(0)
540//#define CR_SERVER_DUMP_F_DIR_LEAVE CR_SERVER_DUMP_MAKE_DIR(1)
541//
542//#define CR_SERVER_DUMP_F_OP_DRAW CR_SERVER_DUMP_MAKE_OP(0)
543//#define CR_SERVER_DUMP_F_OP_SWAPBUFFERS CR_SERVER_DUMP_MAKE_OP(1)
544//#define CR_SERVER_DUMP_F_OP_LINK_PROGRAM CR_SERVER_DUMP_MAKE_OP(2)
545//#define CR_SERVER_DUMP_F_OP_COMPILE_PROGRAM CR_SERVER_DUMP_MAKE_OP(3)
546//
547//#define CR_SERVER_DUMP_F_DMP_BUFF CR_SERVER_DUMP_MAKE_DMP(0)
548//#define CR_SERVER_DUMP_F_DMP_TEX CR_SERVER_DUMP_MAKE_DMP(0)
549//#define CR_SERVER_DUMP_F_DMP_PROGRAM CR_SERVER_DUMP_MAKE_DMP(0)
550//#define CR_SERVER_DUMP_F_DMP_PROGRAM_UNIFORMS CR_SERVER_DUMP_MAKE_DMP(0)
551//#define CR_SERVER_DUMP_F_DMP_STATE CR_SERVER_DUMP_MAKE_DMP(0)
552//
553//#define CR_SERVER_DUMP_GET_OP(_v) ((_v) & CR_SERVER_DUMP_MASK_OP)
554//#define CR_SERVER_DUMP_GET_DMP(_v) ((_v) & CR_SERVER_DUMP_MASK_DMP)
555//#define CR_SERVER_DUMP_GET_DIR(_v) ((_v) & CR_SERVER_DUMP_MASK_DIR)
556
557#define CR_SERVER_DUMP_F_DRAW_BUFF_ENTER 0x00000001
558#define CR_SERVER_DUMP_F_DRAW_BUFF_LEAVE 0x00000002
559#define CR_SERVER_DUMP_F_DRAW_STATE_ENTER 0x00000004
560#define CR_SERVER_DUMP_F_DRAW_STATE_LEAVE 0x00000008
561#define CR_SERVER_DUMP_F_DRAW_TEX_ENTER 0x00000010
562#define CR_SERVER_DUMP_F_DRAW_TEX_LEAVE 0x00000020
563#define CR_SERVER_DUMP_F_DRAW_PROGRAM_ENTER 0x00000040
564#define CR_SERVER_DUMP_F_DRAW_PROGRAM_LEAVE 0x00000080
565#define CR_SERVER_DUMP_F_DRAW_PROGRAM_UNIFORMS_ENTER 0x00000100
566#define CR_SERVER_DUMP_F_DRAW_PROGRAM_UNIFORMS_LEAVE 0x00000200
567#define CR_SERVER_DUMP_F_DRAW_PROGRAM_ATTRIBS_ENTER 0x00000400
568#define CR_SERVER_DUMP_F_DRAW_PROGRAM_ATTRIBS_LEAVE 0x00000800
569
570#define CR_SERVER_DUMP_F_DRAW_ENTER_ALL (CR_SERVER_DUMP_F_DRAW_BUFF_ENTER \
571 | CR_SERVER_DUMP_F_DRAW_TEX_ENTER \
572 | CR_SERVER_DUMP_F_DRAW_PROGRAM_ENTER \
573 | CR_SERVER_DUMP_F_DRAW_PROGRAM_UNIFORMS_ENTER \
574 | CR_SERVER_DUMP_F_DRAW_STATE_ENTER \
575 | CR_SERVER_DUMP_F_DRAW_PROGRAM_ATTRIBS_ENTER)
576
577#define CR_SERVER_DUMP_F_DRAW_LEAVE_ALL (CR_SERVER_DUMP_F_DRAW_BUFF_LEAVE \
578 | CR_SERVER_DUMP_F_DRAW_TEX_LEAVE \
579 | CR_SERVER_DUMP_F_DRAW_PROGRAM_LEAVE \
580 | CR_SERVER_DUMP_F_DRAW_PROGRAM_UNIFORMS_LEAVE \
581 | CR_SERVER_DUMP_F_DRAW_STATE_LEAVE \
582 | CR_SERVER_DUMP_F_DRAW_PROGRAM_ATTRIBS_LEAVE)
583
584#define CR_SERVER_DUMP_F_DRAW_ALL (CR_SERVER_DUMP_F_DRAW_ENTER_ALL | CR_SERVER_DUMP_F_DRAW_LEAVE_ALL)
585
586#define CR_SERVER_DUMP_F_SWAPBUFFERS_ENTER 0x00010000
587#define CR_SERVER_DUMP_F_SWAPBUFFERS_LEAVE 0x00020000
588#define CR_SERVER_DUMP_F_TEXPRESENT 0x00040000
589#define CR_SERVER_DUMP_F_DRAWEL 0x00100000
590#define CR_SERVER_DUMP_F_COMPILE_SHADER 0x01000000
591#define CR_SERVER_DUMP_F_SHADER_SOURCE 0x02000000
592#define CR_SERVER_DUMP_F_LINK_PROGRAM 0x04000000
593
594
595#define CR_SERVER_DUMP_DEFAULT_FILTER_OP(_ev) ((((_ev) & g_CrDbgDumpDraw) != 0) \
596 || ((_ev) == CR_SERVER_DUMP_F_SWAPBUFFERS_ENTER && g_CrDbgDumpDrawFramesCount))
597
598#define CR_SERVER_DUMP_DEFAULT_FILTER_DMP(_ev) (((_ev) & g_CrDbgDumpDraw) != 0)
599
600#define CR_SERVER_DUMP_FILTER_OP(_ev, _pDumper) (g_CrDbgDumpEnabled \
601 && (!g_CrDbgDumpPid \
602 || (g_CrDbgDumpPid > 0 && ((uint64_t)g_CrDbgDumpPid) == cr_server.curClient->pid) \
603 || (g_CrDbgDumpPid < 0 && ((uint64_t)(-g_CrDbgDumpPid)) != cr_server.curClient->pid)) \
604 && crServerDumpFilterOpEnter((_ev), (_pDumper)))
605#define CR_SERVER_DUMP_FILTER_DMP(_ev, _pDumper) (crServerDumpFilterDmp((_ev), (_pDumper)))
606
607#define CR_SERVER_DUMP_DRAW_ENTER() do { \
608 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_DRAW_ENTER_ALL, cr_server.Recorder.pDumper)) break; \
609 crServerDumpCheckInit(); \
610 crDmpStrF(cr_server.Recorder.pDumper, "==ENTER[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
611 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_STATE_ENTER, cr_server.Recorder.pDumper)) { crServerDumpState(); } \
612 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_PROGRAM_ENTER, cr_server.Recorder.pDumper)) { crServerDumpCurrentProgram(); } \
613 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_PROGRAM_UNIFORMS_ENTER, cr_server.Recorder.pDumper)) { crServerDumpCurrentProgramUniforms(); } \
614 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_PROGRAM_ATTRIBS_ENTER, cr_server.Recorder.pDumper)) { crServerDumpCurrentProgramAttribs(); } \
615 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_TEX_ENTER, cr_server.Recorder.pDumper)) { crServerDumpTextures(); } \
616 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_BUFF_ENTER, cr_server.Recorder.pDumper)) { crServerDumpBuffer(-1); } \
617 crDmpStrF(cr_server.Recorder.pDumper, "==Done ENTER[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
618 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_DRAW_ENTER_ALL, cr_server.Recorder.pDumper); \
619 } while (0)
620
621#define CR_SERVER_DUMP_DRAW_LEAVE() do { \
622 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_DRAW_LEAVE_ALL, cr_server.Recorder.pDumper)) break; \
623 crServerDumpCheckInit(); \
624 crDmpStrF(cr_server.Recorder.pDumper, "==LEAVE[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
625 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_TEX_LEAVE, cr_server.Recorder.pDumper)) { crServerDumpTextures(); } \
626 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_BUFF_LEAVE, cr_server.Recorder.pDumper)) { crServerDumpBuffer(-1); } \
627 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_PROGRAM_UNIFORMS_LEAVE, cr_server.Recorder.pDumper)) { crServerDumpCurrentProgramUniforms(); } \
628 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_PROGRAM_ATTRIBS_LEAVE, cr_server.Recorder.pDumper)) { crServerDumpCurrentProgramAttribs(); } \
629 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_PROGRAM_LEAVE, cr_server.Recorder.pDumper)) { crServerDumpCurrentProgram(); } \
630 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_DRAW_STATE_LEAVE, cr_server.Recorder.pDumper)) { crServerDumpState(); } \
631 crDmpStrF(cr_server.Recorder.pDumper, "==Done LEAVE[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
632 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_DRAW_LEAVE_ALL, cr_server.Recorder.pDumper); \
633 } while (0)
634
635#define CR_SERVER_DUMP_COMPILE_SHADER(_id) do { \
636 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_COMPILE_SHADER, cr_server.Recorder.pDumper)) break; \
637 crServerDumpCheckInit(); \
638 crDmpStrF(cr_server.Recorder.pDumper, "==[%d] %s", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
639 crServerDumpShader((_id)); \
640 crDmpStrF(cr_server.Recorder.pDumper, "==Done[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
641 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_COMPILE_SHADER, cr_server.Recorder.pDumper); \
642 } while (0)
643
644#define CR_SERVER_DUMP_SHADER_SOURCE(_id) do { \
645 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_SHADER_SOURCE, cr_server.Recorder.pDumper)) break; \
646 crServerDumpCheckInit(); \
647 crDmpStrF(cr_server.Recorder.pDumper, "==[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
648 crServerDumpShader((_id)); \
649 crDmpStrF(cr_server.Recorder.pDumper, "==Done[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
650 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_SHADER_SOURCE, cr_server.Recorder.pDumper); \
651 } while (0)
652
653#define CR_SERVER_DUMP_LINK_PROGRAM(_id) do { \
654 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_LINK_PROGRAM, cr_server.Recorder.pDumper)) break; \
655 crServerDumpCheckInit(); \
656 crDmpStrF(cr_server.Recorder.pDumper, "==[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
657 crServerDumpProgram((_id)); \
658 crDmpStrF(cr_server.Recorder.pDumper, "==Done[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
659 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_LINK_PROGRAM, cr_server.Recorder.pDumper); \
660 } while (0)
661
662#define CR_SERVER_DUMP_SWAPBUFFERS_ENTER() do { \
663 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_SWAPBUFFERS_ENTER, cr_server.Recorder.pDumper)) break; \
664 crServerDumpCheckInit(); \
665 crDmpStrF(cr_server.Recorder.pDumper, "==ENTER[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
666 if (CR_SERVER_DUMP_FILTER_DMP(CR_SERVER_DUMP_F_SWAPBUFFERS_ENTER, cr_server.Recorder.pDumper)) { crServerDumpBuffer(CR_SERVER_FBO_BB_IDX(cr_server.currentMural)); } \
667 if (g_CrDbgDumpDrawFramesCount) { crServerDumpFramesCheck(); } \
668 crDmpStrF(cr_server.Recorder.pDumper, "==Done ENTER[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
669 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_SWAPBUFFERS_ENTER, cr_server.Recorder.pDumper); \
670 } while (0)
671
672#define CR_SERVER_DUMP_TEXPRESENT(_pTex) do { \
673 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_TEXPRESENT, cr_server.Recorder.pDumper)) break; \
674 crServerDumpCheckInit(); \
675 crDmpStrF(cr_server.Recorder.pDumper, "==[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
676 crServerDumpTexture((_pTex)); \
677 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_TEXPRESENT, cr_server.Recorder.pDumper); \
678 } while (0)
679
680#define CR_SERVER_DUMP_SWAPBUFFERS_LEAVE() do { \
681 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_SWAPBUFFERS_LEAVE, cr_server.Recorder.pDumper)) break; \
682 crDmpStrF(cr_server.Recorder.pDumper, "==LEAVE[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
683 crServerDumpCheckInit(); \
684 crDmpStrF(cr_server.Recorder.pDumper, "==Done LEAVE[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
685 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_SWAPBUFFERS_LEAVE, cr_server.Recorder.pDumper); \
686 } while (0)
687
688#define CR_SERVER_DUMP_DRAWEL_F(_msg) do { \
689 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_DRAWEL, cr_server.Recorder.pDumper)) break; \
690 crServerDumpCheckInit(); \
691 crDmpStrF(cr_server.Recorder.pDumper, "==[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
692 crServerDumpDrawel _msg; \
693 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_DRAWEL, cr_server.Recorder.pDumper); \
694 } while (0)
695
696#define CR_SERVER_DUMP_DRAWEL_V(_index, _pszElFormat, _cbEl, _pvVal, _cVal) do { \
697 if (!CR_SERVER_DUMP_FILTER_OP(CR_SERVER_DUMP_F_DRAWEL, cr_server.Recorder.pDumper)) break; \
698 crServerDumpCheckInit(); \
699 crDmpStrF(cr_server.Recorder.pDumper, "==[%d] %s==", (uint32_t)cr_server.curClient->pid, __FUNCTION__); \
700 crServerDumpDrawelv((_index), (_pszElFormat), (_cbEl), (_pvVal), (_cVal)); \
701 crServerDumpFilterOpLeave(CR_SERVER_DUMP_F_DRAWEL, cr_server.Recorder.pDumper); \
702 } while (0)
703#else /* if !defined VBOX_WITH_CRSERVER_DUMPER */
704#define CR_SERVER_DUMP_DRAW_ENTER() do {} while (0)
705#define CR_SERVER_DUMP_DRAW_LEAVE() do {} while (0)
706#define CR_SERVER_DUMP_COMPILE_SHADER(_id) do {} while (0)
707#define CR_SERVER_DUMP_LINK_PROGRAM(_id) do {} while (0)
708#define CR_SERVER_DUMP_TEXPRESENT(_pTex) do {} while (0)
709#define CR_SERVER_DUMP_SWAPBUFFERS_ENTER() do {} while (0)
710#define CR_SERVER_DUMP_SWAPBUFFERS_LEAVE() do {} while (0)
711#define CR_SERVER_DUMP_SHADER_SOURCE(_id) do {} while (0)
712#define CR_SERVER_DUMP_DRAWEL_F(_msg) do {} while (0)
713#define CR_SERVER_DUMP_DRAWEL_V(_index, _pszElFormat, _cbEl, _pvVal, _cVal) do {} while (0)
714#endif /* !VBOX_WITH_CRSERVER_DUMPER */
715
716RT_C_DECLS_END
717
718#endif /* CR_SERVER_H */
注意: 瀏覽 TracBrowser 來幫助您使用儲存庫瀏覽器

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette