VirtualBox

source: vbox/trunk/include/VBox/ExtPack/ExtPack.h@ 70064

Last change on this file since 70064 was 68828, checked in by vboxsync, 7 years ago

ExtPack: Split up main module of extension pack, have a mandatory one for VBoxSVC and an optional one for the VM process. This finally eliminates the need to drag VBoxVMM into VBoxSVC on some platforms. Many other small cleanups, including reliably calling the unload hook from within a VM process, copy/paste with forgotten adjustments (e.g. extpacks still talking about skeleton) and spelling fixes.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 19.4 KB
Line 
1/** @file
2 * VirtualBox - Extension Pack Interface.
3 */
4
5/*
6 * Copyright (C) 2010-2017 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___VBox_ExtPack_ExtPack_h
27#define ___VBox_ExtPack_ExtPack_h
28
29#include <VBox/types.h>
30
31/** @def VBOXEXTPACK_IF_CS
32 * Selects 'class' on 'struct' for interface references.
33 * @param I The interface name
34 */
35#if defined(__cplusplus) && !defined(RT_OS_WINDOWS)
36# define VBOXEXTPACK_IF_CS(I) class I
37#else
38# define VBOXEXTPACK_IF_CS(I) struct I
39#endif
40
41VBOXEXTPACK_IF_CS(IConsole);
42VBOXEXTPACK_IF_CS(IMachine);
43VBOXEXTPACK_IF_CS(IVirtualBox);
44
45/**
46 * Module kind for use with VBOXEXTPACKHLP::pfnFindModule.
47 */
48typedef enum VBOXEXTPACKMODKIND
49{
50 /** Zero is invalid as always. */
51 VBOXEXTPACKMODKIND_INVALID = 0,
52 /** Raw-mode context module. */
53 VBOXEXTPACKMODKIND_RC,
54 /** Ring-0 context module. */
55 VBOXEXTPACKMODKIND_R0,
56 /** Ring-3 context module. */
57 VBOXEXTPACKMODKIND_R3,
58 /** End of the valid values (exclusive). */
59 VBOXEXTPACKMODKIND_END,
60 /** The usual 32-bit type hack. */
61 VBOXEXTPACKMODKIND_32BIT_HACK = 0x7fffffff
62} VBOXEXTPACKMODKIND;
63
64/**
65 * Contexts returned by VBOXEXTPACKHLP::pfnGetContext.
66 */
67typedef enum VBOXEXTPACKCTX
68{
69 /** Zero is invalid as always. */
70 VBOXEXTPACKCTX_INVALID = 0,
71 /** The per-user daemon process (VBoxSVC). */
72 VBOXEXTPACKCTX_PER_USER_DAEMON,
73 /** A VM process. */
74 VBOXEXTPACKCTX_VM_PROCESS,
75 /** An API client process.
76 * @remarks This will not be returned by VirtualBox yet. */
77 VBOXEXTPACKCTX_CLIENT_PROCESS,
78 /** End of the valid values (exclusive). */
79 VBOXEXTPACKCTX_END,
80 /** The usual 32-bit type hack. */
81 VBOXEXTPACKCTX_32BIT_HACK = 0x7fffffff
82} VBOXEXTPACKCTX;
83
84
85/** Pointer to const helpers passed to the VBoxExtPackRegister() call. */
86typedef const struct VBOXEXTPACKHLP *PCVBOXEXTPACKHLP;
87/**
88 * Extension pack helpers passed to VBoxExtPackRegister().
89 *
90 * This will be valid until the module is unloaded.
91 */
92typedef struct VBOXEXTPACKHLP
93{
94 /** Interface version.
95 * This is set to VBOXEXTPACKHLP_VERSION. */
96 uint32_t u32Version;
97
98 /** The VirtualBox full version (see VBOX_FULL_VERSION). */
99 uint32_t uVBoxFullVersion;
100 /** The VirtualBox subversion tree revision. */
101 uint32_t uVBoxInternalRevision;
102 /** Explicit alignment padding, must be zero. */
103 uint32_t u32Padding;
104 /** Pointer to the version string (read-only). */
105 const char *pszVBoxVersion;
106
107 /**
108 * Finds a module belonging to this extension pack.
109 *
110 * @returns VBox status code.
111 * @param pHlp Pointer to this helper structure.
112 * @param pszName The module base name.
113 * @param pszExt The extension. If NULL the default ring-3
114 * library extension will be used.
115 * @param enmKind The kind of module to locate.
116 * @param pszFound Where to return the path to the module on
117 * success.
118 * @param cbFound The size of the buffer @a pszFound points to.
119 * @param pfNative Where to return the native/agnostic indicator.
120 */
121 DECLR3CALLBACKMEMBER(int, pfnFindModule,(PCVBOXEXTPACKHLP pHlp, const char *pszName, const char *pszExt,
122 VBOXEXTPACKMODKIND enmKind,
123 char *pszFound, size_t cbFound, bool *pfNative));
124
125 /**
126 * Gets the path to a file belonging to this extension pack.
127 *
128 * @returns VBox status code.
129 * @retval VERR_INVALID_POINTER if any of the pointers are invalid.
130 * @retval VERR_BUFFER_OVERFLOW if the buffer is too small. The buffer
131 * will contain nothing.
132 *
133 * @param pHlp Pointer to this helper structure.
134 * @param pszFilename The filename.
135 * @param pszPath Where to return the path to the file on
136 * success.
137 * @param cbPath The size of the buffer @a pszPath.
138 */
139 DECLR3CALLBACKMEMBER(int, pfnGetFilePath,(PCVBOXEXTPACKHLP pHlp, const char *pszFilename, char *pszPath, size_t cbPath));
140
141 /**
142 * Gets the context the extension pack is operating in.
143 *
144 * @returns The context.
145 * @retval VBOXEXTPACKCTX_INVALID if @a pHlp is invalid.
146 *
147 * @param pHlp Pointer to this helper structure.
148 */
149 DECLR3CALLBACKMEMBER(VBOXEXTPACKCTX, pfnGetContext,(PCVBOXEXTPACKHLP pHlp));
150
151 /**
152 * Loads a HGCM service provided by an extension pack.
153 *
154 * @returns VBox status code.
155 * @param pHlp Pointer to this helper structure.
156 * @param pConsole Pointer to the VM's console object.
157 * @param pszServiceLibrary Name of the library file containing the
158 * service implementation, without extension.
159 * @param pszServiceName Name of HGCM service.
160 */
161 DECLR3CALLBACKMEMBER(int, pfnLoadHGCMService,(PCVBOXEXTPACKHLP pHlp, VBOXEXTPACK_IF_CS(IConsole) *pConsole,
162 const char *pszServiceLibrary, const char *pszServiceName));
163
164 /**
165 * Loads a VD plugin provided by an extension pack.
166 *
167 * This makes sense only in the context of the per-user service (VBoxSVC).
168 *
169 * @returns VBox status code.
170 * @param pHlp Pointer to this helper structure.
171 * @param pVirtualBox Pointer to the VirtualBox object.
172 * @param pszPluginLibrary Name of the library file containing the plugin
173 * implementation, without extension.
174 */
175 DECLR3CALLBACKMEMBER(int, pfnLoadVDPlugin,(PCVBOXEXTPACKHLP pHlp, VBOXEXTPACK_IF_CS(IVirtualBox) *pVirtualBox,
176 const char *pszPluginLibrary));
177
178 /**
179 * Unloads a VD plugin provided by an extension pack.
180 *
181 * This makes sense only in the context of the per-user service (VBoxSVC).
182 *
183 * @returns VBox status code.
184 * @param pHlp Pointer to this helper structure.
185 * @param pVirtualBox Pointer to the VirtualBox object.
186 * @param pszPluginLibrary Name of the library file containing the plugin
187 * implementation, without extension.
188 */
189 DECLR3CALLBACKMEMBER(int, pfnUnloadVDPlugin,(PCVBOXEXTPACKHLP pHlp, VBOXEXTPACK_IF_CS(IVirtualBox) *pVirtualBox,
190 const char *pszPluginLibrary));
191
192 DECLR3CALLBACKMEMBER(int, pfnReserved1,(PCVBOXEXTPACKHLP pHlp)); /**< Reserved for minor structure revisions. */
193 DECLR3CALLBACKMEMBER(int, pfnReserved2,(PCVBOXEXTPACKHLP pHlp)); /**< Reserved for minor structure revisions. */
194 DECLR3CALLBACKMEMBER(int, pfnReserved3,(PCVBOXEXTPACKHLP pHlp)); /**< Reserved for minor structure revisions. */
195 DECLR3CALLBACKMEMBER(int, pfnReserved4,(PCVBOXEXTPACKHLP pHlp)); /**< Reserved for minor structure revisions. */
196 DECLR3CALLBACKMEMBER(int, pfnReserved5,(PCVBOXEXTPACKHLP pHlp)); /**< Reserved for minor structure revisions. */
197 DECLR3CALLBACKMEMBER(int, pfnReserved6,(PCVBOXEXTPACKHLP pHlp)); /**< Reserved for minor structure revisions. */
198
199 /** End of structure marker (VBOXEXTPACKHLP_VERSION). */
200 uint32_t u32EndMarker;
201} VBOXEXTPACKHLP;
202/** Current version of the VBOXEXTPACKHLP structure. */
203#define VBOXEXTPACKHLP_VERSION RT_MAKE_U32(2, 1)
204
205
206/** Pointer to the extension pack callback table. */
207typedef struct VBOXEXTPACKREG const *PCVBOXEXTPACKREG;
208/**
209 * Callback table returned by VBoxExtPackRegister.
210 *
211 * All the callbacks are called the context of the per-user service (VBoxSVC).
212 *
213 * This must be valid until the extension pack main module is unloaded.
214 */
215typedef struct VBOXEXTPACKREG
216{
217 /** Interface version.
218 * This is set to VBOXEXTPACKREG_VERSION. */
219 uint32_t u32Version;
220 /** The VirtualBox version this extension pack was built against. */
221 uint32_t uVBoxVersion;
222
223 /**
224 * Hook for doing setups after the extension pack was installed.
225 *
226 * @returns VBox status code.
227 * @retval VERR_EXTPACK_UNSUPPORTED_HOST_UNINSTALL if the extension pack
228 * requires some different host version or a prerequisite is
229 * missing from the host. Automatic uninstall will be attempted.
230 * Must set error info.
231 *
232 * @param pThis Pointer to this structure.
233 * @param pVirtualBox The VirtualBox interface.
234 * @param pErrInfo Where to return extended error information.
235 */
236 DECLCALLBACKMEMBER(int, pfnInstalled)(PCVBOXEXTPACKREG pThis, VBOXEXTPACK_IF_CS(IVirtualBox) *pVirtualBox,
237 PRTERRINFO pErrInfo);
238
239 /**
240 * Hook for cleaning up before the extension pack is uninstalled.
241 *
242 * @returns VBox status code.
243 * @param pThis Pointer to this structure.
244 * @param pVirtualBox The VirtualBox interface.
245 *
246 * @todo This is currently called holding locks making pVirtualBox
247 * relatively unusable.
248 */
249 DECLCALLBACKMEMBER(int, pfnUninstall)(PCVBOXEXTPACKREG pThis, VBOXEXTPACK_IF_CS(IVirtualBox) *pVirtualBox);
250
251 /**
252 * Hook for doing work after the VirtualBox object is ready.
253 *
254 * @param pThis Pointer to this structure.
255 * @param pVirtualBox The VirtualBox interface.
256 */
257 DECLCALLBACKMEMBER(void, pfnVirtualBoxReady)(PCVBOXEXTPACKREG pThis, VBOXEXTPACK_IF_CS(IVirtualBox) *pVirtualBox);
258
259 /**
260 * Hook for doing work before unloading.
261 *
262 * @param pThis Pointer to this structure.
263 *
264 * @remarks The helpers are not available at this point in time.
265 * @remarks This is not called on uninstall, then pfnUninstall will be the
266 * last callback.
267 */
268 DECLCALLBACKMEMBER(void, pfnUnload)(PCVBOXEXTPACKREG pThis);
269
270 /**
271 * Hook for changing the default VM configuration upon creation.
272 *
273 * @returns VBox status code.
274 * @param pThis Pointer to this structure.
275 * @param pVirtualBox The VirtualBox interface.
276 * @param pMachine The machine interface.
277 */
278 DECLCALLBACKMEMBER(int, pfnVMCreated)(PCVBOXEXTPACKREG pThis, VBOXEXTPACK_IF_CS(IVirtualBox) *pVirtualBox,
279 VBOXEXTPACK_IF_CS(IMachine) *pMachine);
280
281 /**
282 * Query the IUnknown interface to an object in the main module.
283 *
284 * @returns IUnknown pointer (referenced) on success, NULL on failure.
285 * @param pThis Pointer to this structure.
286 * @param pObjectId Pointer to the object ID (UUID).
287 */
288 DECLCALLBACKMEMBER(void *, pfnQueryObject)(PCVBOXEXTPACKREG pThis, PCRTUUID pObjectId);
289
290 DECLR3CALLBACKMEMBER(int, pfnReserved1,(PCVBOXEXTPACKREG pThis)); /**< Reserved for minor structure revisions. */
291 DECLR3CALLBACKMEMBER(int, pfnReserved2,(PCVBOXEXTPACKREG pThis)); /**< Reserved for minor structure revisions. */
292 DECLR3CALLBACKMEMBER(int, pfnReserved3,(PCVBOXEXTPACKREG pThis)); /**< Reserved for minor structure revisions. */
293 DECLR3CALLBACKMEMBER(int, pfnReserved4,(PCVBOXEXTPACKREG pThis)); /**< Reserved for minor structure revisions. */
294 DECLR3CALLBACKMEMBER(int, pfnReserved5,(PCVBOXEXTPACKREG pThis)); /**< Reserved for minor structure revisions. */
295 DECLR3CALLBACKMEMBER(int, pfnReserved6,(PCVBOXEXTPACKREG pThis)); /**< Reserved for minor structure revisions. */
296
297 /** Reserved for minor structure revisions. */
298 uint32_t uReserved7;
299
300 /** End of structure marker (VBOXEXTPACKREG_VERSION). */
301 uint32_t u32EndMarker;
302} VBOXEXTPACKREG;
303/** Current version of the VBOXEXTPACKREG structure. */
304#define VBOXEXTPACKREG_VERSION RT_MAKE_U32(2, 0)
305
306
307/**
308 * The VBoxExtPackRegister callback function.
309 *
310 * The Main API (as in VBoxSVC) will invoke this function after loading an
311 * extension pack Main module. Its job is to do version compatibility checking
312 * and returning the extension pack registration structure.
313 *
314 * @returns VBox status code.
315 * @param pHlp Pointer to the extension pack helper function
316 * table. This is valid until the module is unloaded.
317 * @param ppReg Where to return the pointer to the registration
318 * structure containing all the hooks. This structure
319 * be valid and unchanged until the module is unloaded
320 * (i.e. use some static const data for it).
321 * @param pErrInfo Where to return extended error information.
322 */
323typedef DECLCALLBACK(int) FNVBOXEXTPACKREGISTER(PCVBOXEXTPACKHLP pHlp, PCVBOXEXTPACKREG *ppReg, PRTERRINFO pErrInfo);
324/** Pointer to a FNVBOXEXTPACKREGISTER. */
325typedef FNVBOXEXTPACKREGISTER *PFNVBOXEXTPACKREGISTER;
326
327/** The name of the main module entry point. */
328#define VBOX_EXTPACK_MAIN_MOD_ENTRY_POINT "VBoxExtPackRegister"
329
330
331/** Pointer to the extension pack VM callback table. */
332typedef struct VBOXEXTPACKVMREG const *PCVBOXEXTPACKVMREG;
333/**
334 * Callback table returned by VBoxExtPackVMRegister.
335 *
336 * All the callbacks are called the context of a VM process.
337 *
338 * This must be valid until the extension pack main VM module is unloaded.
339 */
340typedef struct VBOXEXTPACKVMREG
341{
342 /** Interface version.
343 * This is set to VBOXEXTPACKVMREG_VERSION. */
344 uint32_t u32Version;
345 /** The VirtualBox version this extension pack was built against. */
346 uint32_t uVBoxVersion;
347
348 /**
349 * Hook for doing work after the Console object is ready.
350 *
351 * @param pThis Pointer to this structure.
352 * @param pConsole The Console interface.
353 */
354 DECLCALLBACKMEMBER(void, pfnConsoleReady)(PCVBOXEXTPACKVMREG pThis, VBOXEXTPACK_IF_CS(IConsole) *pConsole);
355
356 /**
357 * Hook for doing work before unloading.
358 *
359 * @param pThis Pointer to this structure.
360 *
361 * @remarks The helpers are not available at this point in time.
362 */
363 DECLCALLBACKMEMBER(void, pfnUnload)(PCVBOXEXTPACKVMREG pThis);
364
365 /**
366 * Hook for configuring the VMM for a VM.
367 *
368 * @returns VBox status code.
369 * @param pThis Pointer to this structure.
370 * @param pConsole The console interface.
371 * @param pVM The cross context VM structure.
372 */
373 DECLCALLBACKMEMBER(int, pfnVMConfigureVMM)(PCVBOXEXTPACKVMREG pThis, VBOXEXTPACK_IF_CS(IConsole) *pConsole, PVM pVM);
374
375 /**
376 * Hook for doing work right before powering on the VM.
377 *
378 * @returns VBox status code.
379 * @param pThis Pointer to this structure.
380 * @param pConsole The console interface.
381 * @param pVM The cross context VM structure.
382 */
383 DECLCALLBACKMEMBER(int, pfnVMPowerOn)(PCVBOXEXTPACKVMREG pThis, VBOXEXTPACK_IF_CS(IConsole) *pConsole, PVM pVM);
384
385 /**
386 * Hook for doing work after powering off the VM.
387 *
388 * @param pThis Pointer to this structure.
389 * @param pConsole The console interface.
390 * @param pVM The cross context VM structure. Can be NULL.
391 */
392 DECLCALLBACKMEMBER(void, pfnVMPowerOff)(PCVBOXEXTPACKVMREG pThis, VBOXEXTPACK_IF_CS(IConsole) *pConsole, PVM pVM);
393
394 /**
395 * Query the IUnknown interface to an object in the main VM module.
396 *
397 * @returns IUnknown pointer (referenced) on success, NULL on failure.
398 * @param pThis Pointer to this structure.
399 * @param pObjectId Pointer to the object ID (UUID).
400 */
401 DECLCALLBACKMEMBER(void *, pfnQueryObject)(PCVBOXEXTPACKVMREG pThis, PCRTUUID pObjectId);
402
403 DECLR3CALLBACKMEMBER(int, pfnReserved1,(PCVBOXEXTPACKVMREG pThis)); /**< Reserved for minor structure revisions. */
404 DECLR3CALLBACKMEMBER(int, pfnReserved2,(PCVBOXEXTPACKVMREG pThis)); /**< Reserved for minor structure revisions. */
405 DECLR3CALLBACKMEMBER(int, pfnReserved3,(PCVBOXEXTPACKVMREG pThis)); /**< Reserved for minor structure revisions. */
406 DECLR3CALLBACKMEMBER(int, pfnReserved4,(PCVBOXEXTPACKVMREG pThis)); /**< Reserved for minor structure revisions. */
407 DECLR3CALLBACKMEMBER(int, pfnReserved5,(PCVBOXEXTPACKVMREG pThis)); /**< Reserved for minor structure revisions. */
408 DECLR3CALLBACKMEMBER(int, pfnReserved6,(PCVBOXEXTPACKVMREG pThis)); /**< Reserved for minor structure revisions. */
409
410 /** Reserved for minor structure revisions. */
411 uint32_t uReserved7;
412
413 /** End of structure marker (VBOXEXTPACKVMREG_VERSION). */
414 uint32_t u32EndMarker;
415} VBOXEXTPACKVMREG;
416/** Current version of the VBOXEXTPACKVMREG structure. */
417#define VBOXEXTPACKVMREG_VERSION RT_MAKE_U32(2, 0)
418
419
420/**
421 * The VBoxExtPackVMRegister callback function.
422 *
423 * The Main API (in a VM process) will invoke this function after loading an
424 * extension pack VM module. Its job is to do version compatibility checking
425 * and returning the extension pack registration structure for a VM.
426 *
427 * @returns VBox status code.
428 * @param pHlp Pointer to the extension pack helper function
429 * table. This is valid until the module is unloaded.
430 * @param ppReg Where to return the pointer to the registration
431 * structure containing all the hooks. This structure
432 * be valid and unchanged until the module is unloaded
433 * (i.e. use some static const data for it).
434 * @param pErrInfo Where to return extended error information.
435 */
436typedef DECLCALLBACK(int) FNVBOXEXTPACKVMREGISTER(PCVBOXEXTPACKHLP pHlp, PCVBOXEXTPACKVMREG *ppReg, PRTERRINFO pErrInfo);
437/** Pointer to a FNVBOXEXTPACKVMREGISTER. */
438typedef FNVBOXEXTPACKVMREGISTER *PFNVBOXEXTPACKVMREGISTER;
439
440/** The name of the main VM module entry point. */
441#define VBOX_EXTPACK_MAIN_VM_MOD_ENTRY_POINT "VBoxExtPackVMRegister"
442
443
444/**
445 * Checks if extension pack interface version is compatible.
446 *
447 * @returns true if the do, false if they don't.
448 * @param u32Provider The provider version.
449 * @param u32User The user version.
450 */
451#define VBOXEXTPACK_IS_VER_COMPAT(u32Provider, u32User) \
452 ( VBOXEXTPACK_IS_MAJOR_VER_EQUAL(u32Provider, u32User) \
453 && (int32_t)RT_LOWORD(u32Provider) >= (int32_t)RT_LOWORD(u32User) ) /* stupid casts to shut up gcc */
454
455/**
456 * Check if two extension pack interface versions has the same major version.
457 *
458 * @returns true if the do, false if they don't.
459 * @param u32Ver1 The first version number.
460 * @param u32Ver2 The second version number.
461 */
462#define VBOXEXTPACK_IS_MAJOR_VER_EQUAL(u32Ver1, u32Ver2) (RT_HIWORD(u32Ver1) == RT_HIWORD(u32Ver2))
463
464#endif
465
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