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 |
|
---|
18 | #ifdef VBOX_WITH_CRHGSMI
|
---|
19 | # include <VBox/VBoxVideo.h>
|
---|
20 |
|
---|
21 | #include <iprt/cdefs.h>
|
---|
22 |
|
---|
23 | RT_C_DECLS_BEGIN
|
---|
24 |
|
---|
25 | extern uint8_t* g_pvVRamBase;
|
---|
26 | extern uint32_t g_cbVRam;
|
---|
27 | extern HCRHGSMICMDCOMPLETION g_hCrHgsmiCompletion;
|
---|
28 | extern PFNCRHGSMICMDCOMPLETION g_pfnCrHgsmiCompletion;
|
---|
29 |
|
---|
30 | #define VBOXCRHGSMI_PTR(_off, _t) ((_t*)(g_pvVRamBase + (_off)))
|
---|
31 | #define VBOXCRHGSMI_PTR_SAFE(_off, _cb, _t) ((_t*)crServerCrHgsmiPtrGet(_off, _cb))
|
---|
32 |
|
---|
33 | DECLINLINE(void*) crServerCrHgsmiPtrGet(VBOXVIDEOOFFSET offBuffer, uint32_t cbBuffer)
|
---|
34 | {
|
---|
35 | return ((offBuffer) + (cbBuffer) <= g_cbVRam ? VBOXCRHGSMI_PTR(offBuffer, void) : NULL);
|
---|
36 | }
|
---|
37 |
|
---|
38 | DECLINLINE(void) crServerCrHgsmiCmdComplete(struct VBOXVDMACMD_CHROMIUM_CMD *pCmd, int cmdProcessingRc)
|
---|
39 | {
|
---|
40 | g_pfnCrHgsmiCompletion(g_hCrHgsmiCompletion, pCmd, cmdProcessingRc);
|
---|
41 | }
|
---|
42 |
|
---|
43 | #define VBOXCRHGSMI_CMD_COMPLETE(_pData, _rc) do { \
|
---|
44 | CRVBOXHGSMI_CMDDATA_ASSERT_ISSET(_pData); \
|
---|
45 | CRVBOXHGSMI_CMDDATA_RC(_pData, _rc); \
|
---|
46 | crServerCrHgsmiCmdComplete((_pData)->pCmd, VINF_SUCCESS); \
|
---|
47 | } while (0)
|
---|
48 |
|
---|
49 | #define VBOXCRHGSMI_CMD_CHECK_COMPLETE(_pData, _rc) do { \
|
---|
50 | if (CRVBOXHGSMI_CMDDATA_IS_SET(_pData)) { \
|
---|
51 | VBOXCRHGSMI_CMD_COMPLETE(_pData, _rc); \
|
---|
52 | } \
|
---|
53 | } while (0)
|
---|
54 |
|
---|
55 | #endif
|
---|
56 |
|
---|
57 | /*
|
---|
58 | * This is the base number for window and context IDs
|
---|
59 | */
|
---|
60 | #define MAGIC_OFFSET 5000
|
---|
61 |
|
---|
62 | extern CRServer cr_server;
|
---|
63 |
|
---|
64 | /* Semaphore wait queue node */
|
---|
65 | typedef struct _wqnode {
|
---|
66 | RunQueue *q;
|
---|
67 | struct _wqnode *next;
|
---|
68 | } wqnode;
|
---|
69 |
|
---|
70 | typedef struct {
|
---|
71 | GLuint count;
|
---|
72 | GLuint num_waiting;
|
---|
73 | RunQueue **waiting;
|
---|
74 | } CRServerBarrier;
|
---|
75 |
|
---|
76 | typedef struct {
|
---|
77 | GLuint count;
|
---|
78 | wqnode *waiting, *tail;
|
---|
79 | } CRServerSemaphore;
|
---|
80 |
|
---|
81 | typedef struct {
|
---|
82 | GLuint id;
|
---|
83 | GLint projParamStart;
|
---|
84 | GLfloat projMat[16]; /* projection matrix, accumulated via calls to */
|
---|
85 | /* glProgramLocalParameterARB, glProgramParameterNV */
|
---|
86 | } CRServerProgram;
|
---|
87 |
|
---|
88 | void crServerSetVBoxConfiguration();
|
---|
89 | void crServerSetVBoxConfigurationHGCM();
|
---|
90 | void crServerInitDispatch(void);
|
---|
91 | void crServerReturnValue( const void *payload, unsigned int payload_len );
|
---|
92 | void crServerWriteback(void);
|
---|
93 | int crServerRecv( CRConnection *conn, CRMessage *msg, unsigned int len );
|
---|
94 | void crServerSerializeRemoteStreams(void);
|
---|
95 | void crServerAddToRunQueue( CRClient *client );
|
---|
96 | void crServerDeleteClient( CRClient *client );
|
---|
97 |
|
---|
98 |
|
---|
99 | void crServerApplyBaseProjection( const CRmatrix *baseProj );
|
---|
100 | void crServerApplyViewMatrix( const CRmatrix *view );
|
---|
101 | void crServerSetOutputBounds( const CRMuralInfo *mural, int extNum );
|
---|
102 | void crServerComputeViewportBounds( const CRViewportState *v, CRMuralInfo *mural );
|
---|
103 |
|
---|
104 | GLboolean crServerInitializeBucketing(CRMuralInfo *mural);
|
---|
105 |
|
---|
106 | void crComputeOverlapGeom(double *quads, int nquad, CRPoly ***res);
|
---|
107 | void crComputeKnockoutGeom(double *quads, int nquad, int my_quad_idx, CRPoly **res);
|
---|
108 |
|
---|
109 | int crServerGetCurrentEye(void);
|
---|
110 |
|
---|
111 | GLboolean crServerClientInBeginEnd(const CRClient *client);
|
---|
112 |
|
---|
113 | GLint crServerDispatchCreateContextEx(const char *dpyName, GLint visualBits, GLint shareCtx, GLint preloadCtxID, int32_t internalID);
|
---|
114 | GLint crServerDispatchWindowCreateEx(const char *dpyName, GLint visBits, GLint preloadWinID);
|
---|
115 | GLint crServerMuralInit(CRMuralInfo *mural, const char *dpyName, GLint visBits, GLint preloadWinID);
|
---|
116 | void crServerMuralTerm(CRMuralInfo *mural);
|
---|
117 | void crServerMuralSize(CRMuralInfo *mural, GLint width, GLint height);
|
---|
118 | int crServerMuralSynchRootVr(CRMuralInfo *mural, uint32_t *pcRects, const RTRECT **ppRects);
|
---|
119 |
|
---|
120 | GLint crServerGenerateID(GLint *pCounter);
|
---|
121 |
|
---|
122 | GLint crServerSPUWindowID(GLint serverWindow);
|
---|
123 |
|
---|
124 | GLuint crServerTranslateProgramID(GLuint id);
|
---|
125 |
|
---|
126 | CRMuralInfo * crServerGetDummyMural(GLint visualBits);
|
---|
127 |
|
---|
128 | void crServerSetupOutputRedirect(CRMuralInfo *mural);
|
---|
129 | void crServerCheckMuralGeometry(CRMuralInfo *mural);
|
---|
130 | GLboolean crServerSupportRedirMuralFBO(void);
|
---|
131 |
|
---|
132 | void crVBoxServerNotifyEvent(int32_t idScreen);
|
---|
133 |
|
---|
134 | #define CR_SERVER_REDIR_F_NONE 0x00
|
---|
135 | /* the data should be displayed on host (unset when is on or when CR_SERVER_REDIR_F_FBO_RAM_VMFB is set) */
|
---|
136 | #define CR_SERVER_REDIR_F_DISPLAY 0x01
|
---|
137 | /* guest window data get redirected to FBO on host */
|
---|
138 | #define CR_SERVER_REDIR_F_FBO 0x02
|
---|
139 | /* used with CR_SERVER_REDIR_F_FBO only
|
---|
140 | * indicates that FBO data should be copied to RAM for further processing */
|
---|
141 | #define CR_SERVER_REDIR_F_FBO_RAM 0x04
|
---|
142 | /* used with CR_SERVER_REDIR_F_FBO_RAM only
|
---|
143 | * indicates that FBO data should be passed to VRDP backend */
|
---|
144 | #define CR_SERVER_REDIR_F_FBO_RAM_VRDP 0x08
|
---|
145 | /* used with CR_SERVER_REDIR_F_FBO_RAM only
|
---|
146 | * indicates that FBO data should be passed to VM Framebuffer */
|
---|
147 | #define CR_SERVER_REDIR_F_FBO_RAM_VMFB 0x10
|
---|
148 | /* used with CR_SERVER_REDIR_F_FBO_RAM only
|
---|
149 | * makes the RPW (Read Pixels Worker) mechanism to be used for GPU memory aquisition */
|
---|
150 | #define CR_SERVER_REDIR_F_FBO_RPW 0x20
|
---|
151 |
|
---|
152 |
|
---|
153 | #define CR_SERVER_REDIR_F_ALL 0x3f
|
---|
154 |
|
---|
155 | #define CR_SERVER_REDIR_FGROUP_REQUIRE_FBO (CR_SERVER_REDIR_F_ALL & ~CR_SERVER_REDIR_F_DISPLAY)
|
---|
156 | #define CR_SERVER_REDIR_FGROUP_REQUIRE_FBO_RAM (CR_SERVER_REDIR_F_FBO_RAM_VRDP | CR_SERVER_REDIR_F_FBO_RAM_VMFB | CR_SERVER_REDIR_F_FBO_RPW)
|
---|
157 |
|
---|
158 | DECLINLINE(GLuint) crServerRedirModeAdjust(GLuint value)
|
---|
159 | {
|
---|
160 | /* sanitize values */
|
---|
161 | value &= CR_SERVER_REDIR_F_ALL;
|
---|
162 |
|
---|
163 | if (value & CR_SERVER_REDIR_FGROUP_REQUIRE_FBO)
|
---|
164 | value |= CR_SERVER_REDIR_F_FBO;
|
---|
165 | if (value & CR_SERVER_REDIR_FGROUP_REQUIRE_FBO_RAM)
|
---|
166 | value |= CR_SERVER_REDIR_F_FBO_RAM;
|
---|
167 |
|
---|
168 | return value;
|
---|
169 | }
|
---|
170 |
|
---|
171 | int32_t crServerSetOffscreenRenderingMode(GLuint value);
|
---|
172 | void crServerRedirMuralFBO(CRMuralInfo *mural, GLuint redir);
|
---|
173 | void crServerDeleteMuralFBO(CRMuralInfo *mural);
|
---|
174 | void crServerPresentFBO(CRMuralInfo *mural);
|
---|
175 | GLboolean crServerIsRedirectedToFBO();
|
---|
176 | GLint crServerMuralFBOIdxFromBufferName(CRMuralInfo *mural, GLenum buffer);
|
---|
177 | void crServerMuralFBOSwapBuffers(CRMuralInfo *mural);
|
---|
178 |
|
---|
179 | void crServerVBoxCompositionDisableEnter(CRMuralInfo *mural);
|
---|
180 | void crServerVBoxCompositionDisableLeave(CRMuralInfo *mural, GLboolean fForcePresentOnEnabled);
|
---|
181 | void crServerVBoxCompositionPresent(CRMuralInfo *mural);
|
---|
182 | DECLINLINE(GLboolean) crServerVBoxCompositionPresentNeeded(CRMuralInfo *mural)
|
---|
183 | {
|
---|
184 | return mural->bVisible
|
---|
185 | && mural->width
|
---|
186 | && mural->height
|
---|
187 | && !mural->fRootVrOn ? CrVrScrCompositorEntryIsInList(&mural->CEntry) : CrVrScrCompositorEntryIsInList(&mural->RootVrCEntry);
|
---|
188 | }
|
---|
189 |
|
---|
190 | #define CR_SERVER_FBO_BB_IDX(_mural) ((_mural)->iBbBuffer)
|
---|
191 | #define CR_SERVER_FBO_FB_IDX(_mural) (((_mural)->iBbBuffer + 1) % ((_mural)->cBuffers))
|
---|
192 | /* returns a valid index to be used for negative _idx, i.e. for GL_NONE cases */
|
---|
193 | //#define CR_SERVER_FBO_ADJUST_IDX(_mural, _idx) ((_idx) >= 0 ? (_idx) : CR_SERVER_FBO_BB_IDX(_mural))
|
---|
194 | /* just a helper that uses CR_SERVER_FBO_ADJUST_IDX for getting mural's FBO id for buffer index*/
|
---|
195 | //#define CR_SERVER_FBO_FOR_IDX(_mural, _idx) ((_mural)->aidFBOs[CR_SERVER_FBO_ADJUST_IDX((_mural), (_idx))])
|
---|
196 | //#define CR_SERVER_FBO_TEX_FOR_IDX(_mural, _idx) ((_mural)->aidColorTexs[CR_SERVER_FBO_ADJUST_IDX((_mural), (_idx))])
|
---|
197 | #define CR_SERVER_FBO_FOR_IDX(_mural, _idx) ((_idx) >= 0 ? (_mural)->aidFBOs[(_idx)] : 0)
|
---|
198 | #define CR_SERVER_FBO_TEX_FOR_IDX(_mural, _idx) ((_idx) >= 0 ? (_mural)->aidColorTexs[(_idx)] : 0)
|
---|
199 |
|
---|
200 | int32_t crVBoxServerInternalClientRead(CRClient *pClient, uint8_t *pBuffer, uint32_t *pcbBuffer);
|
---|
201 |
|
---|
202 | PCR_DISPLAY crServerDisplayGetInitialized(uint32_t idScreen);
|
---|
203 |
|
---|
204 | void crServerPerformMakeCurrent( CRMuralInfo *mural, CRContextInfo *ctxInfo );
|
---|
205 |
|
---|
206 | PCR_BLITTER crServerVBoxBlitterGet();
|
---|
207 |
|
---|
208 | DECLINLINE(void) crServerVBoxBlitterWinInit(CR_BLITTER_WINDOW *win, CRMuralInfo *mural)
|
---|
209 | {
|
---|
210 | win->Base.id = mural->spuWindow;
|
---|
211 | win->Base.visualBits = mural->CreateInfo.visualBits;
|
---|
212 | win->width = mural->width;
|
---|
213 | win->height = mural->height;
|
---|
214 | }
|
---|
215 |
|
---|
216 | DECLINLINE(void) crServerVBoxBlitterCtxInit(CR_BLITTER_CONTEXT *ctx, CRContextInfo *ctxInfo)
|
---|
217 | {
|
---|
218 | ctx->Base.id = ctxInfo->SpuContext;
|
---|
219 | if (ctx->Base.id < 0)
|
---|
220 | ctx->Base.id = cr_server.MainContextInfo.SpuContext;
|
---|
221 | ctx->Base.visualBits = cr_server.curClient->currentCtxInfo->CreateInfo.visualBits;
|
---|
222 | }
|
---|
223 |
|
---|
224 | /* display worker thread.
|
---|
225 | * see comments for CR_SERVER_RPW struct definition in cr_server.h */
|
---|
226 | DECLINLINE(void) crServerXchgI8(int8_t *pu8Val1, int8_t *pu8Val2)
|
---|
227 | {
|
---|
228 | int8_t tmp;
|
---|
229 | tmp = *pu8Val1;
|
---|
230 | *pu8Val1 = *pu8Val2;
|
---|
231 | *pu8Val2 = tmp;
|
---|
232 | }
|
---|
233 |
|
---|
234 | #ifdef DEBUG_misha
|
---|
235 | # define CR_SERVER_RPW_DEBUG
|
---|
236 | #endif
|
---|
237 | /* *
|
---|
238 | * _name : Draw, Submitted, Worker, Gpu
|
---|
239 | */
|
---|
240 |
|
---|
241 | #ifdef CR_SERVER_RPW_DEBUG
|
---|
242 | # define crServerRpwEntryDbgVerify(_pE) crServerRpwEntryDbgDoVerify(_pE)
|
---|
243 | #else
|
---|
244 | # define crServerRpwEntryDbgVerify(_pE) do {} while (0)
|
---|
245 | #endif
|
---|
246 |
|
---|
247 |
|
---|
248 | #define CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _name) ((_pEntry)->iTex##_name > 0)
|
---|
249 |
|
---|
250 | #define CR_SERVER_RPW_ENTRY_TEX_INVALIDATE(_pEntry, _name) do { \
|
---|
251 | crServerRpwEntryDbgVerify(_pEntry); \
|
---|
252 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _name)); \
|
---|
253 | (_pEntry)->iTex##_name = -(_pEntry)->iTex##_name; \
|
---|
254 | crServerRpwEntryDbgVerify(_pEntry); \
|
---|
255 | } while (0)
|
---|
256 |
|
---|
257 | #define CR_SERVER_RPW_ENTRY_TEX_PROMOTE(_pEntry, _fromName, _toName) do { \
|
---|
258 | crServerRpwEntryDbgVerify(_pEntry); \
|
---|
259 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
|
---|
260 | Assert(!CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
|
---|
261 | crServerXchgI8(&(_pEntry)->iTex##_fromName, &(_pEntry)->iTex##_toName); \
|
---|
262 | crServerRpwEntryDbgVerify(_pEntry); \
|
---|
263 | } while (0)
|
---|
264 |
|
---|
265 | #define CR_SERVER_RPW_ENTRY_TEX_XCHG_VALID(_pEntry, _fromName, _toName) do { \
|
---|
266 | crServerRpwEntryDbgVerify(_pEntry); \
|
---|
267 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
|
---|
268 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
|
---|
269 | crServerXchgI8(&(_pEntry)->iTex##_fromName, &(_pEntry)->iTex##_toName); \
|
---|
270 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
|
---|
271 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
|
---|
272 | crServerRpwEntryDbgVerify(_pEntry); \
|
---|
273 | } while (0)
|
---|
274 |
|
---|
275 |
|
---|
276 | #define CR_SERVER_RPW_ENTRY_TEX_PROMOTE_KEEPVALID(_pEntry, _fromName, _toName) do { \
|
---|
277 | crServerRpwEntryDbgVerify(_pEntry); \
|
---|
278 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
|
---|
279 | Assert(!CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
|
---|
280 | crServerXchgI8(&(_pEntry)->iTex##_fromName, &(_pEntry)->iTex##_toName); \
|
---|
281 | (_pEntry)->iTex##_fromName = -(_pEntry)->iTex##_fromName; \
|
---|
282 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _fromName)); \
|
---|
283 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(_pEntry, _toName)); \
|
---|
284 | crServerRpwEntryDbgVerify(_pEntry); \
|
---|
285 | } while (0)
|
---|
286 |
|
---|
287 | #define CR_SERVER_RPW_ENTRY_TEX(_pEntry, _name) ((_pEntry)->aidWorkerTexs[(_pEntry)->iTex##_name - 1])
|
---|
288 |
|
---|
289 | #define CR_SERVER_RPW_ENTRY_PBO_NEXT_ID(_i) (((_i) + 1) % 2)
|
---|
290 | #define CR_SERVER_RPW_ENTRY_PBO_IS_ACTIVE(_pEntry) ((_pEntry)->iCurPBO >= 0)
|
---|
291 | #define CR_SERVER_RPW_ENTRY_PBO_CUR(_pEntry) ((_pEntry)->aidPBOs[(_pEntry)->iCurPBO])
|
---|
292 | #define CR_SERVER_RPW_ENTRY_PBO_COMPLETED(_pEntry) ((_pEntry)->aidPBOs[CR_SERVER_RPW_ENTRY_PBO_NEXT_ID((_pEntry)->iCurPBO)])
|
---|
293 | #define CR_SERVER_RPW_ENTRY_PBO_FLIP(_pEntry) do { \
|
---|
294 | (_pEntry)->iCurPBO = CR_SERVER_RPW_ENTRY_PBO_NEXT_ID((_pEntry)->iCurPBO); \
|
---|
295 | } while (0)
|
---|
296 |
|
---|
297 | #ifdef CR_SERVER_RPW_DEBUG
|
---|
298 | DECLINLINE(void) crServerRpwEntryDbgDoVerify(CR_SERVER_RPW_ENTRY *pEntry)
|
---|
299 | {
|
---|
300 | int tstMask = 0;
|
---|
301 | int8_t iVal;
|
---|
302 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(pEntry, Draw));
|
---|
303 |
|
---|
304 | #define CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(_v) do { \
|
---|
305 | iVal = RT_ABS(_v); \
|
---|
306 | Assert(iVal > 0); \
|
---|
307 | Assert(iVal < 5); \
|
---|
308 | Assert(!(tstMask & (1 << iVal))); \
|
---|
309 | tstMask |= (1 << iVal); \
|
---|
310 | } while (0)
|
---|
311 |
|
---|
312 | CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(pEntry->iTexDraw);
|
---|
313 | CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(pEntry->iTexSubmitted);
|
---|
314 | CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(pEntry->iTexWorker);
|
---|
315 | CR_VERVER_RPW_ENTRY_DBG_CHECKVAL(pEntry->iTexGpu);
|
---|
316 | Assert(tstMask == 0x1E);
|
---|
317 | }
|
---|
318 | #endif
|
---|
319 |
|
---|
320 | DECLINLINE(bool) crServerRpwIsInitialized(const CR_SERVER_RPW *pWorker)
|
---|
321 | {
|
---|
322 | return !!pWorker->ctxId;
|
---|
323 | }
|
---|
324 | int crServerRpwInit(CR_SERVER_RPW *pWorker);
|
---|
325 | int crServerRpwTerm(CR_SERVER_RPW *pWorker);
|
---|
326 | DECLINLINE(bool) crServerRpwEntryIsInitialized(const CR_SERVER_RPW_ENTRY *pEntry)
|
---|
327 | {
|
---|
328 | return !!pEntry->pfnData;
|
---|
329 | }
|
---|
330 | int crServerRpwEntryInit(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry, uint32_t width, uint32_t height, PFNCR_SERVER_RPW_DATA pfnData);
|
---|
331 | int crServerRpwEntryCleanup(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry);
|
---|
332 | int crServerRpwEntryResize(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry, uint32_t width, uint32_t height);
|
---|
333 | int crServerRpwEntrySubmit(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry);
|
---|
334 | int crServerRpwEntryWaitComplete(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry);
|
---|
335 | int crServerRpwEntryCancel(CR_SERVER_RPW *pWorker, CR_SERVER_RPW_ENTRY *pEntry);
|
---|
336 | DECLINLINE(void) crServerRpwEntryDrawSettingsToTex(const CR_SERVER_RPW_ENTRY *pEntry, VBOXVR_TEXTURE *pTex)
|
---|
337 | {
|
---|
338 | pTex->width = pEntry->Size.cx;
|
---|
339 | pTex->height = pEntry->Size.cy;
|
---|
340 | pTex->target = GL_TEXTURE_2D;
|
---|
341 | Assert(CR_SERVER_RPW_ENTRY_TEX_IS_VALID(pEntry, Draw));
|
---|
342 | pTex->hwid = CR_SERVER_RPW_ENTRY_TEX(pEntry, Draw);
|
---|
343 | }
|
---|
344 | /**/
|
---|
345 |
|
---|
346 | typedef struct CR_SERVER_CTX_SWITCH
|
---|
347 | {
|
---|
348 | GLuint idDrawFBO, idReadFBO;
|
---|
349 | CRContext *pNewCtx;
|
---|
350 | CRContext *pOldCtx;
|
---|
351 | } CR_SERVER_CTX_SWITCH;
|
---|
352 |
|
---|
353 | DECLINLINE(void) crServerCtxSwitchPrepare(CR_SERVER_CTX_SWITCH *pData, CRContext *pNewCtx)
|
---|
354 | {
|
---|
355 | CRMuralInfo *pCurrentMural = cr_server.currentMural;
|
---|
356 | CRContextInfo *pCurCtxInfo = cr_server.currentCtxInfo;
|
---|
357 | GLuint idDrawFBO, idReadFBO;
|
---|
358 | CRContext *pCurCtx = pCurCtxInfo ? pCurCtxInfo->pContext : NULL;
|
---|
359 |
|
---|
360 | CRASSERT(pCurCtx == crStateGetCurrent());
|
---|
361 |
|
---|
362 | if (pCurrentMural)
|
---|
363 | {
|
---|
364 | idDrawFBO = CR_SERVER_FBO_FOR_IDX(pCurrentMural, pCurrentMural->iCurDrawBuffer);
|
---|
365 | idReadFBO = CR_SERVER_FBO_FOR_IDX(pCurrentMural, pCurrentMural->iCurReadBuffer);
|
---|
366 | }
|
---|
367 | else
|
---|
368 | {
|
---|
369 | idDrawFBO = 0;
|
---|
370 | idReadFBO = 0;
|
---|
371 | }
|
---|
372 |
|
---|
373 | crStateSwitchPrepare(pNewCtx, pCurCtx, idDrawFBO, idReadFBO);
|
---|
374 |
|
---|
375 | pData->idDrawFBO = idDrawFBO;
|
---|
376 | pData->idReadFBO = idReadFBO;
|
---|
377 | pData->pNewCtx = pNewCtx;
|
---|
378 | pData->pOldCtx = pCurCtx;
|
---|
379 | }
|
---|
380 |
|
---|
381 | DECLINLINE(void) crServerCtxSwitchPostprocess(CR_SERVER_CTX_SWITCH *pData)
|
---|
382 | {
|
---|
383 | crStateSwitchPostprocess(pData->pOldCtx, pData->pNewCtx, pData->idDrawFBO, pData->idReadFBO);
|
---|
384 | }
|
---|
385 |
|
---|
386 | void crServerInitTmpCtxDispatch();
|
---|
387 |
|
---|
388 | //#define VBOX_WITH_CRSERVER_DUMPER
|
---|
389 | #ifdef VBOX_WITH_CRSERVER_DUMPER
|
---|
390 | void crServerDumpCheckTerm();
|
---|
391 | int crServerDumpCheckInit();
|
---|
392 | void crServerDumpBuffer(int idx);
|
---|
393 | void crServerDumpTextures();
|
---|
394 | void crServerDumpShader(GLint id);
|
---|
395 | void crServerDumpProgram(GLint id);
|
---|
396 | void crServerDumpCurrentProgram();
|
---|
397 | void crServerDumpFramesCheck();
|
---|
398 |
|
---|
399 | extern unsigned long g_CrDbgDumpDraw;
|
---|
400 | extern unsigned long g_CrDbgDumpDrawFramesSettings;
|
---|
401 | extern unsigned long g_CrDbgDumpDrawFramesAppliedSettings;
|
---|
402 | extern unsigned long g_CrDbgDumpDrawFramesCount;
|
---|
403 | bool crServerDumpFilter(unsigned long event);
|
---|
404 |
|
---|
405 | #define CR_SERVER_DUMP_F_DRAW_BUFF_ENTER 0x00000001
|
---|
406 | #define CR_SERVER_DUMP_F_DRAW_BUFF_LEAVE 0x00000002
|
---|
407 | #define CR_SERVER_DUMP_F_DRAW_TEX_ENTER 0x00000010
|
---|
408 | #define CR_SERVER_DUMP_F_DRAW_TEX_LEAVE 0x00000020
|
---|
409 | #define CR_SERVER_DUMP_F_DRAW_PROGRAM_ENTER 0x00000100
|
---|
410 | #define CR_SERVER_DUMP_F_DRAW_PROGRAM_LEAVE 0x00000200
|
---|
411 |
|
---|
412 | #define CR_SERVER_DUMP_F_DRAW_ALL (CR_SERVER_DUMP_F_DRAW_BUFF_ENTER | CR_SERVER_DUMP_F_DRAW_BUFF_LEAVE \
|
---|
413 | | CR_SERVER_DUMP_F_DRAW_TEX_ENTER | CR_SERVER_DUMP_F_DRAW_TEX_LEAVE \
|
---|
414 | | CR_SERVER_DUMP_F_DRAW_PROGRAM_ENTER | CR_SERVER_DUMP_F_DRAW_PROGRAM_LEAVE)
|
---|
415 |
|
---|
416 | #define CR_SERVER_DUMP_F_COMPILE_SHADER 0x00001000
|
---|
417 | #define CR_SERVER_DUMP_F_LINK_PROGRAM 0x00002000
|
---|
418 | #define CR_SERVER_DUMP_F_SWAPBUFFERS_ENTER 0x00010000
|
---|
419 | #define CR_SERVER_DUMP_F_SWAPBUFFERS_LEAVE 0x00020000
|
---|
420 |
|
---|
421 | #define CR_SERVER_DUMP_IF_ANY(_ev) ((g_CrDbgDumpDraw & (_ev)) && crServerDumpFilter((_ev)))
|
---|
422 |
|
---|
423 | #define CR_SERVER_DUMP_DRAW_ENTER() do { \
|
---|
424 | if (!CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_DRAW_BUFF_ENTER | CR_SERVER_DUMP_F_DRAW_TEX_ENTER | CR_SERVER_DUMP_F_DRAW_PROGRAM_ENTER)) break; \
|
---|
425 | crServerDumpCheckInit(); \
|
---|
426 | crDmpStrF(cr_server.Recorder.pDumper, "==> %s", __FUNCTION__); \
|
---|
427 | if (CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_DRAW_PROGRAM_ENTER)) { crServerDumpCurrentProgram(); } \
|
---|
428 | if (CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_DRAW_TEX_ENTER)) { crServerDumpTextures(); } \
|
---|
429 | if (CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_DRAW_BUFF_ENTER)) { crServerDumpBuffer(-1); } \
|
---|
430 | crDmpStrF(cr_server.Recorder.pDumper, "=================="); \
|
---|
431 | } while (0)
|
---|
432 |
|
---|
433 | #define CR_SERVER_DUMP_DRAW_LEAVE() do { \
|
---|
434 | if (!CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_DRAW_BUFF_LEAVE | CR_SERVER_DUMP_F_DRAW_TEX_LEAVE | CR_SERVER_DUMP_F_DRAW_PROGRAM_LEAVE)) break; \
|
---|
435 | crServerDumpCheckInit(); \
|
---|
436 | crDmpStrF(cr_server.Recorder.pDumper, "<== %s", __FUNCTION__); \
|
---|
437 | if (CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_DRAW_BUFF_LEAVE)) { crServerDumpBuffer(-1); } \
|
---|
438 | if (CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_DRAW_TEX_LEAVE)) { crServerDumpTextures(); } \
|
---|
439 | if (CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_DRAW_PROGRAM_LEAVE)) { crServerDumpCurrentProgram(); } \
|
---|
440 | crDmpStrF(cr_server.Recorder.pDumper, "=================="); \
|
---|
441 | } while (0)
|
---|
442 |
|
---|
443 | #define CR_SERVER_DUMP_COMPILE_SHADER(_id) do { \
|
---|
444 | if (!CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_COMPILE_SHADER)) break; \
|
---|
445 | crServerDumpCheckInit(); \
|
---|
446 | crServerDumpShader((_id)); \
|
---|
447 | } while (0)
|
---|
448 |
|
---|
449 | #define CR_SERVER_DUMP_LINK_PROGRAM(_id) do { \
|
---|
450 | if (!CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_LINK_PROGRAM)) break; \
|
---|
451 | crServerDumpCheckInit(); \
|
---|
452 | crServerDumpProgram((_id)); \
|
---|
453 | } while (0)
|
---|
454 |
|
---|
455 | #define CR_SERVER_DUMP_SWAPBUFFERS_ENTER() do { \
|
---|
456 | if (!g_CrDbgDumpDrawFramesCount && !CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_SWAPBUFFERS_ENTER)) break; \
|
---|
457 | crServerDumpCheckInit(); \
|
---|
458 | crDmpStrF(cr_server.Recorder.pDumper, "== %s", __FUNCTION__); \
|
---|
459 | if (CR_SERVER_DUMP_IF_ANY(CR_SERVER_DUMP_F_SWAPBUFFERS_ENTER)) { crServerDumpBuffer(CR_SERVER_FBO_BB_IDX(cr_server.currentMural)); } \
|
---|
460 | if (g_CrDbgDumpDrawFramesCount) { crServerDumpFramesCheck(); } \
|
---|
461 | } while (0)
|
---|
462 |
|
---|
463 | #define CR_SERVER_DUMP_SWAPBUFFERS_LEAVE() do {} while (0)
|
---|
464 | #else /* if !defined VBOX_WITH_CRSERVER_DUMPER */
|
---|
465 | #define CR_SERVER_DUMP_DRAW_ENTER() do {} while (0)
|
---|
466 | #define CR_SERVER_DUMP_DRAW_LEAVE() do {} while (0)
|
---|
467 | #define CR_SERVER_DUMP_COMPILE_SHADER(_id) do {} while (0)
|
---|
468 | #define CR_SERVER_DUMP_LINK_PROGRAM(_id) do {} while (0)
|
---|
469 | #define CR_SERVER_DUMP_SWAPBUFFERS_ENTER() do {} while (0)
|
---|
470 | #define CR_SERVER_DUMP_SWAPBUFFERS_LEAVE() do {} while (0)
|
---|
471 | #endif /* !VBOX_WITH_CRSERVER_DUMPER */
|
---|
472 |
|
---|
473 | RT_C_DECLS_END
|
---|
474 |
|
---|
475 | #endif /* CR_SERVER_H */
|
---|