VirtualBox

source: vbox/trunk/include/VBox/Graphics/VBoxVideoHost3D.h@ 69028

Last change on this file since 69028 was 69015, checked in by vboxsync, 7 years ago

Fix up header files for graphics hardware.
bugref:9017: Additions/x11: put vboxvideo into upstream X.Org

Make sure that all graphics hardware header files have svn Id tags to be
able to match X.Org files with VirtualBox revisions.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 6.8 KB
Line 
1/* $Id: VBoxVideoHost3D.h 69015 2017-10-09 12:50:34Z vboxsync $ */
2/** @file
3 * VirtualBox 3D host inter-components interfaces
4 */
5
6/*
7 * Copyright (C) 2011-2016 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_Graphics_VBoxVideoHost3D_h
28#define ___VBox_Graphics_VBoxVideoHost3D_h
29
30#include <iprt/cdefs.h>
31#include "VBoxVideo.h"
32#include <VBox/hgcmsvc.h>
33#include <VBox/vmm/pdmifs.h>
34#include <iprt/list.h>
35
36/* screen update instance */
37typedef struct PDMIDISPLAYCONNECTOR *HVBOXCRCMDCLTSCR;
38struct VBVACMDHDR;
39
40typedef struct VBOXCMDVBVA_HDR *PVBOXCMDVBVA_HDR;
41
42typedef DECLCALLBACKPTR(void, PFNVBOXCRCMD_CLTSCR_UPDATE_BEGIN)(HVBOXCRCMDCLTSCR hClt, unsigned u32Screen);
43typedef DECLCALLBACKPTR(void, PFNVBOXCRCMD_CLTSCR_UPDATE_END)(HVBOXCRCMDCLTSCR hClt, unsigned uScreenId, int32_t x, int32_t y, uint32_t cx, uint32_t cy);
44typedef DECLCALLBACKPTR(void, PFNVBOXCRCMD_CLTSCR_UPDATE_PROCESS)(HVBOXCRCMDCLTSCR hClt, unsigned u32Screen, const struct VBVACMDHDR *pCmd, size_t cbCmd);
45
46/*client callbacks to be used by the server
47 * when working in the CrCmd mode */
48typedef struct VBOXCRCMD_SVRENABLE_INFO
49{
50 HVBOXCRCMDCLTSCR hCltScr;
51 PFNVBOXCRCMD_CLTSCR_UPDATE_BEGIN pfnCltScrUpdateBegin;
52 PFNVBOXCRCMD_CLTSCR_UPDATE_PROCESS pfnCltScrUpdateProcess;
53 PFNVBOXCRCMD_CLTSCR_UPDATE_END pfnCltScrUpdateEnd;
54} VBOXCRCMD_SVRENABLE_INFO;
55
56typedef struct VBOXVDMAHOST * HVBOXCRCLIENT;
57struct VBOXCRCMDCTL_CALLOUT_LISTENTRY;
58typedef DECLCALLBACKPTR(void, PFNVBOXCRCMDCTL_CALLOUT_CB)(struct VBOXCRCMDCTL_CALLOUT_LISTENTRY *pEntry);
59
60#pragma pack(1)
61typedef struct VBOXCRCMDCTL_CALLOUT_LISTENTRY
62{
63 RTLISTNODE Node;
64 PFNVBOXCRCMDCTL_CALLOUT_CB pfnCb;
65} VBOXCRCMDCTL_CALLOUT_LISTENTRY;
66
67typedef struct VBOXCRCMDCTL_CALLOUT_LIST
68{
69 RTLISTANCHOR List;
70} VBOXCRCMDCTL_CALLOUT_LIST;
71#pragma pack()
72
73struct VBOXCRCMDCTL;
74
75typedef DECLCALLBACKPTR(int, PFNVBOXCRCLIENT_CALLOUT)(HVBOXCRCLIENT hClient, struct VBOXCRCMDCTL* pCmd, VBOXCRCMDCTL_CALLOUT_LISTENTRY *pEntry, PFNVBOXCRCMDCTL_CALLOUT_CB pfnCb);
76
77typedef struct VBOXCRCLIENT_INFO
78{
79 HVBOXCRCLIENT hClient;
80 PFNVBOXCRCLIENT_CALLOUT pfnCallout;
81} VBOXCRCLIENT_INFO;
82
83typedef void * HVBOXCRCMDSVR;
84
85/* enables the CrCmd interface, thus the hgcm interface gets disabled.
86 * all subsequent calls will be done in the thread Enable was done,
87 * until the Disable is called */
88typedef DECLCALLBACKPTR(int, PFNVBOXCRCMD_SVR_ENABLE)(HVBOXCRCMDSVR hSvr, VBOXCRCMD_SVRENABLE_INFO *pInfo);
89/* Opposite to Enable (see above) */
90typedef DECLCALLBACKPTR(int, PFNVBOXCRCMD_SVR_DISABLE)(HVBOXCRCMDSVR hSvr);
91/* process command */
92typedef DECLCALLBACKPTR(int8_t, PFNVBOXCRCMD_SVR_CMD)(HVBOXCRCMDSVR hSvr, const VBOXCMDVBVA_HDR *pCmd, uint32_t cbCmd);
93/* process host control */
94typedef DECLCALLBACKPTR(int, PFNVBOXCRCMD_SVR_HOSTCTL)(HVBOXCRCMDSVR hSvr, uint8_t* pCtl, uint32_t cbCmd);
95/* process guest control */
96typedef DECLCALLBACKPTR(int, PFNVBOXCRCMD_SVR_GUESTCTL)(HVBOXCRCMDSVR hSvr, uint8_t* pCtl, uint32_t cbCmd);
97/* screen resize */
98typedef DECLCALLBACKPTR(int, PFNVBOXCRCMD_SVR_RESIZE)(HVBOXCRCMDSVR hSvr, const struct VBVAINFOSCREEN *pScreen, const uint32_t *pTargetMap);
99/* process SaveState */
100typedef DECLCALLBACKPTR(int, PFNVBOXCRCMD_SVR_SAVESTATE)(HVBOXCRCMDSVR hSvr, PSSMHANDLE pSSM);
101/* process LoadState */
102typedef DECLCALLBACKPTR(int, PFNVBOXCRCMD_SVR_LOADSTATE)(HVBOXCRCMDSVR hSvr, PSSMHANDLE pSSM, uint32_t u32Version);
103
104
105typedef struct VBOXCRCMD_SVRINFO
106{
107 HVBOXCRCMDSVR hSvr;
108 PFNVBOXCRCMD_SVR_ENABLE pfnEnable;
109 PFNVBOXCRCMD_SVR_DISABLE pfnDisable;
110 PFNVBOXCRCMD_SVR_CMD pfnCmd;
111 PFNVBOXCRCMD_SVR_HOSTCTL pfnHostCtl;
112 PFNVBOXCRCMD_SVR_GUESTCTL pfnGuestCtl;
113 PFNVBOXCRCMD_SVR_RESIZE pfnResize;
114 PFNVBOXCRCMD_SVR_SAVESTATE pfnSaveState;
115 PFNVBOXCRCMD_SVR_LOADSTATE pfnLoadState;
116} VBOXCRCMD_SVRINFO;
117
118
119typedef struct VBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP
120{
121 VBOXVDMACMD_CHROMIUM_CTL Hdr;
122 union
123 {
124 void *pvVRamBase;
125 uint64_t uAlignment;
126 };
127 uint64_t cbVRam;
128 PPDMLED pLed;
129 VBOXCRCLIENT_INFO CrClientInfo;
130 /* out */
131 struct VBOXCRCMD_SVRINFO CrCmdServerInfo;
132} VBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP, *PVBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP;
133
134typedef enum
135{
136 VBOXCRCMDCTL_TYPE_HGCM = 1,
137 VBOXCRCMDCTL_TYPE_DISABLE,
138 VBOXCRCMDCTL_TYPE_ENABLE,
139 VBOXCRCMDCTL_TYPE_32bit = 0x7fffffff
140} VBOXCRCMDCTL_TYPE;
141
142#pragma pack(1)
143
144typedef struct VBOXCRCMDCTL
145{
146 VBOXCRCMDCTL_TYPE enmType;
147 uint32_t u32Function;
148 /* not to be used by clients */
149 VBOXCRCMDCTL_CALLOUT_LIST CalloutList;
150 union
151 {
152 void (*pfnInternal)(void);
153 void *pvInternal;
154 } u;
155} VBOXCRCMDCTL;
156
157#define VBOXCRCMDCTL_IS_CALLOUT_AVAILABLE(_pCtl) (!!((_pCtl)->CalloutList.List.pNext))
158
159typedef struct VBOXCRCMDCTL_HGCM
160{
161 VBOXCRCMDCTL Hdr;
162 VBOXHGCMSVCPARM aParms[1];
163} VBOXCRCMDCTL_HGCM;
164#pragma pack()
165
166typedef struct VBOXVDMAHOST * HVBOXCRCMDCTL_REMAINING_HOST_COMMAND;
167
168typedef DECLCALLBACKPTR(uint8_t*, PFNVBOXCRCMDCTL_REMAINING_HOST_COMMAND)(HVBOXCRCMDCTL_REMAINING_HOST_COMMAND hClient, uint32_t *pcbCtl, int prevCmdRc);
169
170typedef struct VBOXCRCMDCTL_HGCMENABLE_DATA
171{
172 HVBOXCRCMDCTL_REMAINING_HOST_COMMAND hRHCmd;
173 PFNVBOXCRCMDCTL_REMAINING_HOST_COMMAND pfnRHCmd;
174} VBOXCRCMDCTL_HGCMENABLE_DATA;
175
176typedef struct VBOXVDMAHOST * HVBOXCRCMDCTL_NOTIFY_TERMINATING;
177
178typedef DECLCALLBACKPTR(int, PFNVBOXCRCMDCTL_NOTIFY_TERMINATING)(HVBOXCRCMDCTL_NOTIFY_TERMINATING hClient, VBOXCRCMDCTL_HGCMENABLE_DATA *pHgcmEnableData);
179
180typedef DECLCALLBACKPTR(void, PFNVBOXCRCMDCTL_NOTIFY_TERMINATING_DONE)(HVBOXCRCMDCTL_NOTIFY_TERMINATING hClient);
181
182typedef struct VBOXCRCMDCTL_HGCMDISABLE_DATA
183{
184 HVBOXCRCMDCTL_NOTIFY_TERMINATING hNotifyTerm;
185 PFNVBOXCRCMDCTL_NOTIFY_TERMINATING pfnNotifyTerm;
186 PFNVBOXCRCMDCTL_NOTIFY_TERMINATING_DONE pfnNotifyTermDone;
187} VBOXCRCMDCTL_HGCMDISABLE_DATA;
188
189#pragma pack(1)
190typedef struct VBOXCRCMDCTL_ENABLE
191{
192 VBOXCRCMDCTL Hdr;
193 VBOXCRCMDCTL_HGCMENABLE_DATA Data;
194} VBOXCRCMDCTL_ENABLE;
195
196typedef struct VBOXCRCMDCTL_DISABLE
197{
198 VBOXCRCMDCTL Hdr;
199 VBOXCRCMDCTL_HGCMDISABLE_DATA Data;
200} VBOXCRCMDCTL_DISABLE;
201#pragma pack()
202
203#endif
204
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