VirtualBox

source: vbox/trunk/src/VBox/HostDrivers/Support/SUPDrvIOC.h@ 25258

Last change on this file since 25258 was 25258, checked in by vboxsync, 15 years ago

SUPDrv: Sketched out support for native module loading. (OS parts are all stubs and the IOC interface changes disabled.)

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 37.3 KB
Line 
1/* $Revision: 25258 $ */
2/** @file
3 * VirtualBox Support Driver - IOCtl definitions.
4 */
5
6/*
7 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
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 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
27 * Clara, CA 95054 USA or visit http://www.sun.com if you need
28 * additional information or have any questions.
29 */
30
31#ifndef ___SUPDrvIOC_h___
32#define ___SUPDrvIOC_h___
33
34/*#define SUPDRV_USE_NATIVE_LOADER*/
35
36/*
37 * Basic types.
38 */
39#include <iprt/types.h>
40
41/*
42 * IOCtl numbers.
43 * We're using the Win32 type of numbers here, thus the macros below.
44 * The SUP_IOCTL_FLAG macro is used to separate requests from 32-bit
45 * and 64-bit processes.
46 */
47#ifdef RT_ARCH_AMD64
48# define SUP_IOCTL_FLAG 128
49#elif defined(RT_ARCH_X86)
50# define SUP_IOCTL_FLAG 0
51#else
52# error "dunno which arch this is!"
53#endif
54
55#ifdef RT_OS_WINDOWS
56# ifndef CTL_CODE
57# include <Windows.h>
58# endif
59 /* Automatic buffering, size not encoded. */
60# define SUP_CTL_CODE_SIZE(Function, Size) CTL_CODE(FILE_DEVICE_UNKNOWN, (Function) | SUP_IOCTL_FLAG, METHOD_BUFFERED, FILE_WRITE_ACCESS)
61# define SUP_CTL_CODE_BIG(Function) CTL_CODE(FILE_DEVICE_UNKNOWN, (Function) | SUP_IOCTL_FLAG, METHOD_BUFFERED, FILE_WRITE_ACCESS)
62# define SUP_CTL_CODE_FAST(Function) CTL_CODE(FILE_DEVICE_UNKNOWN, (Function) | SUP_IOCTL_FLAG, METHOD_NEITHER, FILE_WRITE_ACCESS)
63# define SUP_CTL_CODE_NO_SIZE(uIOCtl) (uIOCtl)
64
65#elif defined(RT_OS_SOLARIS)
66 /* No automatic buffering, size limited to 255 bytes. */
67# include <sys/ioccom.h>
68# define SUP_CTL_CODE_SIZE(Function, Size) _IOWRN('V', (Function) | SUP_IOCTL_FLAG, sizeof(SUPREQHDR))
69# define SUP_CTL_CODE_BIG(Function) _IOWRN('V', (Function) | SUP_IOCTL_FLAG, sizeof(SUPREQHDR))
70# define SUP_CTL_CODE_FAST(Function) _IO( 'V', (Function) | SUP_IOCTL_FLAG)
71# define SUP_CTL_CODE_NO_SIZE(uIOCtl) (uIOCtl)
72
73#elif defined(RT_OS_OS2)
74 /* No automatic buffering, size not encoded. */
75# define SUP_CTL_CATEGORY 0xc0
76# define SUP_CTL_CODE_SIZE(Function, Size) ((unsigned char)(Function))
77# define SUP_CTL_CODE_BIG(Function) ((unsigned char)(Function))
78# define SUP_CTL_CATEGORY_FAST 0xc1
79# define SUP_CTL_CODE_FAST(Function) ((unsigned char)(Function))
80# define SUP_CTL_CODE_NO_SIZE(uIOCtl) (uIOCtl)
81
82#elif defined(RT_OS_LINUX)
83 /* No automatic buffering, size limited to 16KB. */
84# include <linux/ioctl.h>
85# define SUP_CTL_CODE_SIZE(Function, Size) _IOC(_IOC_READ | _IOC_WRITE, 'V', (Function) | SUP_IOCTL_FLAG, (Size))
86# define SUP_CTL_CODE_BIG(Function) _IO('V', (Function) | SUP_IOCTL_FLAG)
87# define SUP_CTL_CODE_FAST(Function) _IO('V', (Function) | SUP_IOCTL_FLAG)
88# define SUP_CTL_CODE_NO_SIZE(uIOCtl) ((uIOCtl) & ~IOCSIZE_MASK)
89
90#elif defined(RT_OS_L4)
91 /* Implemented in suplib, no worries. */
92# define SUP_CTL_CODE_SIZE(Function, Size) (Function)
93# define SUP_CTL_CODE_BIG(Function) (Function)
94# define SUP_CTL_CODE_FAST(Function) (Function)
95# define SUP_CTL_CODE_NO_SIZE(uIOCtl) (uIOCtl)
96
97#else /* BSD Like */
98 /* Automatic buffering, size limited to 4KB on *BSD and 8KB on Darwin - commands the limit, 4KB. */
99# include <sys/ioccom.h>
100# define SUP_CTL_CODE_SIZE(Function, Size) _IOC(IOC_INOUT, 'V', (Function) | SUP_IOCTL_FLAG, (Size))
101# define SUP_CTL_CODE_BIG(Function) _IO('V', (Function) | SUP_IOCTL_FLAG)
102# define SUP_CTL_CODE_FAST(Function) _IO('V', (Function) | SUP_IOCTL_FLAG)
103# define SUP_CTL_CODE_NO_SIZE(uIOCtl) ( (uIOCtl) & ~_IOC(0,0,0,IOCPARM_MASK) )
104#endif
105
106/** Fast path IOCtl: VMMR0_DO_RAW_RUN */
107#define SUP_IOCTL_FAST_DO_RAW_RUN SUP_CTL_CODE_FAST(64)
108/** Fast path IOCtl: VMMR0_DO_HWACC_RUN */
109#define SUP_IOCTL_FAST_DO_HWACC_RUN SUP_CTL_CODE_FAST(65)
110/** Just a NOP call for profiling the latency of a fast ioctl call to VMMR0. */
111#define SUP_IOCTL_FAST_DO_NOP SUP_CTL_CODE_FAST(66)
112
113
114
115/*******************************************************************************
116* Structures and Typedefs *
117*******************************************************************************/
118#ifdef RT_ARCH_AMD64
119# pragma pack(8) /* paranoia. */
120#else
121# pragma pack(4) /* paranoia. */
122#endif
123
124
125/**
126 * Common In/Out header.
127 */
128typedef struct SUPREQHDR
129{
130 /** Cookie. */
131 uint32_t u32Cookie;
132 /** Session cookie. */
133 uint32_t u32SessionCookie;
134 /** The size of the input. */
135 uint32_t cbIn;
136 /** The size of the output. */
137 uint32_t cbOut;
138 /** Flags. See SUPREQHDR_FLAGS_* for details and values. */
139 uint32_t fFlags;
140 /** The VBox status code of the operation, out direction only. */
141 int32_t rc;
142} SUPREQHDR;
143/** Pointer to a IOC header. */
144typedef SUPREQHDR *PSUPREQHDR;
145
146/** @name SUPREQHDR::fFlags values
147 * @{ */
148/** Masks out the magic value. */
149#define SUPREQHDR_FLAGS_MAGIC_MASK UINT32_C(0xff0000ff)
150/** The generic mask. */
151#define SUPREQHDR_FLAGS_GEN_MASK UINT32_C(0x0000ff00)
152/** The request specific mask. */
153#define SUPREQHDR_FLAGS_REQ_MASK UINT32_C(0x00ff0000)
154
155/** There is extra input that needs copying on some platforms. */
156#define SUPREQHDR_FLAGS_EXTRA_IN UINT32_C(0x00000100)
157/** There is extra output that needs copying on some platforms. */
158#define SUPREQHDR_FLAGS_EXTRA_OUT UINT32_C(0x00000200)
159
160/** The magic value. */
161#define SUPREQHDR_FLAGS_MAGIC UINT32_C(0x42000042)
162/** The default value. Use this when no special stuff is requested. */
163#define SUPREQHDR_FLAGS_DEFAULT SUPREQHDR_FLAGS_MAGIC
164/** @} */
165
166
167/** @name SUP_IOCTL_COOKIE
168 * @{
169 */
170/** Negotiate cookie. */
171#define SUP_IOCTL_COOKIE SUP_CTL_CODE_SIZE(1, SUP_IOCTL_COOKIE_SIZE)
172/** The request size. */
173#define SUP_IOCTL_COOKIE_SIZE sizeof(SUPCOOKIE)
174/** The SUPREQHDR::cbIn value. */
175#define SUP_IOCTL_COOKIE_SIZE_IN sizeof(SUPREQHDR) + RT_SIZEOFMEMB(SUPCOOKIE, u.In)
176/** The SUPREQHDR::cbOut value. */
177#define SUP_IOCTL_COOKIE_SIZE_OUT sizeof(SUPREQHDR) + RT_SIZEOFMEMB(SUPCOOKIE, u.Out)
178/** SUPCOOKIE_IN magic word. */
179#define SUPCOOKIE_MAGIC "The Magic Word!"
180/** The initial cookie. */
181#define SUPCOOKIE_INITIAL_COOKIE 0x69726f74 /* 'tori' */
182
183/** Current interface version.
184 * The upper 16-bit is the major version, the the lower the minor version.
185 * When incompatible changes are made, the upper major number has to be changed.
186 *
187 * Update rules:
188 * -# Only update the major number when incompatible changes have been made to
189 * the IOC interface or the ABI provided via the functions returned by
190 * SUPQUERYFUNCS.
191 * -# When adding new features (new IOC number, new flags, new exports, ++)
192 * only update the minor number and change SUPLib.cpp to require the
193 * new IOC version.
194 * -# When incrementing the major number, clear the minor part and reset
195 * any IOC version requirements in SUPLib.cpp.
196 * -# When increment the major number, execute all pending work.
197 *
198 * @todo Pending work on next major version change:
199 * - Nothing.
200 *
201 * @remarks Major version 0x0011YYYY was consumed by the 3.0.12 release. The
202 * next major version used on the trunk will be 0x00120000!
203 */
204#ifdef SUPDRV_USE_NATIVE_LOADER
205#define SUPDRV_IOC_VERSION 0x00120000
206#else
207#define SUPDRV_IOC_VERSION 0x00100001
208#endif
209
210/** SUP_IOCTL_COOKIE. */
211typedef struct SUPCOOKIE
212{
213 /** The header.
214 * u32Cookie must be set to SUPCOOKIE_INITIAL_COOKIE.
215 * u32SessionCookie should be set to some random value. */
216 SUPREQHDR Hdr;
217 union
218 {
219 struct
220 {
221 /** Magic word. */
222 char szMagic[16];
223 /** The requested interface version number. */
224 uint32_t u32ReqVersion;
225 /** The minimum interface version number. */
226 uint32_t u32MinVersion;
227 } In;
228 struct
229 {
230 /** Cookie. */
231 uint32_t u32Cookie;
232 /** Session cookie. */
233 uint32_t u32SessionCookie;
234 /** Interface version for this session. */
235 uint32_t u32SessionVersion;
236 /** The actual interface version in the driver. */
237 uint32_t u32DriverVersion;
238 /** Number of functions available for the SUP_IOCTL_QUERY_FUNCS request. */
239 uint32_t cFunctions;
240 /** Session handle. */
241 R0PTRTYPE(PSUPDRVSESSION) pSession;
242 } Out;
243 } u;
244} SUPCOOKIE, *PSUPCOOKIE;
245/** @} */
246
247
248/** @name SUP_IOCTL_QUERY_FUNCS
249 * Query SUPR0 functions.
250 * @{
251 */
252#define SUP_IOCTL_QUERY_FUNCS(cFuncs) SUP_CTL_CODE_BIG(2)
253#define SUP_IOCTL_QUERY_FUNCS_SIZE(cFuncs) RT_UOFFSETOF(SUPQUERYFUNCS, u.Out.aFunctions[(cFuncs)])
254#define SUP_IOCTL_QUERY_FUNCS_SIZE_IN sizeof(SUPREQHDR)
255#define SUP_IOCTL_QUERY_FUNCS_SIZE_OUT(cFuncs) SUP_IOCTL_QUERY_FUNCS_SIZE(cFuncs)
256
257/** A function. */
258typedef struct SUPFUNC
259{
260 /** Name - mangled. */
261 char szName[32];
262 /** Address. */
263 RTR0PTR pfn;
264} SUPFUNC, *PSUPFUNC;
265
266typedef struct SUPQUERYFUNCS
267{
268 /** The header. */
269 SUPREQHDR Hdr;
270 union
271 {
272 struct
273 {
274 /** Number of functions returned. */
275 uint32_t cFunctions;
276 /** Array of functions. */
277 SUPFUNC aFunctions[1];
278 } Out;
279 } u;
280} SUPQUERYFUNCS, *PSUPQUERYFUNCS;
281/** @} */
282
283
284/** @name SUP_IOCTL_LDR_OPEN
285 * Open an image.
286 * @{
287 */
288#define SUP_IOCTL_LDR_OPEN SUP_CTL_CODE_SIZE(3, SUP_IOCTL_LDR_OPEN_SIZE)
289#define SUP_IOCTL_LDR_OPEN_SIZE sizeof(SUPLDROPEN)
290#define SUP_IOCTL_LDR_OPEN_SIZE_IN sizeof(SUPLDROPEN)
291#define SUP_IOCTL_LDR_OPEN_SIZE_OUT (sizeof(SUPREQHDR) + RT_SIZEOFMEMB(SUPLDROPEN, u.Out))
292typedef struct SUPLDROPEN
293{
294 /** The header. */
295 SUPREQHDR Hdr;
296 union
297 {
298 struct
299 {
300 /** Size of the image we'll be loading (includeing tables). */
301 uint32_t cbImageWithTabs;
302#ifdef SUPDRV_USE_NATIVE_LOADER
303 /** The size of the image bits. (Less or equal to cbImageWithTabs.) */
304 uint32_t cbImageBits;
305#endif
306 /** Image name.
307 * This is the NAME of the image, not the file name. It is used
308 * to share code with other processes. (Max len is 32 chars!) */
309 char szName[32];
310#ifdef SUPDRV_USE_NATIVE_LOADER
311 /** Image file name.
312 * This can be used to load the image using a native loader. */
313 char szFilename[196];
314#endif
315 } In;
316 struct
317 {
318 /** The base address of the image. */
319 RTR0PTR pvImageBase;
320 /** Indicate whether or not the image requires loading. */
321 bool fNeedsLoading;
322 } Out;
323 } u;
324} SUPLDROPEN, *PSUPLDROPEN;
325/** @} */
326
327
328/** @name SUP_IOCTL_LDR_LOAD
329 * Upload the image bits.
330 * @{
331 */
332#define SUP_IOCTL_LDR_LOAD SUP_CTL_CODE_BIG(4)
333#define SUP_IOCTL_LDR_LOAD_SIZE(cbImage) RT_UOFFSETOF(SUPLDRLOAD, u.In.achImage[cbImage])
334#define SUP_IOCTL_LDR_LOAD_SIZE_IN(cbImage) RT_UOFFSETOF(SUPLDRLOAD, u.In.achImage[cbImage])
335#define SUP_IOCTL_LDR_LOAD_SIZE_OUT sizeof(SUPREQHDR)
336
337/**
338 * Module initialization callback function.
339 * This is called once after the module has been loaded.
340 *
341 * @returns 0 on success.
342 * @returns Appropriate error code on failure.
343 */
344typedef DECLCALLBACK(int) FNR0MODULEINIT(void);
345/** Pointer to a FNR0MODULEINIT(). */
346typedef R0PTRTYPE(FNR0MODULEINIT *) PFNR0MODULEINIT;
347
348/**
349 * Module termination callback function.
350 * This is called once right before the module is being unloaded.
351 */
352typedef DECLCALLBACK(void) FNR0MODULETERM(void);
353/** Pointer to a FNR0MODULETERM(). */
354typedef R0PTRTYPE(FNR0MODULETERM *) PFNR0MODULETERM;
355
356/**
357 * Symbol table entry.
358 */
359typedef struct SUPLDRSYM
360{
361 /** Offset into of the string table. */
362 uint32_t offName;
363 /** Offset of the symbol relative to the image load address. */
364 uint32_t offSymbol;
365} SUPLDRSYM;
366/** Pointer to a symbol table entry. */
367typedef SUPLDRSYM *PSUPLDRSYM;
368/** Pointer to a const symbol table entry. */
369typedef SUPLDRSYM const *PCSUPLDRSYM;
370
371/**
372 * SUPLDRLOAD::u::In::EP type.
373 */
374typedef enum SUPLDRLOADEP
375{
376 SUPLDRLOADEP_NOTHING = 0,
377 SUPLDRLOADEP_VMMR0,
378 SUPLDRLOADEP_SERVICE,
379 SUPLDRLOADEP_32BIT_HACK = 0x7fffffff
380} SUPLDRLOADEP;
381
382typedef struct SUPLDRLOAD
383{
384 /** The header. */
385 SUPREQHDR Hdr;
386 union
387 {
388 struct
389 {
390 /** The address of module initialization function. Similar to _DLL_InitTerm(hmod, 0). */
391 PFNR0MODULEINIT pfnModuleInit;
392 /** The address of module termination function. Similar to _DLL_InitTerm(hmod, 1). */
393 PFNR0MODULETERM pfnModuleTerm;
394 /** Special entry points. */
395 union
396 {
397 /** SUPLDRLOADEP_VMMR0. */
398 struct
399 {
400 /** The module handle (i.e. address). */
401 RTR0PTR pvVMMR0;
402 /** Address of VMMR0EntryInt function. */
403 RTR0PTR pvVMMR0EntryInt;
404 /** Address of VMMR0EntryFast function. */
405 RTR0PTR pvVMMR0EntryFast;
406 /** Address of VMMR0EntryEx function. */
407 RTR0PTR pvVMMR0EntryEx;
408 } VMMR0;
409 /** SUPLDRLOADEP_SERVICE. */
410 struct
411 {
412 /** The service request handler.
413 * (PFNR0SERVICEREQHANDLER isn't defined yet.) */
414 RTR0PTR pfnServiceReq;
415 /** Reserved, must be NIL. */
416 RTR0PTR apvReserved[3];
417 } Service;
418 } EP;
419 /** Address. */
420 RTR0PTR pvImageBase;
421 /** Entry point type. */
422 SUPLDRLOADEP eEPType;
423#ifdef SUPDRV_USE_NATIVE_LOADER
424 /** The size of the image bits (starting at offset 0 and
425 * approaching offSymbols). */
426 uint32_t cbImageBits;
427#endif
428 /** The offset of the symbol table. */
429 uint32_t offSymbols;
430 /** The number of entries in the symbol table. */
431 uint32_t cSymbols;
432 /** The offset of the string table. */
433 uint32_t offStrTab;
434 /** Size of the string table. */
435 uint32_t cbStrTab;
436 /** Size of image data in achImage. */
437 uint32_t cbImageWithTabs;
438 /** The image data. */
439 char achImage[1];
440 } In;
441 } u;
442} SUPLDRLOAD, *PSUPLDRLOAD;
443/** @} */
444
445
446/** @name SUP_IOCTL_LDR_FREE
447 * Free an image.
448 * @{
449 */
450#define SUP_IOCTL_LDR_FREE SUP_CTL_CODE_SIZE(5, SUP_IOCTL_LDR_FREE_SIZE)
451#define SUP_IOCTL_LDR_FREE_SIZE sizeof(SUPLDRFREE)
452#define SUP_IOCTL_LDR_FREE_SIZE_IN sizeof(SUPLDRFREE)
453#define SUP_IOCTL_LDR_FREE_SIZE_OUT sizeof(SUPREQHDR)
454typedef struct SUPLDRFREE
455{
456 /** The header. */
457 SUPREQHDR Hdr;
458 union
459 {
460 struct
461 {
462 /** Address. */
463 RTR0PTR pvImageBase;
464 } In;
465 } u;
466} SUPLDRFREE, *PSUPLDRFREE;
467/** @} */
468
469
470/** @name SUP_IOCTL_LDR_GET_SYMBOL
471 * Get address of a symbol within an image.
472 * @{
473 */
474#define SUP_IOCTL_LDR_GET_SYMBOL SUP_CTL_CODE_SIZE(6, SUP_IOCTL_LDR_GET_SYMBOL_SIZE)
475#define SUP_IOCTL_LDR_GET_SYMBOL_SIZE sizeof(SUPLDRGETSYMBOL)
476#define SUP_IOCTL_LDR_GET_SYMBOL_SIZE_IN sizeof(SUPLDRGETSYMBOL)
477#define SUP_IOCTL_LDR_GET_SYMBOL_SIZE_OUT (sizeof(SUPREQHDR) + RT_SIZEOFMEMB(SUPLDRGETSYMBOL, u.Out))
478typedef struct SUPLDRGETSYMBOL
479{
480 /** The header. */
481 SUPREQHDR Hdr;
482 union
483 {
484 struct
485 {
486 /** Address. */
487 RTR0PTR pvImageBase;
488 /** The symbol name. */
489 char szSymbol[64];
490 } In;
491 struct
492 {
493 /** The symbol address. */
494 RTR0PTR pvSymbol;
495 } Out;
496 } u;
497} SUPLDRGETSYMBOL, *PSUPLDRGETSYMBOL;
498/** @} */
499
500
501/** @name SUP_IOCTL_CALL_VMMR0
502 * Call the R0 VMM Entry point.
503 *
504 * @todo Might have to convert this to a big request...
505 * @{
506 */
507#define SUP_IOCTL_CALL_VMMR0(cbReq) SUP_CTL_CODE_SIZE(7, SUP_IOCTL_CALL_VMMR0_SIZE(cbReq))
508#define SUP_IOCTL_CALL_VMMR0_SIZE(cbReq) RT_UOFFSETOF(SUPCALLVMMR0, abReqPkt[cbReq])
509#define SUP_IOCTL_CALL_VMMR0_SIZE_IN(cbReq) SUP_IOCTL_CALL_VMMR0_SIZE(cbReq)
510#define SUP_IOCTL_CALL_VMMR0_SIZE_OUT(cbReq) SUP_IOCTL_CALL_VMMR0_SIZE(cbReq)
511typedef struct SUPCALLVMMR0
512{
513 /** The header. */
514 SUPREQHDR Hdr;
515 union
516 {
517 struct
518 {
519 /** The VM handle. */
520 PVMR0 pVMR0;
521 /** VCPU id. */
522 uint32_t idCpu;
523 /** Which operation to execute. */
524 uint32_t uOperation;
525 /** Argument to use when no request packet is supplied. */
526 uint64_t u64Arg;
527 } In;
528 } u;
529 /** The VMMR0Entry request packet. */
530 uint8_t abReqPkt[1];
531} SUPCALLVMMR0, *PSUPCALLVMMR0;
532/** @} */
533
534
535/** @name SUP_IOCTL_LOW_ALLOC
536 * Allocate memory below 4GB (physically).
537 * @{
538 */
539#define SUP_IOCTL_LOW_ALLOC SUP_CTL_CODE_BIG(8)
540#define SUP_IOCTL_LOW_ALLOC_SIZE(cPages) ((uint32_t)RT_UOFFSETOF(SUPLOWALLOC, u.Out.aPages[cPages]))
541#define SUP_IOCTL_LOW_ALLOC_SIZE_IN (sizeof(SUPREQHDR) + RT_SIZEOFMEMB(SUPLOWALLOC, u.In))
542#define SUP_IOCTL_LOW_ALLOC_SIZE_OUT(cPages) SUP_IOCTL_LOW_ALLOC_SIZE(cPages)
543typedef struct SUPLOWALLOC
544{
545 /** The header. */
546 SUPREQHDR Hdr;
547 union
548 {
549 struct
550 {
551 /** Number of pages to allocate. */
552 uint32_t cPages;
553 } In;
554 struct
555 {
556 /** The ring-3 address of the allocated memory. */
557 RTR3PTR pvR3;
558 /** The ring-0 address of the allocated memory. */
559 RTR0PTR pvR0;
560 /** Array of pages. */
561 RTHCPHYS aPages[1];
562 } Out;
563 } u;
564} SUPLOWALLOC, *PSUPLOWALLOC;
565/** @} */
566
567
568/** @name SUP_IOCTL_LOW_FREE
569 * Free low memory.
570 * @{
571 */
572#define SUP_IOCTL_LOW_FREE SUP_CTL_CODE_SIZE(9, SUP_IOCTL_LOW_FREE_SIZE)
573#define SUP_IOCTL_LOW_FREE_SIZE sizeof(SUPLOWFREE)
574#define SUP_IOCTL_LOW_FREE_SIZE_IN sizeof(SUPLOWFREE)
575#define SUP_IOCTL_LOW_FREE_SIZE_OUT sizeof(SUPREQHDR)
576typedef struct SUPLOWFREE
577{
578 /** The header. */
579 SUPREQHDR Hdr;
580 union
581 {
582 struct
583 {
584 /** The ring-3 address of the memory to free. */
585 RTR3PTR pvR3;
586 } In;
587 } u;
588} SUPLOWFREE, *PSUPLOWFREE;
589/** @} */
590
591
592/** @name SUP_IOCTL_PAGE_ALLOC_EX
593 * Allocate memory and map it into kernel and/or user space. The memory is of
594 * course locked. The result should be freed using SUP_IOCTL_PAGE_FREE.
595 *
596 * @remarks Allocations without a kernel mapping may fail with
597 * VERR_NOT_SUPPORTED on some platforms.
598 *
599 * @{
600 */
601#define SUP_IOCTL_PAGE_ALLOC_EX SUP_CTL_CODE_BIG(10)
602#define SUP_IOCTL_PAGE_ALLOC_EX_SIZE(cPages) RT_UOFFSETOF(SUPPAGEALLOCEX, u.Out.aPages[cPages])
603#define SUP_IOCTL_PAGE_ALLOC_EX_SIZE_IN (sizeof(SUPREQHDR) + RT_SIZEOFMEMB(SUPPAGEALLOCEX, u.In))
604#define SUP_IOCTL_PAGE_ALLOC_EX_SIZE_OUT(cPages) SUP_IOCTL_PAGE_ALLOC_EX_SIZE(cPages)
605typedef struct SUPPAGEALLOCEX
606{
607 /** The header. */
608 SUPREQHDR Hdr;
609 union
610 {
611 struct
612 {
613 /** Number of pages to allocate */
614 uint32_t cPages;
615 /** Whether it should have kernel mapping. */
616 bool fKernelMapping;
617 /** Whether it should have a user mapping. */
618 bool fUserMapping;
619 /** Reserved. Must be false. */
620 bool fReserved0;
621 /** Reserved. Must be false. */
622 bool fReserved1;
623 } In;
624 struct
625 {
626 /** Returned ring-3 address. */
627 RTR3PTR pvR3;
628 /** Returned ring-0 address. */
629 RTR0PTR pvR0;
630 /** The physical addresses of the allocated pages. */
631 RTHCPHYS aPages[1];
632 } Out;
633 } u;
634} SUPPAGEALLOCEX, *PSUPPAGEALLOCEX;
635/** @} */
636
637
638/** @name SUP_IOCTL_PAGE_MAP_KERNEL
639 * Maps a portion of memory allocated by SUP_IOCTL_PAGE_ALLOC_EX /
640 * SUPR0PageAllocEx into kernel space for use by a device or similar.
641 *
642 * The mapping will be freed together with the ring-3 mapping when
643 * SUP_IOCTL_PAGE_FREE or SUPR0PageFree is called.
644 *
645 * @remarks Not necessarily supported on all platforms.
646 *
647 * @{
648 */
649#define SUP_IOCTL_PAGE_MAP_KERNEL SUP_CTL_CODE_SIZE(11, SUP_IOCTL_PAGE_MAP_KERNEL_SIZE)
650#define SUP_IOCTL_PAGE_MAP_KERNEL_SIZE sizeof(SUPPAGEMAPKERNEL)
651#define SUP_IOCTL_PAGE_MAP_KERNEL_SIZE_IN sizeof(SUPPAGEMAPKERNEL)
652#define SUP_IOCTL_PAGE_MAP_KERNEL_SIZE_OUT sizeof(SUPPAGEMAPKERNEL)
653typedef struct SUPPAGEMAPKERNEL
654{
655 /** The header. */
656 SUPREQHDR Hdr;
657 union
658 {
659 struct
660 {
661 /** The pointer of to the previously allocated memory. */
662 RTR3PTR pvR3;
663 /** The offset to start mapping from. */
664 uint32_t offSub;
665 /** Size of the section to map. */
666 uint32_t cbSub;
667 /** Flags reserved for future fun. */
668 uint32_t fFlags;
669 } In;
670 struct
671 {
672 /** The ring-0 address corresponding to pvR3 + offSub. */
673 RTR0PTR pvR0;
674 } Out;
675 } u;
676} SUPPAGEMAPKERNEL, *PSUPPAGEMAPKERNEL;
677/** @} */
678
679
680/** @name SUP_IOCTL_PAGE_PROTECT
681 * Changes the page level protection of the user and/or kernel mappings of
682 * memory previously allocated by SUPR0PageAllocEx.
683 *
684 * @remarks Not necessarily supported on all platforms.
685 *
686 * @{
687 */
688#define SUP_IOCTL_PAGE_PROTECT SUP_CTL_CODE_SIZE(12, SUP_IOCTL_PAGE_PROTECT_SIZE)
689#define SUP_IOCTL_PAGE_PROTECT_SIZE sizeof(SUPPAGEPROTECT)
690#define SUP_IOCTL_PAGE_PROTECT_SIZE_IN sizeof(SUPPAGEPROTECT)
691#define SUP_IOCTL_PAGE_PROTECT_SIZE_OUT sizeof(SUPPAGEPROTECT)
692typedef struct SUPPAGEPROTECT
693{
694 /** The header. */
695 SUPREQHDR Hdr;
696 union
697 {
698 struct
699 {
700 /** The pointer of to the previously allocated memory.
701 * Pass NIL_RTR3PTR if the ring-0 mapping should remain unaffected. */
702 RTR3PTR pvR3;
703 /** The pointer of to the previously allocated memory.
704 * Pass NIL_RTR0PTR if the ring-0 mapping should remain unaffected. */
705 RTR0PTR pvR0;
706 /** The offset to start changing protection at. */
707 uint32_t offSub;
708 /** Size of the portion that should be changed. */
709 uint32_t cbSub;
710 /** Protection flags, RTMEM_PROT_*. */
711 uint32_t fProt;
712 } In;
713 } u;
714} SUPPAGEPROTECT, *PSUPPAGEPROTECT;
715/** @} */
716
717
718/** @name SUP_IOCTL_PAGE_FREE
719 * Free memory allocated with SUP_IOCTL_PAGE_ALLOC_EX.
720 * @{
721 */
722#define SUP_IOCTL_PAGE_FREE SUP_CTL_CODE_SIZE(13, SUP_IOCTL_PAGE_FREE_SIZE_IN)
723#define SUP_IOCTL_PAGE_FREE_SIZE sizeof(SUPPAGEFREE)
724#define SUP_IOCTL_PAGE_FREE_SIZE_IN sizeof(SUPPAGEFREE)
725#define SUP_IOCTL_PAGE_FREE_SIZE_OUT sizeof(SUPREQHDR)
726typedef struct SUPPAGEFREE
727{
728 /** The header. */
729 SUPREQHDR Hdr;
730 union
731 {
732 struct
733 {
734 /** Address of memory range to free. */
735 RTR3PTR pvR3;
736 } In;
737 } u;
738} SUPPAGEFREE, *PSUPPAGEFREE;
739/** @} */
740
741
742
743
744/** @name SUP_IOCTL_PAGE_LOCK
745 * Pin down physical pages.
746 * @{
747 */
748#define SUP_IOCTL_PAGE_LOCK SUP_CTL_CODE_BIG(14)
749#define SUP_IOCTL_PAGE_LOCK_SIZE(cPages) (RT_MAX((size_t)SUP_IOCTL_PAGE_LOCK_SIZE_IN, (size_t)SUP_IOCTL_PAGE_LOCK_SIZE_OUT(cPages)))
750#define SUP_IOCTL_PAGE_LOCK_SIZE_IN (sizeof(SUPREQHDR) + RT_SIZEOFMEMB(SUPPAGELOCK, u.In))
751#define SUP_IOCTL_PAGE_LOCK_SIZE_OUT(cPages) RT_UOFFSETOF(SUPPAGELOCK, u.Out.aPages[cPages])
752typedef struct SUPPAGELOCK
753{
754 /** The header. */
755 SUPREQHDR Hdr;
756 union
757 {
758 struct
759 {
760 /** Start of page range. Must be PAGE aligned. */
761 RTR3PTR pvR3;
762 /** The range size given as a page count. */
763 uint32_t cPages;
764 } In;
765
766 struct
767 {
768 /** Array of pages. */
769 RTHCPHYS aPages[1];
770 } Out;
771 } u;
772} SUPPAGELOCK, *PSUPPAGELOCK;
773/** @} */
774
775
776/** @name SUP_IOCTL_PAGE_UNLOCK
777 * Unpin physical pages.
778 * @{ */
779#define SUP_IOCTL_PAGE_UNLOCK SUP_CTL_CODE_SIZE(15, SUP_IOCTL_PAGE_UNLOCK_SIZE)
780#define SUP_IOCTL_PAGE_UNLOCK_SIZE sizeof(SUPPAGEUNLOCK)
781#define SUP_IOCTL_PAGE_UNLOCK_SIZE_IN sizeof(SUPPAGEUNLOCK)
782#define SUP_IOCTL_PAGE_UNLOCK_SIZE_OUT sizeof(SUPREQHDR)
783typedef struct SUPPAGEUNLOCK
784{
785 /** The header. */
786 SUPREQHDR Hdr;
787 union
788 {
789 struct
790 {
791 /** Start of page range of a range previuosly pinned. */
792 RTR3PTR pvR3;
793 } In;
794 } u;
795} SUPPAGEUNLOCK, *PSUPPAGEUNLOCK;
796/** @} */
797
798
799/** @name SUP_IOCTL_CONT_ALLOC
800 * Allocate contious memory.
801 * @{
802 */
803#define SUP_IOCTL_CONT_ALLOC SUP_CTL_CODE_SIZE(16, SUP_IOCTL_CONT_ALLOC_SIZE)
804#define SUP_IOCTL_CONT_ALLOC_SIZE sizeof(SUPCONTALLOC)
805#define SUP_IOCTL_CONT_ALLOC_SIZE_IN (sizeof(SUPREQHDR) + RT_SIZEOFMEMB(SUPCONTALLOC, u.In))
806#define SUP_IOCTL_CONT_ALLOC_SIZE_OUT sizeof(SUPCONTALLOC)
807typedef struct SUPCONTALLOC
808{
809 /** The header. */
810 SUPREQHDR Hdr;
811 union
812 {
813 struct
814 {
815 /** The allocation size given as a page count. */
816 uint32_t cPages;
817 } In;
818
819 struct
820 {
821 /** The address of the ring-0 mapping of the allocated memory. */
822 RTR0PTR pvR0;
823 /** The address of the ring-3 mapping of the allocated memory. */
824 RTR3PTR pvR3;
825 /** The physical address of the allocation. */
826 RTHCPHYS HCPhys;
827 } Out;
828 } u;
829} SUPCONTALLOC, *PSUPCONTALLOC;
830/** @} */
831
832
833/** @name SUP_IOCTL_CONT_FREE Input.
834 * @{
835 */
836/** Free contious memory. */
837#define SUP_IOCTL_CONT_FREE SUP_CTL_CODE_SIZE(17, SUP_IOCTL_CONT_FREE_SIZE)
838#define SUP_IOCTL_CONT_FREE_SIZE sizeof(SUPCONTFREE)
839#define SUP_IOCTL_CONT_FREE_SIZE_IN sizeof(SUPCONTFREE)
840#define SUP_IOCTL_CONT_FREE_SIZE_OUT sizeof(SUPREQHDR)
841typedef struct SUPCONTFREE
842{
843 /** The header. */
844 SUPREQHDR Hdr;
845 union
846 {
847 struct
848 {
849 /** The ring-3 address of the memory to free. */
850 RTR3PTR pvR3;
851 } In;
852 } u;
853} SUPCONTFREE, *PSUPCONTFREE;
854/** @} */
855
856
857/** @name SUP_IOCTL_GET_PAGING_MODE
858 * Get the host paging mode.
859 * @{
860 */
861#define SUP_IOCTL_GET_PAGING_MODE SUP_CTL_CODE_SIZE(18, SUP_IOCTL_GET_PAGING_MODE_SIZE)
862#define SUP_IOCTL_GET_PAGING_MODE_SIZE sizeof(SUPGETPAGINGMODE)
863#define SUP_IOCTL_GET_PAGING_MODE_SIZE_IN sizeof(SUPREQHDR)
864#define SUP_IOCTL_GET_PAGING_MODE_SIZE_OUT sizeof(SUPGETPAGINGMODE)
865typedef struct SUPGETPAGINGMODE
866{
867 /** The header. */
868 SUPREQHDR Hdr;
869 union
870 {
871 struct
872 {
873 /** The paging mode. */
874 SUPPAGINGMODE enmMode;
875 } Out;
876 } u;
877} SUPGETPAGINGMODE, *PSUPGETPAGINGMODE;
878/** @} */
879
880
881/** @name SUP_IOCTL_SET_VM_FOR_FAST
882 * Set the VM handle for doing fast call ioctl calls.
883 * @{
884 */
885#define SUP_IOCTL_SET_VM_FOR_FAST SUP_CTL_CODE_SIZE(19, SUP_IOCTL_SET_VM_FOR_FAST_SIZE)
886#define SUP_IOCTL_SET_VM_FOR_FAST_SIZE sizeof(SUPSETVMFORFAST)
887#define SUP_IOCTL_SET_VM_FOR_FAST_SIZE_IN sizeof(SUPSETVMFORFAST)
888#define SUP_IOCTL_SET_VM_FOR_FAST_SIZE_OUT sizeof(SUPREQHDR)
889typedef struct SUPSETVMFORFAST
890{
891 /** The header. */
892 SUPREQHDR Hdr;
893 union
894 {
895 struct
896 {
897 /** The ring-0 VM handle (pointer). */
898 PVMR0 pVMR0;
899 } In;
900 } u;
901} SUPSETVMFORFAST, *PSUPSETVMFORFAST;
902/** @} */
903
904
905/** @name SUP_IOCTL_GIP_MAP
906 * Map the GIP into user space.
907 * @{
908 */
909#define SUP_IOCTL_GIP_MAP SUP_CTL_CODE_SIZE(20, SUP_IOCTL_GIP_MAP_SIZE)
910#define SUP_IOCTL_GIP_MAP_SIZE sizeof(SUPGIPMAP)
911#define SUP_IOCTL_GIP_MAP_SIZE_IN sizeof(SUPREQHDR)
912#define SUP_IOCTL_GIP_MAP_SIZE_OUT sizeof(SUPGIPMAP)
913typedef struct SUPGIPMAP
914{
915 /** The header. */
916 SUPREQHDR Hdr;
917 union
918 {
919 struct
920 {
921 /** The physical address of the GIP. */
922 RTHCPHYS HCPhysGip;
923 /** Pointer to the read-only usermode GIP mapping for this session. */
924 R3PTRTYPE(PSUPGLOBALINFOPAGE) pGipR3;
925 /** Pointer to the supervisor mode GIP mapping. */
926 R0PTRTYPE(PSUPGLOBALINFOPAGE) pGipR0;
927 } Out;
928 } u;
929} SUPGIPMAP, *PSUPGIPMAP;
930/** @} */
931
932
933/** @name SUP_IOCTL_GIP_UNMAP
934 * Unmap the GIP.
935 * @{
936 */
937#define SUP_IOCTL_GIP_UNMAP SUP_CTL_CODE_SIZE(21, SUP_IOCTL_GIP_UNMAP_SIZE)
938#define SUP_IOCTL_GIP_UNMAP_SIZE sizeof(SUPGIPUNMAP)
939#define SUP_IOCTL_GIP_UNMAP_SIZE_IN sizeof(SUPGIPUNMAP)
940#define SUP_IOCTL_GIP_UNMAP_SIZE_OUT sizeof(SUPGIPUNMAP)
941typedef struct SUPGIPUNMAP
942{
943 /** The header. */
944 SUPREQHDR Hdr;
945} SUPGIPUNMAP, *PSUPGIPUNMAP;
946/** @} */
947
948
949/** @name SUP_IOCTL_CALL_SERVICE
950 * Call the a ring-0 service.
951 *
952 * @todo Might have to convert this to a big request, just like
953 * SUP_IOCTL_CALL_VMMR0
954 * @{
955 */
956#define SUP_IOCTL_CALL_SERVICE(cbReq) SUP_CTL_CODE_SIZE(22, SUP_IOCTL_CALL_SERVICE_SIZE(cbReq))
957#define SUP_IOCTL_CALL_SERVICE_SIZE(cbReq) RT_UOFFSETOF(SUPCALLSERVICE, abReqPkt[cbReq])
958#define SUP_IOCTL_CALL_SERVICE_SIZE_IN(cbReq) SUP_IOCTL_CALL_SERVICE_SIZE(cbReq)
959#define SUP_IOCTL_CALL_SERVICE_SIZE_OUT(cbReq) SUP_IOCTL_CALL_SERVICE_SIZE(cbReq)
960typedef struct SUPCALLSERVICE
961{
962 /** The header. */
963 SUPREQHDR Hdr;
964 union
965 {
966 struct
967 {
968 /** The service name. */
969 char szName[28];
970 /** Which operation to execute. */
971 uint32_t uOperation;
972 /** Argument to use when no request packet is supplied. */
973 uint64_t u64Arg;
974 } In;
975 } u;
976 /** The request packet passed to SUP. */
977 uint8_t abReqPkt[1];
978} SUPCALLSERVICE, *PSUPCALLSERVICE;
979/** @} */
980
981
982/** @name SUP_IOCTL_LOGGER_SETTINGS
983 * Changes the ring-0 release or debug logger settings.
984 * @{
985 */
986#define SUP_IOCTL_LOGGER_SETTINGS(cbStrTab) SUP_CTL_CODE_SIZE(23, SUP_IOCTL_LOGGER_SETTINGS_SIZE(cbStrTab))
987#define SUP_IOCTL_LOGGER_SETTINGS_SIZE(cbStrTab) RT_UOFFSETOF(SUPLOGGERSETTINGS, u.In.szStrings[cbStrTab])
988#define SUP_IOCTL_LOGGER_SETTINGS_SIZE_IN(cbStrTab) RT_UOFFSETOF(SUPLOGGERSETTINGS, u.In.szStrings[cbStrTab])
989#define SUP_IOCTL_LOGGER_SETTINGS_SIZE_OUT sizeof(SUPREQHDR)
990typedef struct SUPLOGGERSETTINGS
991{
992 /** The header. */
993 SUPREQHDR Hdr;
994 union
995 {
996 struct
997 {
998 /** Which logger. */
999 uint32_t fWhich;
1000 /** What to do with it. */
1001 uint32_t fWhat;
1002 /** Offset of the flags setting string. */
1003 uint32_t offFlags;
1004 /** Offset of the groups setting string. */
1005 uint32_t offGroups;
1006 /** Offset of the destination setting string. */
1007 uint32_t offDestination;
1008 /** The string table. */
1009 char szStrings[1];
1010 } In;
1011 } u;
1012} SUPLOGGERSETTINGS, *PSUPLOGGERSETTINGS;
1013
1014/** Debug logger. */
1015#define SUPLOGGERSETTINGS_WHICH_DEBUG 0
1016/** Release logger. */
1017#define SUPLOGGERSETTINGS_WHICH_RELEASE 1
1018
1019/** Change the settings. */
1020#define SUPLOGGERSETTINGS_WHAT_SETTINGS 0
1021/** Create the logger instance. */
1022#define SUPLOGGERSETTINGS_WHAT_CREATE 1
1023/** Destroy the logger instance. */
1024#define SUPLOGGERSETTINGS_WHAT_DESTROY 2
1025
1026/** @} */
1027
1028
1029/** @name Semaphore Types
1030 * @{ */
1031#define SUP_SEM_TYPE_EVENT 0
1032#define SUP_SEM_TYPE_EVENT_MULTI 1
1033/** @} */
1034
1035
1036/** @name SUP_IOCTL_SEM_CREATE
1037 * Create a semaphore
1038 * @{
1039 */
1040#define SUP_IOCTL_SEM_CREATE SUP_CTL_CODE_SIZE(24, SUP_IOCTL_SEM_CREATE_SIZE)
1041#define SUP_IOCTL_SEM_CREATE_SIZE sizeof(SUPSEMCREATE)
1042#define SUP_IOCTL_SEM_CREATE_SIZE_IN sizeof(SUPSEMCREATE)
1043#define SUP_IOCTL_SEM_CREATE_SIZE_OUT sizeof(SUPSEMCREATE)
1044typedef struct SUPSEMCREATE
1045{
1046 /** The header. */
1047 SUPREQHDR Hdr;
1048 union
1049 {
1050 struct
1051 {
1052 /** The semaphore type. */
1053 uint32_t uType;
1054 } In;
1055 struct
1056 {
1057 /** The handle of the created semaphore. */
1058 uint32_t hSem;
1059 } Out;
1060 } u;
1061} SUPSEMCREATE, *PSUPSEMCREATE;
1062
1063/** @} */
1064
1065
1066/** @name SUP_IOCTL_SEM_OP
1067 * Semaphore operations.
1068 * @{
1069 */
1070#define SUP_IOCTL_SEM_OP SUP_CTL_CODE_SIZE(25, SUP_IOCTL_SEM_OP_SIZE)
1071#define SUP_IOCTL_SEM_OP_SIZE sizeof(SUPSEMOP)
1072#define SUP_IOCTL_SEM_OP_SIZE_IN sizeof(SUPSEMOP)
1073#define SUP_IOCTL_SEM_OP_SIZE_OUT sizeof(SUPREQHDR)
1074typedef struct SUPSEMOP
1075{
1076 /** The header. */
1077 SUPREQHDR Hdr;
1078 union
1079 {
1080 struct
1081 {
1082 /** The semaphore type. */
1083 uint32_t uType;
1084 /** The semaphore handle. */
1085 uint32_t hSem;
1086 /** The operation. */
1087 uint32_t uOp;
1088 /** The number of milliseconds to wait if it's a wait operation. */
1089 uint32_t cMillies;
1090 } In;
1091 } u;
1092} SUPSEMOP, *PSUPSEMOP;
1093
1094/** Wait for a number of millisecons. */
1095#define SUPSEMOP_WAIT 0
1096/** Signal the semaphore. */
1097#define SUPSEMOP_SIGNAL 1
1098/** Reset the sempahore (only applicable to SUP_SEM_TYPE_EVENT_MULTI). */
1099#define SUPSEMOP_RESET 2
1100/** Close the semaphore handle. */
1101#define SUPSEMOP_CLOSE 3
1102
1103/** @} */
1104
1105/** @name SUP_IOCTL_VT_CAPS Input.
1106 * @{
1107 */
1108/** Free contious memory. */
1109#define SUP_IOCTL_VT_CAPS SUP_CTL_CODE_SIZE(26, SUP_IOCTL_VT_CAPS_SIZE)
1110#define SUP_IOCTL_VT_CAPS_SIZE sizeof(SUPVTCAPS)
1111#define SUP_IOCTL_VT_CAPS_SIZE_IN sizeof(SUPREQHDR)
1112#define SUP_IOCTL_VT_CAPS_SIZE_OUT sizeof(SUPVTCAPS)
1113typedef struct SUPVTCAPS
1114{
1115 /** The header. */
1116 SUPREQHDR Hdr;
1117 union
1118 {
1119 struct
1120 {
1121 /** The VT capability dword. */
1122 uint32_t Caps;
1123 } Out;
1124 } u;
1125} SUPVTCAPS, *PSUPVTCAPS;
1126/** @} */
1127
1128#pragma pack() /* paranoia */
1129
1130#endif
1131
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