VirtualBox

source: vbox/trunk/include/VBox/HostServices/VBoxCrOpenGLSvc.h@ 60981

Last change on this file since 60981 was 56291, checked in by vboxsync, 10 years ago

include: Updated (C) year.

  • Property svn:eol-style set to native
File size: 10.9 KB
Line 
1/** @file
2 * OpenGL:
3 * Common header for host service and guest clients.
4 */
5
6/*
7 * Copyright (C) 2006-2015 Oracle Corporation
8 *
9 * This file is part of VirtualBox Open Source Edition (OSE), as
10 * available from http://www.virtualbox.org. This file is free software;
11 * you can redistribute it and/or modify it under the terms of the GNU
12 * General Public License (GPL) as published by the Free Software
13 * Foundation, in version 2 as it comes in the "COPYING" file of the
14 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
15 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
16 *
17 * The contents of this file may alternatively be used under the terms
18 * of the Common Development and Distribution License Version 1.0
19 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
20 * VirtualBox OSE distribution, in which case the provisions of the
21 * CDDL are applicable instead of those of the GPL.
22 *
23 * You may elect to license modified versions of this file under the
24 * terms and conditions of either the GPL or the CDDL or both.
25 */
26
27#ifndef ___VBox_HostService_VBoxCrOpenGLSvc_h
28#define ___VBox_HostService_VBoxCrOpenGLSvc_h
29
30#include <VBox/types.h>
31#include <VBox/VMMDev.h>
32#include <VBox/VBoxGuest2.h>
33#include <VBox/hgcmsvc.h>
34#include <VBox/VBoxVideo.h>
35#include <VBox/VBoxVideoHost3D.h>
36
37/* crOpenGL host functions */
38#define SHCRGL_HOST_FN_SET_CONSOLE (1)
39#define SHCRGL_HOST_FN_SET_VISIBLE_REGION (5)
40#define SHCRGL_HOST_FN_SET_VM (7)
41#define SHCRGL_HOST_FN_SCREEN_CHANGED (8)
42#ifdef VBOX_WITH_CRHGSMI
43#define SHCRGL_HOST_FN_CRHGSMI_CMD (10)
44#define SHCRGL_HOST_FN_CRHGSMI_CTL (11)
45#endif
46#define SHCRGL_HOST_FN_VIEWPORT_CHANGED (15)
47#define SHCRGL_HOST_FN_SET_OUTPUT_REDIRECT (20)
48#define SHCRGL_HOST_FN_DEV_RESIZE (22)
49#define SHCRGL_HOST_FN_VIEWPORT_CHANGED2 (23)
50#define SHCRGL_HOST_FN_TAKE_SCREENSHOT (24)
51#define SHCRGL_HOST_FN_WINDOWS_SHOW (25)
52#define SHCRGL_HOST_FN_CTL (26)
53#define SHCRGL_HOST_FN_SET_SCALE_FACTOR (27)
54#define SHCRGL_HOST_FN_SET_UNSCALED_HIDPI (28)
55
56/* crOpenGL guest functions */
57#define SHCRGL_GUEST_FN_WRITE (2)
58#define SHCRGL_GUEST_FN_READ (3)
59#define SHCRGL_GUEST_FN_WRITE_READ (4)
60#define SHCRGL_GUEST_FN_SET_VERSION (6)
61#define SHCRGL_GUEST_FN_INJECT (9)
62#define SHCRGL_GUEST_FN_SET_PID (12)
63#define SHCRGL_GUEST_FN_WRITE_BUFFER (13)
64#define SHCRGL_GUEST_FN_WRITE_READ_BUFFERED (14)
65#define SHCRGL_GUEST_FN_GET_CAPS_LEGACY (15)
66#define SHCRGL_GUEST_FN_GET_CAPS_NEW (16)
67
68/* Parameters count */
69#define SHCRGL_CPARMS_SET_CONSOLE (1)
70#define SHCRGL_CPARMS_SET_VM (1)
71#define SHCRGL_CPARMS_SET_VISIBLE_REGION (1)
72#define SHCRGL_CPARMS_WRITE (1)
73#define SHCRGL_CPARMS_READ (2)
74#define SHCRGL_CPARMS_WRITE_READ (3)
75#define SHCRGL_CPARMS_SET_VERSION (2)
76#define SHCRGL_CPARMS_SCREEN_CHANGED (1)
77#define SHCRGL_CPARMS_DEV_RESIZE (1)
78#define SHCRGL_CPARMS_INJECT (2)
79#define SHCRGL_CPARMS_SET_PID (1)
80#define SHCRGL_CPARMS_WRITE_BUFFER (4)
81#define SHCRGL_CPARMS_WRITE_READ_BUFFERED (3)
82#define SHCRGL_CPARMS_SET_OUTPUT_REDIRECT (1)
83#define SHCRGL_CPARMS_CRCMD_NOTIFY_CMDS (0)
84#define SHCRGL_CPARMS_VIEWPORT_CHANGED (5)
85#define SHCRGL_CPARMS_VIEWPORT_CHANGED2 (1)
86#define SHCRGL_CPARMS_GET_CAPS_LEGACY (1)
87#define SHCRGL_CPARMS_GET_CAPS_NEW (1)
88
89/* @todo Move to H3DOR.h begin */
90
91/* Names of supported output redirect formats. */
92#define H3DOR_FMT_RGBA_TOPDOWN "H3DOR_FMT_RGBA_TOPDOWN"
93#define H3DOR_FMT_RGBA "H3DOR_FMT_RGBA"
94
95/* Comma separated list of output formats supported by the output redirect target. */
96#define H3DOR_PROP_FORMATS 0
97
98#pragma pack(1)
99typedef struct {
100 /* The caller's context of the redirection. */
101 const void *pvContext;
102 /* Inform caller that a new window will be redirected. */
103 DECLR3CALLBACKMEMBER(void, H3DORBegin, (const void *pvContext, void **ppvInstance,
104 const char *pszFormat));
105 /* The window dimension has been changed. */
106 DECLR3CALLBACKMEMBER(void, H3DORGeometry, (void *pvInstance,
107 int32_t x, int32_t y, uint32_t w, uint32_t h));
108 /* Update the window visible region. */
109 DECLR3CALLBACKMEMBER(void, H3DORVisibleRegion, (void *pvInstance,
110 uint32_t cRects, const RTRECT *paRects));
111 /* A rendered 3D frame is ready. Format of pvData is "pszFormat" parameter of H3DORBegin. */
112 DECLR3CALLBACKMEMBER(void, H3DORFrame, (void *pvInstance,
113 void *pvData, uint32_t cbData));
114 /* The window is closed. */
115 DECLR3CALLBACKMEMBER(void, H3DOREnd, (void *pvInstance));
116 /* Obtain caller's parameters: the list of supported formats, etc. */
117 DECLR3CALLBACKMEMBER(int, H3DORContextProperty, (const void *pvContext, uint32_t index,
118 void *pvBuffer, uint32_t cbBuffer, uint32_t *pcbOut));
119} H3DOUTPUTREDIRECT;
120#pragma pack()
121
122/* @todo Move to H3DOR.h end */
123
124#ifdef VBOX_WITH_CRHGSMI
125#pragma pack(1)
126typedef struct
127{
128 int32_t result; /**< OUT Host HGSMI return code.*/
129 uint32_t u32ClientID; /**< IN The id of the caller. */
130 uint32_t u32Function; /**< IN Function number. */
131 uint32_t u32Reserved;
132} CRVBOXHGSMIHDR;
133AssertCompileSize(CRVBOXHGSMIHDR, 16);
134
135/** GUEST_FN_WRITE Parameters structure. */
136typedef struct
137{
138 CRVBOXHGSMIHDR hdr;
139 /** buffer index, in
140 * Data buffer
141 */
142 uint32_t iBuffer;
143} CRVBOXHGSMIWRITE;
144
145/** GUEST_FN_READ Parameters structure. */
146typedef struct
147{
148 CRVBOXHGSMIHDR hdr;
149
150 /** buffer index, in/out
151 * Data buffer
152 */
153 uint32_t iBuffer;
154 uint32_t cbBuffer;
155} CRVBOXHGSMIREAD;
156
157/** GUEST_FN_WRITE_READ Parameters structure. */
158typedef struct
159{
160 CRVBOXHGSMIHDR hdr;
161
162 /** buffer index, in
163 * Data buffer
164 */
165 uint32_t iBuffer;
166
167 /** buffer index, out
168 * Writeback buffer
169 */
170 uint32_t iWriteback;
171 uint32_t cbWriteback;
172} CRVBOXHGSMIWRITEREAD;
173
174/** GUEST_FN_SET_VERSION Parameters structure. */
175typedef struct
176{
177 CRVBOXHGSMIHDR hdr;
178
179 /** 32bit, in
180 * Major version
181 */
182 uint32_t vMajor;
183
184 /** 32bit, in
185 * Minor version
186 */
187 uint32_t vMinor;
188} CRVBOXHGSMISETVERSION;
189
190/** GUEST_FN_INJECT Parameters structure. */
191typedef struct
192{
193 CRVBOXHGSMIHDR hdr;
194
195 /** 32bit, in
196 * ClientID to inject commands buffer for
197 */
198 uint32_t u32ClientID;
199 /** buffer index, in
200 * Data buffer
201 */
202 uint32_t iBuffer;
203} CRVBOXHGSMIINJECT;
204
205/** GUEST_FN_SET_PID Parameters structure. */
206typedef struct
207{
208 CRVBOXHGSMIHDR hdr;
209
210 /** 64bit, in
211 * PID
212 */
213 uint64_t u64PID;
214} CRVBOXHGSMISETPID;
215
216#pragma pack()
217#endif
218/**
219 * SHCRGL_GUEST_FN_WRITE
220 */
221
222/** GUEST_FN_WRITE Parameters structure. */
223typedef struct
224{
225 VBoxGuestHGCMCallInfo hdr;
226
227 /** pointer, in
228 * Data buffer
229 */
230 HGCMFunctionParameter pBuffer;
231} CRVBOXHGCMWRITE;
232
233/** GUEST_FN_READ Parameters structure. */
234typedef struct
235{
236 VBoxGuestHGCMCallInfo hdr;
237
238 /** pointer, in/out
239 * Data buffer
240 */
241 HGCMFunctionParameter pBuffer;
242
243 /** 32bit, out
244 * Count of bytes written to buffer
245 */
246 HGCMFunctionParameter cbBuffer;
247
248} CRVBOXHGCMREAD;
249
250/** GUEST_FN_WRITE_READ Parameters structure. */
251typedef struct
252{
253 VBoxGuestHGCMCallInfo hdr;
254
255 /** pointer, in
256 * Data buffer
257 */
258 HGCMFunctionParameter pBuffer;
259
260 /** pointer, out
261 * Writeback buffer
262 */
263 HGCMFunctionParameter pWriteback;
264
265 /** 32bit, out
266 * Count of bytes written to writeback buffer
267 */
268 HGCMFunctionParameter cbWriteback;
269
270} CRVBOXHGCMWRITEREAD;
271
272/** GUEST_FN_SET_VERSION Parameters structure. */
273typedef struct
274{
275 VBoxGuestHGCMCallInfo hdr;
276
277 /** 32bit, in
278 * Major version
279 */
280 HGCMFunctionParameter vMajor;
281
282 /** 32bit, in
283 * Minor version
284 */
285 HGCMFunctionParameter vMinor;
286
287} CRVBOXHGCMSETVERSION;
288
289/** GUEST_FN_GET_CAPS Parameters structure. */
290typedef struct
291{
292 VBoxGuestHGCMCallInfo hdr;
293
294 /** 32bit, out
295 * Caps
296 */
297 HGCMFunctionParameter Caps;
298} CRVBOXHGCMGETCAPS;
299
300/** GUEST_FN_INJECT Parameters structure. */
301typedef struct
302{
303 VBoxGuestHGCMCallInfo hdr;
304
305 /** 32bit, in
306 * ClientID to inject commands buffer for
307 */
308 HGCMFunctionParameter u32ClientID;
309 /** pointer, in
310 * Data buffer
311 */
312 HGCMFunctionParameter pBuffer;
313} CRVBOXHGCMINJECT;
314
315/** GUEST_FN_SET_PID Parameters structure. */
316typedef struct
317{
318 VBoxGuestHGCMCallInfo hdr;
319
320 /** 64bit, in
321 * PID
322 */
323 HGCMFunctionParameter u64PID;
324} CRVBOXHGCMSETPID;
325
326/** GUEST_FN_WRITE_BUFFER Parameters structure. */
327typedef struct
328{
329 VBoxGuestHGCMCallInfo hdr;
330
331 /** 32bit, in/out
332 * Buffer id, 0 means host have to allocate one
333 */
334 HGCMFunctionParameter iBufferID;
335
336 /** 32bit, in
337 * Buffer size
338 */
339 HGCMFunctionParameter cbBufferSize;
340
341 /** 32bit, in
342 * Write offset in buffer
343 */
344 HGCMFunctionParameter ui32Offset;
345
346 /** pointer, in
347 * Data buffer
348 */
349 HGCMFunctionParameter pBuffer;
350
351} CRVBOXHGCMWRITEBUFFER;
352
353/** GUEST_FN_WRITE_READ_BUFFERED Parameters structure. */
354typedef struct
355{
356 VBoxGuestHGCMCallInfo hdr;
357
358 /** 32bit, in
359 * Buffer id.
360 */
361 HGCMFunctionParameter iBufferID;
362
363 /** pointer, out
364 * Writeback buffer
365 */
366 HGCMFunctionParameter pWriteback;
367
368 /** 32bit, out
369 * Count of bytes written to writeback buffer
370 */
371 HGCMFunctionParameter cbWriteback;
372
373} CRVBOXHGCMWRITEREADBUFFERED;
374
375
376typedef struct
377{
378 VBVAINFOSCREEN Screen;
379 void *pvVRAM;
380} CRVBOXHGCMDEVRESIZE;
381
382typedef struct
383{
384 uint32_t u32Screen;
385 uint32_t x;
386 uint32_t y;
387 uint32_t width;
388 uint32_t height;
389} CRVBOXHGCMVIEWPORT;
390
391typedef DECLCALLBACKPTR(void, PFNCRSCREENSHOTREPORT)(void *pvCtx, uint32_t uScreen,
392 uint32_t x, uint32_t y, uint32_t uBitsPerPixel,
393 uint32_t uBytesPerLine, uint32_t uGuestWidth, uint32_t uGuestHeight,
394 uint8_t *pu8BufferAddress, uint64_t u64TimeStamp);
395
396typedef DECLCALLBACKPTR(bool, PFNCRSCREENSHOTBEGIN)(void *pvCtx, uint32_t uScreen, uint64_t u64TimeStamp);
397typedef DECLCALLBACKPTR(void, PFNCRSCREENSHOTEND)(void *pvCtx, uint32_t uScreen, uint64_t u64TimeStamp);
398
399#define CRSCREEN_ALL (0xffffffff)
400
401typedef struct
402{
403 /* screen id or CRSCREEN_ALL to specify all enabled */
404 uint32_t u32Screen;
405 uint32_t u32Width;
406 uint32_t u32Height;
407 uint32_t u32Pitch;
408 void *pvBuffer;
409 void *pvContext;
410 PFNCRSCREENSHOTBEGIN pfnScreenshotBegin;
411 PFNCRSCREENSHOTREPORT pfnScreenshotPerform;
412 PFNCRSCREENSHOTEND pfnScreenshotEnd;
413} CRVBOXHGCMTAKESCREENSHOT;
414
415typedef struct
416{
417 uint32_t u32Screen;
418 uint32_t u32ScaleFactorWMultiplied;
419 uint32_t u32ScaleFactorHMultiplied;
420} CRVBOXHGCMSETSCALEFACTOR;
421
422typedef struct
423{
424 bool fUnscaledHiDPI;
425} CRVBOXHGCMSETUNSCALEDHIDPIOUTPUT;
426
427#endif
Note: See TracBrowser for help on using the repository browser.

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