| /** @file | |
| * Virtual Device for Guest <-> VMM/Host communication (ADD,DEV). | |
| */ | |
| /* | |
| * Copyright (C) 2006-2015 Oracle Corporation | |
| * | |
| * This file is part of VirtualBox Open Source Edition (OSE), as | |
| * available from http://www.virtualbox.org. This file is free software; | |
| * you can redistribute it and/or modify it under the terms of the GNU | |
| * General Public License (GPL) as published by the Free Software | |
| * Foundation, in version 2 as it comes in the "COPYING" file of the | |
| * VirtualBox OSE distribution. VirtualBox OSE is distributed in the | |
| * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind. | |
| * | |
| * The contents of this file may alternatively be used under the terms | |
| * of the Common Development and Distribution License Version 1.0 | |
| * (CDDL) only, as it comes in the "COPYING.CDDL" file of the | |
| * VirtualBox OSE distribution, in which case the provisions of the | |
| * CDDL are applicable instead of those of the GPL. | |
| * | |
| * You may elect to license modified versions of this file under the | |
| * terms and conditions of either the GPL or the CDDL or both. | |
| */ | |
| #ifndef ___VBox_VMMDev_h | |
| #define ___VBox_VMMDev_h | |
| #include <VBox/cdefs.h> | |
| #include <VBox/param.h> /* for the PCI IDs. */ | |
| #include <VBox/types.h> | |
| #include <VBox/err.h> | |
| #include <VBox/ostypes.h> | |
| #include <VBox/VMMDev2.h> | |
| #include <iprt/assert.h> | |
| #pragma pack(4) /* force structure dword packing here. */ | |
| RT_C_DECLS_BEGIN | |
| /** @defgroup grp_vmmdev VMM Device | |
| * | |
| * @note This interface cannot be changed, it can only be extended! | |
| * | |
| * @{ | |
| */ | |
| /** Size of VMMDev RAM region accessible by guest. | |
| * Must be big enough to contain VMMDevMemory structure (see further down). | |
| * For now: 4 megabyte. | |
| */ | |
| #define VMMDEV_RAM_SIZE (4 * 256 * PAGE_SIZE) | |
| /** Size of VMMDev heap region accessible by guest. | |
| * (Must be a power of two (pci range).) | |
| */ | |
| #define VMMDEV_HEAP_SIZE (4 * PAGE_SIZE) | |
| /** Port for generic request interface (relative offset). */ | |
| #define VMMDEV_PORT_OFF_REQUEST 0 | |
| /** @name VMMDev events. | |
| * | |
| * Used mainly by VMMDevReq_AcknowledgeEvents/VMMDevEvents and version 1.3 of | |
| * VMMDevMemory. | |
| * | |
| * @{ | |
| */ | |
| /** Host mouse capabilities has been changed. */ | |
| #define VMMDEV_EVENT_MOUSE_CAPABILITIES_CHANGED RT_BIT(0) | |
| /** HGCM event. */ | |
| #define VMMDEV_EVENT_HGCM RT_BIT(1) | |
| /** A display change request has been issued. */ | |
| #define VMMDEV_EVENT_DISPLAY_CHANGE_REQUEST RT_BIT(2) | |
| /** Credentials are available for judgement. */ | |
| #define VMMDEV_EVENT_JUDGE_CREDENTIALS RT_BIT(3) | |
| /** The guest has been restored. */ | |
| #define VMMDEV_EVENT_RESTORED RT_BIT(4) | |
| /** Seamless mode state changed. */ | |
| #define VMMDEV_EVENT_SEAMLESS_MODE_CHANGE_REQUEST RT_BIT(5) | |
| /** Memory balloon size changed. */ | |
| #define VMMDEV_EVENT_BALLOON_CHANGE_REQUEST RT_BIT(6) | |
| /** Statistics interval changed. */ | |
| #define VMMDEV_EVENT_STATISTICS_INTERVAL_CHANGE_REQUEST RT_BIT(7) | |
| /** VRDP status changed. */ | |
| #define VMMDEV_EVENT_VRDP RT_BIT(8) | |
| /** New mouse position data available. */ | |
| #define VMMDEV_EVENT_MOUSE_POSITION_CHANGED RT_BIT(9) | |
| /** CPU hotplug event occurred. */ | |
| #define VMMDEV_EVENT_CPU_HOTPLUG RT_BIT(10) | |
| /** The mask of valid events, for sanity checking. */ | |
| #define VMMDEV_EVENT_VALID_EVENT_MASK UINT32_C(0x000007ff) | |
| /** @} */ | |
| /** @defgroup grp_vmmdev_req VMMDev Generic Request Interface | |
| * @{ | |
| */ | |
| /** @name Current version of the VMMDev interface. | |
| * | |
| * Additions are allowed to work only if | |
| * additions_major == vmmdev_current && additions_minor <= vmmdev_current. | |
| * Additions version is reported to host (VMMDev) by VMMDevReq_ReportGuestInfo. | |
| * | |
| * @remarks These defines also live in the 16-bit and assembly versions of this | |
| * header. | |
| */ | |
| #define VMMDEV_VERSION 0x00010004 | |
| #define VMMDEV_VERSION_MAJOR (VMMDEV_VERSION >> 16) | |
| #define VMMDEV_VERSION_MINOR (VMMDEV_VERSION & 0xffff) | |
| /** @} */ | |
| /** Maximum request packet size. */ | |
| #define VMMDEV_MAX_VMMDEVREQ_SIZE _1M | |
| /** Maximum number of HGCM parameters. */ | |
| #define VMMDEV_MAX_HGCM_PARMS 1024 | |
| /** Maximum total size of hgcm buffers in one call. */ | |
| #define VMMDEV_MAX_HGCM_DATA_SIZE UINT32_C(0x7FFFFFFF) | |
| /** | |
| * VMMDev request types. | |
| * @note when updating this, adjust vmmdevGetRequestSize() as well | |
| */ | |
| typedef enum | |
| { | |
| VMMDevReq_InvalidRequest = 0, | |
| VMMDevReq_GetMouseStatus = 1, | |
| VMMDevReq_SetMouseStatus = 2, | |
| VMMDevReq_SetPointerShape = 3, | |
| VMMDevReq_GetHostVersion = 4, | |
| VMMDevReq_Idle = 5, | |
| VMMDevReq_GetHostTime = 10, | |
| VMMDevReq_GetHypervisorInfo = 20, | |
| VMMDevReq_SetHypervisorInfo = 21, | |
| VMMDevReq_RegisterPatchMemory = 22, /* since version 3.0.6 */ | |
| VMMDevReq_DeregisterPatchMemory = 23, /* since version 3.0.6 */ | |
| VMMDevReq_SetPowerStatus = 30, | |
| VMMDevReq_AcknowledgeEvents = 41, | |
| VMMDevReq_CtlGuestFilterMask = 42, | |
| VMMDevReq_ReportGuestInfo = 50, | |
| VMMDevReq_ReportGuestInfo2 = 58, /* since version 3.2.0 */ | |
| VMMDevReq_ReportGuestStatus = 59, /* since version 3.2.8 */ | |
| VMMDevReq_ReportGuestUserState = 74, /* since version 4.3 */ | |
| /** | |
| * Retrieve a display resize request sent by the host using | |
| * @a IDisplay:setVideoModeHint. Deprecated. | |
| * | |
| * Similar to @a VMMDevReq_GetDisplayChangeRequest2, except that it only | |
| * considers host requests sent for the first virtual display. This guest | |
| * request should not be used in new guest code, and the results are | |
| * undefined if a guest mixes calls to this and | |
| * @a VMMDevReq_GetDisplayChangeRequest2. | |
| */ | |
| VMMDevReq_GetDisplayChangeRequest = 51, | |
| VMMDevReq_VideoModeSupported = 52, | |
| VMMDevReq_GetHeightReduction = 53, | |
| /** | |
| * Retrieve a display resize request sent by the host using | |
| * @a IDisplay:setVideoModeHint. | |
| * | |
| * Queries a display resize request sent from the host. If the | |
| * @a eventAck member is sent to true and there is an unqueried | |
| * request available for one of the virtual display then that request will | |
| * be returned. If several displays have unqueried requests the lowest | |
| * numbered display will be chosen first. Only the most recent unseen | |
| * request for each display is remembered. | |
| * If @a eventAck is set to false, the last host request queried with | |
| * @a eventAck set is resent, or failing that the most recent received from | |
| * the host. If no host request was ever received then all zeros are | |
| * returned. | |
| */ | |
| VMMDevReq_GetDisplayChangeRequest2 = 54, | |
| VMMDevReq_ReportGuestCapabilities = 55, | |
| VMMDevReq_SetGuestCapabilities = 56, | |
| VMMDevReq_VideoModeSupported2 = 57, /* since version 3.2.0 */ | |
| VMMDevReq_GetDisplayChangeRequestEx = 80, /* since version 4.2.4 */ | |
| #ifdef VBOX_WITH_HGCM | |
| VMMDevReq_HGCMConnect = 60, | |
| VMMDevReq_HGCMDisconnect = 61, | |
| #ifdef VBOX_WITH_64_BITS_GUESTS | |
| VMMDevReq_HGCMCall32 = 62, | |
| VMMDevReq_HGCMCall64 = 63, | |
| #else | |
| VMMDevReq_HGCMCall = 62, | |
| #endif /* VBOX_WITH_64_BITS_GUESTS */ | |
| VMMDevReq_HGCMCancel = 64, | |
| VMMDevReq_HGCMCancel2 = 65, | |
| #endif | |
| VMMDevReq_VideoAccelEnable = 70, | |
| VMMDevReq_VideoAccelFlush = 71, | |
| VMMDevReq_VideoSetVisibleRegion = 72, | |
| VMMDevReq_GetSeamlessChangeRequest = 73, | |
| VMMDevReq_QueryCredentials = 100, | |
| VMMDevReq_ReportCredentialsJudgement = 101, | |
| VMMDevReq_ReportGuestStats = 110, | |
| VMMDevReq_GetMemBalloonChangeRequest = 111, | |
| VMMDevReq_GetStatisticsChangeRequest = 112, | |
| VMMDevReq_ChangeMemBalloon = 113, | |
| VMMDevReq_GetVRDPChangeRequest = 150, | |
| VMMDevReq_LogString = 200, | |
| VMMDevReq_GetCpuHotPlugRequest = 210, | |
| VMMDevReq_SetCpuHotPlugStatus = 211, | |
| VMMDevReq_RegisterSharedModule = 212, | |
| VMMDevReq_UnregisterSharedModule = 213, | |
| VMMDevReq_CheckSharedModules = 214, | |
| VMMDevReq_GetPageSharingStatus = 215, | |
| VMMDevReq_DebugIsPageShared = 216, | |
| VMMDevReq_GetSessionId = 217, /* since version 3.2.8 */ | |
| VMMDevReq_WriteCoreDump = 218, | |
| VMMDevReq_GuestHeartbeat = 219, | |
| VMMDevReq_HeartbeatConfigure = 220, | |
| VMMDevReq_SizeHack = 0x7fffffff | |
| } VMMDevRequestType; | |
| #ifdef VBOX_WITH_64_BITS_GUESTS | |
| /* | |
| * Constants and structures are redefined for the guest. | |
| * | |
| * Host code MUST always use either *32 or *64 variant explicitely. | |
| * Host source code will use VBOX_HGCM_HOST_CODE define to catch undefined | |
| * data types and constants. | |
| * | |
| * This redefinition means that the new additions builds will use | |
| * the *64 or *32 variants depending on the current architecture bit count (ARCH_BITS). | |
| */ | |
| # ifndef VBOX_HGCM_HOST_CODE | |
| # if ARCH_BITS == 64 | |
| # define VMMDevReq_HGCMCall VMMDevReq_HGCMCall64 | |
| # elif ARCH_BITS == 32 | |
| # define VMMDevReq_HGCMCall VMMDevReq_HGCMCall32 | |
| # else | |
| # error "Unsupported ARCH_BITS" | |
| # endif | |
| # endif /* !VBOX_HGCM_HOST_CODE */ | |
| #endif /* VBOX_WITH_64_BITS_GUESTS */ | |
| /** Version of VMMDevRequestHeader structure. */ | |
| #define VMMDEV_REQUEST_HEADER_VERSION (0x10001) | |
| /** | |
| * Generic VMMDev request header. | |
| */ | |
| typedef struct | |
| { | |
| /** IN: Size of the structure in bytes (including body). */ | |
| uint32_t size; | |
| /** IN: Version of the structure. */ | |
| uint32_t version; | |
| /** IN: Type of the request. */ | |
| VMMDevRequestType requestType; | |
| /** OUT: Return code. */ | |
| int32_t rc; | |
| /** Reserved field no.1. MBZ. */ | |
| uint32_t reserved1; | |
| /** Reserved field no.2. MBZ. */ | |
| uint32_t reserved2; | |
| } VMMDevRequestHeader; | |
| AssertCompileSize(VMMDevRequestHeader, 24); | |
| /** | |
| * Mouse status request structure. | |
| * | |
| * Used by VMMDevReq_GetMouseStatus and VMMDevReq_SetMouseStatus. | |
| */ | |
| typedef struct | |
| { | |
| /** header */ | |
| VMMDevRequestHeader header; | |
| /** Mouse feature mask. See VMMDEV_MOUSE_*. */ | |
| uint32_t mouseFeatures; | |
| /** Mouse x position. */ | |
| int32_t pointerXPos; | |
| /** Mouse y position. */ | |
| int32_t pointerYPos; | |
| } VMMDevReqMouseStatus; | |
| AssertCompileSize(VMMDevReqMouseStatus, 24+12); | |
| /** @name Mouse capability bits (VMMDevReqMouseStatus::mouseFeatures). | |
| * @{ */ | |
| /** The guest can (== wants to) handle absolute coordinates. */ | |
| #define VMMDEV_MOUSE_GUEST_CAN_ABSOLUTE RT_BIT(0) | |
| /** The host can (== wants to) send absolute coordinates. | |
| * (Input not captured.) */ | |
| #define VMMDEV_MOUSE_HOST_WANTS_ABSOLUTE RT_BIT(1) | |
| /** The guest can *NOT* switch to software cursor and therefore depends on the | |
| * host cursor. | |
| * | |
| * When guest additions are installed and the host has promised to display the | |
| * cursor itself, the guest installs a hardware mouse driver. Don't ask the | |
| * guest to switch to a software cursor then. */ | |
| #define VMMDEV_MOUSE_GUEST_NEEDS_HOST_CURSOR RT_BIT(2) | |
| /** The host does NOT provide support for drawing the cursor itself. */ | |
| #define VMMDEV_MOUSE_HOST_CANNOT_HWPOINTER RT_BIT(3) | |
| /** The guest can read VMMDev events to find out about pointer movement */ | |
| #define VMMDEV_MOUSE_NEW_PROTOCOL RT_BIT(4) | |
| /** If the guest changes the status of the | |
| * VMMDEV_MOUSE_GUEST_NEEDS_HOST_CURSOR bit, the host will honour this */ | |
| #define VMMDEV_MOUSE_HOST_RECHECKS_NEEDS_HOST_CURSOR RT_BIT(5) | |
| /** The host supplies an absolute pointing device. The Guest Additions may | |
| * wish to use this to decide whether to install their own driver */ | |
| #define VMMDEV_MOUSE_HOST_HAS_ABS_DEV RT_BIT(6) | |
| /** The mask of all VMMDEV_MOUSE_* flags */ | |
| #define VMMDEV_MOUSE_MASK UINT32_C(0x0000007f) | |
| /** The mask of guest capability changes for which notification events should | |
| * be sent */ | |
| #define VMMDEV_MOUSE_NOTIFY_HOST_MASK \ | |
| (VMMDEV_MOUSE_GUEST_CAN_ABSOLUTE | VMMDEV_MOUSE_GUEST_NEEDS_HOST_CURSOR) | |
| /** The mask of all capabilities which the guest can legitimately change */ | |
| #define VMMDEV_MOUSE_GUEST_MASK \ | |
| (VMMDEV_MOUSE_NOTIFY_HOST_MASK | VMMDEV_MOUSE_NEW_PROTOCOL) | |
| /** The mask of host capability changes for which notification events should | |
| * be sent */ | |
| #define VMMDEV_MOUSE_NOTIFY_GUEST_MASK \ | |
| VMMDEV_MOUSE_HOST_WANTS_ABSOLUTE | |
| /** The mask of all capabilities which the host can legitimately change */ | |
| #define VMMDEV_MOUSE_HOST_MASK \ | |
| ( VMMDEV_MOUSE_NOTIFY_GUEST_MASK \ | |
| | VMMDEV_MOUSE_HOST_CANNOT_HWPOINTER \ | |
| | VMMDEV_MOUSE_HOST_RECHECKS_NEEDS_HOST_CURSOR \ | |
| | VMMDEV_MOUSE_HOST_HAS_ABS_DEV) | |
| /** @} */ | |
| /** @name Absolute mouse reporting range | |
| * @{ */ | |
| /** @todo Should these be here? They are needed by both host and guest. */ | |
| /** The minumum value our pointing device can return. */ | |
| #define VMMDEV_MOUSE_RANGE_MIN 0 | |
| /** The maximum value our pointing device can return. */ | |
| #define VMMDEV_MOUSE_RANGE_MAX 0xFFFF | |
| /** The full range our pointing device can return. */ | |
| #define VMMDEV_MOUSE_RANGE (VMMDEV_MOUSE_RANGE_MAX - VMMDEV_MOUSE_RANGE_MIN) | |
| /** @} */ | |
| /** | |
| * Mouse pointer shape/visibility change request. | |
| * | |
| * Used by VMMDevReq_SetPointerShape. The size is variable. | |
| */ | |
| typedef struct VMMDevReqMousePointer | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** VBOX_MOUSE_POINTER_* bit flags. */ | |
| uint32_t fFlags; | |
| /** x coordinate of hot spot. */ | |
| uint32_t xHot; | |
| /** y coordinate of hot spot. */ | |
| uint32_t yHot; | |
| /** Width of the pointer in pixels. */ | |
| uint32_t width; | |
| /** Height of the pointer in scanlines. */ | |
| uint32_t height; | |
| /** Pointer data. | |
| * | |
| **** | |
| * The data consists of 1 bpp AND mask followed by 32 bpp XOR (color) mask. | |
| * | |
| * For pointers without alpha channel the XOR mask pixels are 32 bit values: (lsb)BGR0(msb). | |
| * For pointers with alpha channel the XOR mask consists of (lsb)BGRA(msb) 32 bit values. | |
| * | |
| * Guest driver must create the AND mask for pointers with alpha channel, so if host does not | |
| * support alpha, the pointer could be displayed as a normal color pointer. The AND mask can | |
| * be constructed from alpha values. For example alpha value >= 0xf0 means bit 0 in the AND mask. | |
| * | |
| * The AND mask is 1 bpp bitmap with byte aligned scanlines. Size of AND mask, | |
| * therefore, is cbAnd = (width + 7) / 8 * height. The padding bits at the | |
| * end of any scanline are undefined. | |
| * | |
| * The XOR mask follows the AND mask on the next 4 bytes aligned offset: | |
| * uint8_t *pXor = pAnd + (cbAnd + 3) & ~3 | |
| * Bytes in the gap between the AND and the XOR mask are undefined. | |
| * XOR mask scanlines have no gap between them and size of XOR mask is: | |
| * cXor = width * 4 * height. | |
| **** | |
| * | |
| * Preallocate 4 bytes for accessing actual data as p->pointerData. | |
| */ | |
| char pointerData[4]; | |
| } VMMDevReqMousePointer; | |
| AssertCompileSize(VMMDevReqMousePointer, 24+24); | |
| /** | |
| * Get the size that a VMMDevReqMousePointer request should have for a given | |
| * size of cursor, including the trailing cursor image and mask data. | |
| * @note an "empty" request still has the four preallocated bytes of data | |
| * | |
| * @returns the size | |
| * @param width the cursor width | |
| * @param height the cursor height | |
| */ | |
| DECLINLINE(size_t) vmmdevGetMousePointerReqSize(uint32_t width, uint32_t height) | |
| { | |
| size_t cbBase = RT_OFFSETOF(VMMDevReqMousePointer, pointerData); | |
| size_t cbMask = (width + 7) / 8 * height; | |
| size_t cbArgb = width * height * 4; | |
| return RT_MAX(cbBase + ((cbMask + 3) & ~3) + cbArgb, | |
| sizeof(VMMDevReqMousePointer)); | |
| } | |
| /** @name VMMDevReqMousePointer::fFlags | |
| * @note The VBOX_MOUSE_POINTER_* flags are used in the guest video driver, | |
| * values must be <= 0x8000 and must not be changed. (try make more sense | |
| * of this, please). | |
| * @{ | |
| */ | |
| /** pointer is visible */ | |
| #define VBOX_MOUSE_POINTER_VISIBLE (0x0001) | |
| /** pointer has alpha channel */ | |
| #define VBOX_MOUSE_POINTER_ALPHA (0x0002) | |
| /** pointerData contains new pointer shape */ | |
| #define VBOX_MOUSE_POINTER_SHAPE (0x0004) | |
| /** @} */ | |
| /** | |
| * String log request structure. | |
| * | |
| * Used by VMMDevReq_LogString. | |
| * @deprecated Use the IPRT logger or VbglR3WriteLog instead. | |
| */ | |
| typedef struct | |
| { | |
| /** header */ | |
| VMMDevRequestHeader header; | |
| /** variable length string data */ | |
| char szString[1]; | |
| } VMMDevReqLogString; | |
| AssertCompileSize(VMMDevReqLogString, 24+4); | |
| /** | |
| * VirtualBox host version request structure. | |
| * | |
| * Used by VMMDevReq_GetHostVersion. | |
| * | |
| * @remarks VBGL uses this to detect the precense of new features in the | |
| * interface. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Major version. */ | |
| uint16_t major; | |
| /** Minor version. */ | |
| uint16_t minor; | |
| /** Build number. */ | |
| uint32_t build; | |
| /** SVN revision. */ | |
| uint32_t revision; | |
| /** Feature mask. */ | |
| uint32_t features; | |
| } VMMDevReqHostVersion; | |
| AssertCompileSize(VMMDevReqHostVersion, 24+16); | |
| /** @name VMMDevReqHostVersion::features | |
| * @{ */ | |
| /** Physical page lists are supported by HGCM. */ | |
| #define VMMDEV_HVF_HGCM_PHYS_PAGE_LIST RT_BIT(0) | |
| /** @} */ | |
| /** | |
| * Guest capabilities structure. | |
| * | |
| * Used by VMMDevReq_ReportGuestCapabilities. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Capabilities (VMMDEV_GUEST_*). */ | |
| uint32_t caps; | |
| } VMMDevReqGuestCapabilities; | |
| AssertCompileSize(VMMDevReqGuestCapabilities, 24+4); | |
| /** | |
| * Guest capabilities structure, version 2. | |
| * | |
| * Used by VMMDevReq_SetGuestCapabilities. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Mask of capabilities to be added. */ | |
| uint32_t u32OrMask; | |
| /** Mask of capabilities to be removed. */ | |
| uint32_t u32NotMask; | |
| } VMMDevReqGuestCapabilities2; | |
| AssertCompileSize(VMMDevReqGuestCapabilities2, 24+8); | |
| /** @name Guest capability bits. | |
| * Used by VMMDevReq_ReportGuestCapabilities and VMMDevReq_SetGuestCapabilities. | |
| * @{ */ | |
| /** The guest supports seamless display rendering. */ | |
| #define VMMDEV_GUEST_SUPPORTS_SEAMLESS RT_BIT_32(0) | |
| /** The guest supports mapping guest to host windows. */ | |
| #define VMMDEV_GUEST_SUPPORTS_GUEST_HOST_WINDOW_MAPPING RT_BIT_32(1) | |
| /** The guest graphical additions are active. | |
| * Used for fast activation and deactivation of certain graphical operations | |
| * (e.g. resizing & seamless). The legacy VMMDevReq_ReportGuestCapabilities | |
| * request sets this automatically, but VMMDevReq_SetGuestCapabilities does | |
| * not. */ | |
| #define VMMDEV_GUEST_SUPPORTS_GRAPHICS RT_BIT_32(2) | |
| /** The mask of valid events, for sanity checking. */ | |
| #define VMMDEV_GUEST_CAPABILITIES_MASK UINT32_C(0x00000007) | |
| /** @} */ | |
| /** | |
| * Idle request structure. | |
| * | |
| * Used by VMMDevReq_Idle. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| } VMMDevReqIdle; | |
| AssertCompileSize(VMMDevReqIdle, 24); | |
| /** | |
| * Host time request structure. | |
| * | |
| * Used by VMMDevReq_GetHostTime. | |
| */ | |
| typedef struct | |
| { | |
| /** Header */ | |
| VMMDevRequestHeader header; | |
| /** OUT: Time in milliseconds since unix epoch. */ | |
| uint64_t time; | |
| } VMMDevReqHostTime; | |
| AssertCompileSize(VMMDevReqHostTime, 24+8); | |
| /** | |
| * Hypervisor info structure. | |
| * | |
| * Used by VMMDevReq_GetHypervisorInfo and VMMDevReq_SetHypervisorInfo. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Guest virtual address of proposed hypervisor start. | |
| * Not used by VMMDevReq_GetHypervisorInfo. | |
| * @todo Make this 64-bit compatible? */ | |
| RTGCPTR32 hypervisorStart; | |
| /** Hypervisor size in bytes. */ | |
| uint32_t hypervisorSize; | |
| } VMMDevReqHypervisorInfo; | |
| AssertCompileSize(VMMDevReqHypervisorInfo, 24+8); | |
| /** @name Default patch memory size . | |
| * Used by VMMDevReq_RegisterPatchMemory and VMMDevReq_DeregisterPatchMemory. | |
| * @{ */ | |
| #define VMMDEV_GUEST_DEFAULT_PATCHMEM_SIZE 8192 | |
| /** @} */ | |
| /** | |
| * Patching memory structure. (locked executable & read-only page from the guest's perspective) | |
| * | |
| * Used by VMMDevReq_RegisterPatchMemory and VMMDevReq_DeregisterPatchMemory | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Guest virtual address of the patching page(s). */ | |
| RTGCPTR64 pPatchMem; | |
| /** Patch page size in bytes. */ | |
| uint32_t cbPatchMem; | |
| } VMMDevReqPatchMemory; | |
| AssertCompileSize(VMMDevReqPatchMemory, 24+12); | |
| /** | |
| * Guest power requests. | |
| * | |
| * See VMMDevReq_SetPowerStatus and VMMDevPowerStateRequest. | |
| */ | |
| typedef enum | |
| { | |
| VMMDevPowerState_Invalid = 0, | |
| VMMDevPowerState_Pause = 1, | |
| VMMDevPowerState_PowerOff = 2, | |
| VMMDevPowerState_SaveState = 3, | |
| VMMDevPowerState_SizeHack = 0x7fffffff | |
| } VMMDevPowerState; | |
| AssertCompileSize(VMMDevPowerState, 4); | |
| /** | |
| * VM power status structure. | |
| * | |
| * Used by VMMDevReq_SetPowerStatus. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Power state request. */ | |
| VMMDevPowerState powerState; | |
| } VMMDevPowerStateRequest; | |
| AssertCompileSize(VMMDevPowerStateRequest, 24+4); | |
| /** | |
| * Pending events structure. | |
| * | |
| * Used by VMMDevReq_AcknowledgeEvents. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** OUT: Pending event mask. */ | |
| uint32_t events; | |
| } VMMDevEvents; | |
| AssertCompileSize(VMMDevEvents, 24+4); | |
| /** | |
| * Guest event filter mask control. | |
| * | |
| * Used by VMMDevReq_CtlGuestFilterMask. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Mask of events to be added to the filter. */ | |
| uint32_t u32OrMask; | |
| /** Mask of events to be removed from the filter. */ | |
| uint32_t u32NotMask; | |
| } VMMDevCtlGuestFilterMask; | |
| AssertCompileSize(VMMDevCtlGuestFilterMask, 24+8); | |
| /** | |
| * Guest information structure. | |
| * | |
| * Used by VMMDevReportGuestInfo and PDMIVMMDEVCONNECTOR::pfnUpdateGuestVersion. | |
| */ | |
| typedef struct VBoxGuestInfo | |
| { | |
| /** The VMMDev interface version expected by additions. | |
| * *Deprecated*, do not use anymore! Will be removed. */ | |
| uint32_t interfaceVersion; | |
| /** Guest OS type. */ | |
| VBOXOSTYPE osType; | |
| } VBoxGuestInfo; | |
| AssertCompileSize(VBoxGuestInfo, 8); | |
| /** | |
| * Guest information report. | |
| * | |
| * Used by VMMDevReq_ReportGuestInfo. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Guest information. */ | |
| VBoxGuestInfo guestInfo; | |
| } VMMDevReportGuestInfo; | |
| AssertCompileSize(VMMDevReportGuestInfo, 24+8); | |
| /** | |
| * Guest information structure, version 2. | |
| * | |
| * Used by VMMDevReportGuestInfo2 and PDMIVMMDEVCONNECTOR::pfnUpdateGuestVersion2. | |
| */ | |
| typedef struct VBoxGuestInfo2 | |
| { | |
| /** Major version. */ | |
| uint16_t additionsMajor; | |
| /** Minor version. */ | |
| uint16_t additionsMinor; | |
| /** Build number. */ | |
| uint32_t additionsBuild; | |
| /** SVN revision. */ | |
| uint32_t additionsRevision; | |
| /** Feature mask, currently unused. */ | |
| uint32_t additionsFeatures; | |
| /** The intentional meaning of this field was: | |
| * Some additional information, for example 'Beta 1' or something like that. | |
| * | |
| * The way it was implemented was implemented: VBOX_VERSION_STRING. | |
| * | |
| * This means the first three members are duplicated in this field (if the guest | |
| * build config is sane). So, the user must check this and chop it off before | |
| * usage. There is, because of the Main code's blind trust in the field's | |
| * content, no way back. */ | |
| char szName[128]; | |
| } VBoxGuestInfo2; | |
| AssertCompileSize(VBoxGuestInfo2, 144); | |
| /** | |
| * Guest information report, version 2. | |
| * | |
| * Used by VMMDevReq_ReportGuestInfo2. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Guest information. */ | |
| VBoxGuestInfo2 guestInfo; | |
| } VMMDevReportGuestInfo2; | |
| AssertCompileSize(VMMDevReportGuestInfo2, 24+144); | |
| /** | |
| * The guest facility. | |
| * This needs to be kept in sync with AdditionsFacilityType of the Main API! | |
| */ | |
| typedef enum | |
| { | |
| VBoxGuestFacilityType_Unknown = 0, | |
| VBoxGuestFacilityType_VBoxGuestDriver = 20, | |
| VBoxGuestFacilityType_AutoLogon = 90, /* VBoxGINA / VBoxCredProv / pam_vbox. */ | |
| VBoxGuestFacilityType_VBoxService = 100, | |
| VBoxGuestFacilityType_VBoxTrayClient = 101, /* VBoxTray (Windows), VBoxClient (Linux, Unix). */ | |
| VBoxGuestFacilityType_Seamless = 1000, | |
| VBoxGuestFacilityType_Graphics = 1100, | |
| VBoxGuestFacilityType_All = 0x7ffffffe, | |
| VBoxGuestFacilityType_SizeHack = 0x7fffffff | |
| } VBoxGuestFacilityType; | |
| AssertCompileSize(VBoxGuestFacilityType, 4); | |
| /** | |
| * The current guest status of a facility. | |
| * This needs to be kept in sync with AdditionsFacilityStatus of the Main API! | |
| * | |
| * @remarks r=bird: Pretty please, for future types like this, simply do a | |
| * linear allocation without any gaps. This stuff is impossible work | |
| * efficiently with, let alone validate. Applies to the other facility | |
| * enums too. | |
| */ | |
| typedef enum | |
| { | |
| VBoxGuestFacilityStatus_Inactive = 0, | |
| VBoxGuestFacilityStatus_Paused = 1, | |
| VBoxGuestFacilityStatus_PreInit = 20, | |
| VBoxGuestFacilityStatus_Init = 30, | |
| VBoxGuestFacilityStatus_Active = 50, | |
| VBoxGuestFacilityStatus_Terminating = 100, | |
| VBoxGuestFacilityStatus_Terminated = 101, | |
| VBoxGuestFacilityStatus_Failed = 800, | |
| VBoxGuestFacilityStatus_Unknown = 999, | |
| VBoxGuestFacilityStatus_SizeHack = 0x7fffffff | |
| } VBoxGuestFacilityStatus; | |
| AssertCompileSize(VBoxGuestFacilityStatus, 4); | |
| /** | |
| * The facility class. | |
| * This needs to be kept in sync with AdditionsFacilityClass of the Main API! | |
| */ | |
| typedef enum | |
| { | |
| VBoxGuestFacilityClass_None = 0, | |
| VBoxGuestFacilityClass_Driver = 10, | |
| VBoxGuestFacilityClass_Service = 30, | |
| VBoxGuestFacilityClass_Program = 50, | |
| VBoxGuestFacilityClass_Feature = 100, | |
| VBoxGuestFacilityClass_ThirdParty = 999, | |
| VBoxGuestFacilityClass_All = 0x7ffffffe, | |
| VBoxGuestFacilityClass_SizeHack = 0x7fffffff | |
| } VBoxGuestFacilityClass; | |
| AssertCompileSize(VBoxGuestFacilityClass, 4); | |
| /** | |
| * Guest status structure. | |
| * | |
| * Used by VMMDevReqGuestStatus. | |
| */ | |
| typedef struct VBoxGuestStatus | |
| { | |
| /** Facility the status is indicated for. */ | |
| VBoxGuestFacilityType facility; | |
| /** Current guest status. */ | |
| VBoxGuestFacilityStatus status; | |
| /** Flags, not used at the moment. */ | |
| uint32_t flags; | |
| } VBoxGuestStatus; | |
| AssertCompileSize(VBoxGuestStatus, 12); | |
| /** | |
| * Guest Additions status structure. | |
| * | |
| * Used by VMMDevReq_ReportGuestStatus. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Guest information. */ | |
| VBoxGuestStatus guestStatus; | |
| } VMMDevReportGuestStatus; | |
| AssertCompileSize(VMMDevReportGuestStatus, 24+12); | |
| /** | |
| * The current status of specific guest user. | |
| * This needs to be kept in sync with GuestUserState of the Main API! | |
| */ | |
| typedef enum VBoxGuestUserState | |
| { | |
| VBoxGuestUserState_Unknown = 0, | |
| VBoxGuestUserState_LoggedIn = 1, | |
| VBoxGuestUserState_LoggedOut = 2, | |
| VBoxGuestUserState_Locked = 3, | |
| VBoxGuestUserState_Unlocked = 4, | |
| VBoxGuestUserState_Disabled = 5, | |
| VBoxGuestUserState_Idle = 6, | |
| VBoxGuestUserState_InUse = 7, | |
| VBoxGuestUserState_Created = 8, | |
| VBoxGuestUserState_Deleted = 9, | |
| VBoxGuestUserState_SessionChanged = 10, | |
| VBoxGuestUserState_CredentialsChanged = 11, | |
| VBoxGuestUserState_RoleChanged = 12, | |
| VBoxGuestUserState_GroupAdded = 13, | |
| VBoxGuestUserState_GroupRemoved = 14, | |
| VBoxGuestUserState_Elevated = 15, | |
| VBoxGuestUserState_SizeHack = 0x7fffffff | |
| } VBoxGuestUserState; | |
| AssertCompileSize(VBoxGuestUserState, 4); | |
| /** | |
| * Guest user status updates. | |
| */ | |
| typedef struct VBoxGuestUserStatus | |
| { | |
| /** The guest user state to send. */ | |
| VBoxGuestUserState state; | |
| /** Size (in bytes) of szUser. */ | |
| uint32_t cbUser; | |
| /** Size (in bytes) of szDomain. */ | |
| uint32_t cbDomain; | |
| /** Size (in bytes) of aDetails. */ | |
| uint32_t cbDetails; | |
| /** Note: Here begins the dynamically | |
| * allocated region. */ | |
| /** Guest user to report state for. */ | |
| char szUser[1]; | |
| /** Domain the guest user is bound to. */ | |
| char szDomain[1]; | |
| /** Optional details of the state. */ | |
| uint8_t aDetails[1]; | |
| } VBoxGuestUserStatus; | |
| AssertCompileSize(VBoxGuestUserStatus, 20); | |
| /** | |
| * Guest user status structure. | |
| * | |
| * Used by VMMDevReq_ReportGuestUserStatus. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Guest user status. */ | |
| VBoxGuestUserStatus status; | |
| } VMMDevReportGuestUserState; | |
| AssertCompileSize(VMMDevReportGuestUserState, 24+20); | |
| /** | |
| * Guest statistics structure. | |
| * | |
| * Used by VMMDevReportGuestStats and PDMIVMMDEVCONNECTOR::pfnReportStatistics. | |
| */ | |
| typedef struct VBoxGuestStatistics | |
| { | |
| /** Virtual CPU ID. */ | |
| uint32_t u32CpuId; | |
| /** Reported statistics. */ | |
| uint32_t u32StatCaps; | |
| /** Idle CPU load (0-100) for last interval. */ | |
| uint32_t u32CpuLoad_Idle; | |
| /** Kernel CPU load (0-100) for last interval. */ | |
| uint32_t u32CpuLoad_Kernel; | |
| /** User CPU load (0-100) for last interval. */ | |
| uint32_t u32CpuLoad_User; | |
| /** Nr of threads. */ | |
| uint32_t u32Threads; | |
| /** Nr of processes. */ | |
| uint32_t u32Processes; | |
| /** Nr of handles. */ | |
| uint32_t u32Handles; | |
| /** Memory load (0-100). */ | |
| uint32_t u32MemoryLoad; | |
| /** Page size of guest system. */ | |
| uint32_t u32PageSize; | |
| /** Total physical memory (in 4KB pages). */ | |
| uint32_t u32PhysMemTotal; | |
| /** Available physical memory (in 4KB pages). */ | |
| uint32_t u32PhysMemAvail; | |
| /** Ballooned physical memory (in 4KB pages). */ | |
| uint32_t u32PhysMemBalloon; | |
| /** Total number of committed memory (which is not necessarily in-use) (in 4KB pages). */ | |
| uint32_t u32MemCommitTotal; | |
| /** Total amount of memory used by the kernel (in 4KB pages). */ | |
| uint32_t u32MemKernelTotal; | |
| /** Total amount of paged memory used by the kernel (in 4KB pages). */ | |
| uint32_t u32MemKernelPaged; | |
| /** Total amount of nonpaged memory used by the kernel (in 4KB pages). */ | |
| uint32_t u32MemKernelNonPaged; | |
| /** Total amount of memory used for the system cache (in 4KB pages). */ | |
| uint32_t u32MemSystemCache; | |
| /** Pagefile size (in 4KB pages). */ | |
| uint32_t u32PageFileSize; | |
| } VBoxGuestStatistics; | |
| AssertCompileSize(VBoxGuestStatistics, 19*4); | |
| /** @name Guest statistics values (VBoxGuestStatistics::u32StatCaps). | |
| * @{ */ | |
| #define VBOX_GUEST_STAT_CPU_LOAD_IDLE RT_BIT(0) | |
| #define VBOX_GUEST_STAT_CPU_LOAD_KERNEL RT_BIT(1) | |
| #define VBOX_GUEST_STAT_CPU_LOAD_USER RT_BIT(2) | |
| #define VBOX_GUEST_STAT_THREADS RT_BIT(3) | |
| #define VBOX_GUEST_STAT_PROCESSES RT_BIT(4) | |
| #define VBOX_GUEST_STAT_HANDLES RT_BIT(5) | |
| #define VBOX_GUEST_STAT_MEMORY_LOAD RT_BIT(6) | |
| #define VBOX_GUEST_STAT_PHYS_MEM_TOTAL RT_BIT(7) | |
| #define VBOX_GUEST_STAT_PHYS_MEM_AVAIL RT_BIT(8) | |
| #define VBOX_GUEST_STAT_PHYS_MEM_BALLOON RT_BIT(9) | |
| #define VBOX_GUEST_STAT_MEM_COMMIT_TOTAL RT_BIT(10) | |
| #define VBOX_GUEST_STAT_MEM_KERNEL_TOTAL RT_BIT(11) | |
| #define VBOX_GUEST_STAT_MEM_KERNEL_PAGED RT_BIT(12) | |
| #define VBOX_GUEST_STAT_MEM_KERNEL_NONPAGED RT_BIT(13) | |
| #define VBOX_GUEST_STAT_MEM_SYSTEM_CACHE RT_BIT(14) | |
| #define VBOX_GUEST_STAT_PAGE_FILE_SIZE RT_BIT(15) | |
| /** @} */ | |
| /** | |
| * Guest statistics command structure. | |
| * | |
| * Used by VMMDevReq_ReportGuestStats. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Guest information. */ | |
| VBoxGuestStatistics guestStats; | |
| } VMMDevReportGuestStats; | |
| AssertCompileSize(VMMDevReportGuestStats, 24+19*4); | |
| /** Memory balloon change request structure. */ | |
| #define VMMDEV_MAX_MEMORY_BALLOON(PhysMemTotal) ( (9 * (PhysMemTotal)) / 10 ) | |
| /** | |
| * Poll for ballooning change request. | |
| * | |
| * Used by VMMDevReq_GetMemBalloonChangeRequest. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Balloon size in megabytes. */ | |
| uint32_t cBalloonChunks; | |
| /** Guest ram size in megabytes. */ | |
| uint32_t cPhysMemChunks; | |
| /** Setting this to VMMDEV_EVENT_BALLOON_CHANGE_REQUEST indicates that the | |
| * request is a response to that event. | |
| * (Don't confuse this with VMMDevReq_AcknowledgeEvents.) */ | |
| uint32_t eventAck; | |
| } VMMDevGetMemBalloonChangeRequest; | |
| AssertCompileSize(VMMDevGetMemBalloonChangeRequest, 24+12); | |
| /** | |
| * Change the size of the balloon. | |
| * | |
| * Used by VMMDevReq_ChangeMemBalloon. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** The number of pages in the array. */ | |
| uint32_t cPages; | |
| /** true = inflate, false = deflate. */ | |
| uint32_t fInflate; | |
| /** Physical address (RTGCPHYS) of each page, variable size. */ | |
| RTGCPHYS aPhysPage[1]; | |
| } VMMDevChangeMemBalloon; | |
| AssertCompileSize(VMMDevChangeMemBalloon, 24+16); | |
| /** @name The ballooning chunk size which VMMDev works at. | |
| * @{ */ | |
| #define VMMDEV_MEMORY_BALLOON_CHUNK_PAGES (_1M/4096) | |
| #define VMMDEV_MEMORY_BALLOON_CHUNK_SIZE (VMMDEV_MEMORY_BALLOON_CHUNK_PAGES*4096) | |
| /** @} */ | |
| /** | |
| * Guest statistics interval change request structure. | |
| * | |
| * Used by VMMDevReq_GetStatisticsChangeRequest. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** The interval in seconds. */ | |
| uint32_t u32StatInterval; | |
| /** Setting this to VMMDEV_EVENT_STATISTICS_INTERVAL_CHANGE_REQUEST indicates | |
| * that the request is a response to that event. | |
| * (Don't confuse this with VMMDevReq_AcknowledgeEvents.) */ | |
| uint32_t eventAck; | |
| } VMMDevGetStatisticsChangeRequest; | |
| AssertCompileSize(VMMDevGetStatisticsChangeRequest, 24+8); | |
| /** The size of a string field in the credentials request (including '\\0'). | |
| * @see VMMDevCredentials */ | |
| #define VMMDEV_CREDENTIALS_SZ_SIZE 128 | |
| /** | |
| * Credentials request structure. | |
| * | |
| * Used by VMMDevReq_QueryCredentials. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** IN/OUT: Request flags. */ | |
| uint32_t u32Flags; | |
| /** OUT: User name (UTF-8). */ | |
| char szUserName[VMMDEV_CREDENTIALS_SZ_SIZE]; | |
| /** OUT: Password (UTF-8). */ | |
| char szPassword[VMMDEV_CREDENTIALS_SZ_SIZE]; | |
| /** OUT: Domain name (UTF-8). */ | |
| char szDomain[VMMDEV_CREDENTIALS_SZ_SIZE]; | |
| } VMMDevCredentials; | |
| AssertCompileSize(VMMDevCredentials, 24+4+3*128); | |
| /** @name Credentials request flag (VMMDevCredentials::u32Flags) | |
| * @{ */ | |
| /** query from host whether credentials are present */ | |
| #define VMMDEV_CREDENTIALS_QUERYPRESENCE RT_BIT(1) | |
| /** read credentials from host (can be combined with clear) */ | |
| #define VMMDEV_CREDENTIALS_READ RT_BIT(2) | |
| /** clear credentials on host (can be combined with read) */ | |
| #define VMMDEV_CREDENTIALS_CLEAR RT_BIT(3) | |
| /** read credentials for judgement in the guest */ | |
| #define VMMDEV_CREDENTIALS_READJUDGE RT_BIT(8) | |
| /** clear credentials for judegement on the host */ | |
| #define VMMDEV_CREDENTIALS_CLEARJUDGE RT_BIT(9) | |
| /** report credentials acceptance by guest */ | |
| #define VMMDEV_CREDENTIALS_JUDGE_OK RT_BIT(10) | |
| /** report credentials denial by guest */ | |
| #define VMMDEV_CREDENTIALS_JUDGE_DENY RT_BIT(11) | |
| /** report that no judgement could be made by guest */ | |
| #define VMMDEV_CREDENTIALS_JUDGE_NOJUDGEMENT RT_BIT(12) | |
| /** flag telling the guest that credentials are present */ | |
| #define VMMDEV_CREDENTIALS_PRESENT RT_BIT(16) | |
| /** flag telling guest that local logons should be prohibited */ | |
| #define VMMDEV_CREDENTIALS_NOLOCALLOGON RT_BIT(17) | |
| /** @} */ | |
| /** | |
| * Seamless mode change request structure. | |
| * | |
| * Used by VMMDevReq_GetSeamlessChangeRequest. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** New seamless mode. */ | |
| VMMDevSeamlessMode mode; | |
| /** Setting this to VMMDEV_EVENT_SEAMLESS_MODE_CHANGE_REQUEST indicates | |
| * that the request is a response to that event. | |
| * (Don't confuse this with VMMDevReq_AcknowledgeEvents.) */ | |
| uint32_t eventAck; | |
| } VMMDevSeamlessChangeRequest; | |
| AssertCompileSize(VMMDevSeamlessChangeRequest, 24+8); | |
| AssertCompileMemberOffset(VMMDevSeamlessChangeRequest, eventAck, 24+4); | |
| /** | |
| * Display change request structure. | |
| * | |
| * Used by VMMDevReq_GetDisplayChangeRequest. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Horizontal pixel resolution (0 = do not change). */ | |
| uint32_t xres; | |
| /** Vertical pixel resolution (0 = do not change). */ | |
| uint32_t yres; | |
| /** Bits per pixel (0 = do not change). */ | |
| uint32_t bpp; | |
| /** Setting this to VMMDEV_EVENT_DISPLAY_CHANGE_REQUEST indicates | |
| * that the request is a response to that event. | |
| * (Don't confuse this with VMMDevReq_AcknowledgeEvents.) */ | |
| uint32_t eventAck; | |
| } VMMDevDisplayChangeRequest; | |
| AssertCompileSize(VMMDevDisplayChangeRequest, 24+16); | |
| /** | |
| * Display change request structure, version 2. | |
| * | |
| * Used by VMMDevReq_GetDisplayChangeRequest2. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Horizontal pixel resolution (0 = do not change). */ | |
| uint32_t xres; | |
| /** Vertical pixel resolution (0 = do not change). */ | |
| uint32_t yres; | |
| /** Bits per pixel (0 = do not change). */ | |
| uint32_t bpp; | |
| /** Setting this to VMMDEV_EVENT_DISPLAY_CHANGE_REQUEST indicates | |
| * that the request is a response to that event. | |
| * (Don't confuse this with VMMDevReq_AcknowledgeEvents.) */ | |
| uint32_t eventAck; | |
| /** 0 for primary display, 1 for the first secondary, etc. */ | |
| uint32_t display; | |
| } VMMDevDisplayChangeRequest2; | |
| AssertCompileSize(VMMDevDisplayChangeRequest2, 24+20); | |
| /** | |
| * Display change request structure, version Extended. | |
| * | |
| * Used by VMMDevReq_GetDisplayChangeRequestEx. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Horizontal pixel resolution (0 = do not change). */ | |
| uint32_t xres; | |
| /** Vertical pixel resolution (0 = do not change). */ | |
| uint32_t yres; | |
| /** Bits per pixel (0 = do not change). */ | |
| uint32_t bpp; | |
| /** Setting this to VMMDEV_EVENT_DISPLAY_CHANGE_REQUEST indicates | |
| * that the request is a response to that event. | |
| * (Don't confuse this with VMMDevReq_AcknowledgeEvents.) */ | |
| uint32_t eventAck; | |
| /** 0 for primary display, 1 for the first secondary, etc. */ | |
| uint32_t display; | |
| /** New OriginX of secondary virtual screen */ | |
| uint32_t cxOrigin; | |
| /** New OriginY of secondary virtual screen */ | |
| uint32_t cyOrigin; | |
| /** Change in origin of the secondary virtaul scree is | |
| * required */ | |
| bool fChangeOrigin; | |
| /** secondary virtual screen enabled or disabled */ | |
| bool fEnabled; | |
| } VMMDevDisplayChangeRequestEx; | |
| AssertCompileSize(VMMDevDisplayChangeRequestEx, 24+32); | |
| /** | |
| * Video mode supported request structure. | |
| * | |
| * Used by VMMDevReq_VideoModeSupported. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** IN: Horizontal pixel resolution. */ | |
| uint32_t width; | |
| /** IN: Vertical pixel resolution. */ | |
| uint32_t height; | |
| /** IN: Bits per pixel. */ | |
| uint32_t bpp; | |
| /** OUT: Support indicator. */ | |
| bool fSupported; | |
| } VMMDevVideoModeSupportedRequest; | |
| AssertCompileSize(VMMDevVideoModeSupportedRequest, 24+16); | |
| /** | |
| * Video mode supported request structure for a specific display. | |
| * | |
| * Used by VMMDevReq_VideoModeSupported2. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** IN: The guest display number. */ | |
| uint32_t display; | |
| /** IN: Horizontal pixel resolution. */ | |
| uint32_t width; | |
| /** IN: Vertical pixel resolution. */ | |
| uint32_t height; | |
| /** IN: Bits per pixel. */ | |
| uint32_t bpp; | |
| /** OUT: Support indicator. */ | |
| bool fSupported; | |
| } VMMDevVideoModeSupportedRequest2; | |
| AssertCompileSize(VMMDevVideoModeSupportedRequest2, 24+20); | |
| /** | |
| * Video modes height reduction request structure. | |
| * | |
| * Used by VMMDevReq_GetHeightReduction. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** OUT: Height reduction in pixels. */ | |
| uint32_t heightReduction; | |
| } VMMDevGetHeightReductionRequest; | |
| AssertCompileSize(VMMDevGetHeightReductionRequest, 24+4); | |
| /** | |
| * VRDP change request structure. | |
| * | |
| * Used by VMMDevReq_GetVRDPChangeRequest. | |
| */ | |
| typedef struct | |
| { | |
| /** Header */ | |
| VMMDevRequestHeader header; | |
| /** Whether VRDP is active or not. */ | |
| uint8_t u8VRDPActive; | |
| /** The configured experience level for active VRDP. */ | |
| uint32_t u32VRDPExperienceLevel; | |
| } VMMDevVRDPChangeRequest; | |
| AssertCompileSize(VMMDevVRDPChangeRequest, 24+8); | |
| AssertCompileMemberOffset(VMMDevVRDPChangeRequest, u8VRDPActive, 24); | |
| AssertCompileMemberOffset(VMMDevVRDPChangeRequest, u32VRDPExperienceLevel, 24+4); | |
| /** @name VRDP Experience level (VMMDevVRDPChangeRequest::u32VRDPExperienceLevel) | |
| * @{ */ | |
| #define VRDP_EXPERIENCE_LEVEL_ZERO 0 /**< Theming disabled. */ | |
| #define VRDP_EXPERIENCE_LEVEL_LOW 1 /**< Full window dragging and desktop wallpaper disabled. */ | |
| #define VRDP_EXPERIENCE_LEVEL_MEDIUM 2 /**< Font smoothing, gradients. */ | |
| #define VRDP_EXPERIENCE_LEVEL_HIGH 3 /**< Animation effects disabled. */ | |
| #define VRDP_EXPERIENCE_LEVEL_FULL 4 /**< Everything enabled. */ | |
| /** @} */ | |
| /** | |
| * VBVA enable request structure. | |
| * | |
| * Used by VMMDevReq_VideoAccelEnable. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** 0 - disable, !0 - enable. */ | |
| uint32_t u32Enable; | |
| /** The size of VBVAMEMORY::au8RingBuffer expected by driver. | |
| * The host will refuse to enable VBVA if the size is not equal to | |
| * VBVA_RING_BUFFER_SIZE. | |
| */ | |
| uint32_t cbRingBuffer; | |
| /** Guest initializes the status to 0. Host sets appropriate VBVA_F_STATUS_ flags. */ | |
| uint32_t fu32Status; | |
| } VMMDevVideoAccelEnable; | |
| AssertCompileSize(VMMDevVideoAccelEnable, 24+12); | |
| /** @name VMMDevVideoAccelEnable::fu32Status. | |
| * @{ */ | |
| #define VBVA_F_STATUS_ACCEPTED (0x01) | |
| #define VBVA_F_STATUS_ENABLED (0x02) | |
| /** @} */ | |
| /** | |
| * VBVA flush request structure. | |
| * | |
| * Used by VMMDevReq_VideoAccelFlush. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| } VMMDevVideoAccelFlush; | |
| AssertCompileSize(VMMDevVideoAccelFlush, 24); | |
| /** | |
| * VBVA set visible region request structure. | |
| * | |
| * Used by VMMDevReq_VideoSetVisibleRegion. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Number of rectangles */ | |
| uint32_t cRect; | |
| /** Rectangle array. | |
| * @todo array is spelled aRects[1]. */ | |
| RTRECT Rect; | |
| } VMMDevVideoSetVisibleRegion; | |
| AssertCompileSize(RTRECT, 16); | |
| AssertCompileSize(VMMDevVideoSetVisibleRegion, 24+4+16); | |
| /** | |
| * CPU event types. | |
| */ | |
| typedef enum | |
| { | |
| VMMDevCpuStatusType_Invalid = 0, | |
| VMMDevCpuStatusType_Disable = 1, | |
| VMMDevCpuStatusType_Enable = 2, | |
| VMMDevCpuStatusType_SizeHack = 0x7fffffff | |
| } VMMDevCpuStatusType; | |
| /** | |
| * CPU hotplug event status request. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Status type */ | |
| VMMDevCpuStatusType enmStatusType; | |
| } VMMDevCpuHotPlugStatusRequest; | |
| AssertCompileSize(VMMDevCpuHotPlugStatusRequest, 24+4); | |
| /** | |
| * Get the ID of the changed CPU and event type. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Event type */ | |
| VMMDevCpuEventType enmEventType; | |
| /** core id of the CPU changed */ | |
| uint32_t idCpuCore; | |
| /** package id of the CPU changed */ | |
| uint32_t idCpuPackage; | |
| } VMMDevGetCpuHotPlugRequest; | |
| AssertCompileSize(VMMDevGetCpuHotPlugRequest, 24+4+4+4); | |
| /** | |
| * Shared region description | |
| */ | |
| typedef struct VMMDEVSHAREDREGIONDESC | |
| { | |
| RTGCPTR64 GCRegionAddr; | |
| uint32_t cbRegion; | |
| uint32_t u32Alignment; | |
| } VMMDEVSHAREDREGIONDESC; | |
| AssertCompileSize(VMMDEVSHAREDREGIONDESC, 16); | |
| #define VMMDEVSHAREDREGIONDESC_MAX 32 | |
| /** | |
| * Shared module registration | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Shared module size. */ | |
| uint32_t cbModule; | |
| /** Number of included region descriptors */ | |
| uint32_t cRegions; | |
| /** Base address of the shared module. */ | |
| RTGCPTR64 GCBaseAddr; | |
| /** Guest OS type. */ | |
| VBOXOSFAMILY enmGuestOS; | |
| /** Alignment. */ | |
| uint32_t u32Align; | |
| /** Module name */ | |
| char szName[128]; | |
| /** Module version */ | |
| char szVersion[16]; | |
| /** Shared region descriptor(s). */ | |
| VMMDEVSHAREDREGIONDESC aRegions[1]; | |
| } VMMDevSharedModuleRegistrationRequest; | |
| AssertCompileSize(VMMDevSharedModuleRegistrationRequest, 24+4+4+8+4+4+128+16+16); | |
| /** | |
| * Shared module unregistration | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Shared module size. */ | |
| uint32_t cbModule; | |
| /** Align at 8 byte boundary. */ | |
| uint32_t u32Alignment; | |
| /** Base address of the shared module. */ | |
| RTGCPTR64 GCBaseAddr; | |
| /** Module name */ | |
| char szName[128]; | |
| /** Module version */ | |
| char szVersion[16]; | |
| } VMMDevSharedModuleUnregistrationRequest; | |
| AssertCompileSize(VMMDevSharedModuleUnregistrationRequest, 24+4+4+8+128+16); | |
| /** | |
| * Shared module periodic check | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| } VMMDevSharedModuleCheckRequest; | |
| AssertCompileSize(VMMDevSharedModuleCheckRequest, 24); | |
| /** | |
| * Paging sharing enabled query | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Enabled flag (out) */ | |
| bool fEnabled; | |
| /** Alignment */ | |
| bool fAlignment[3]; | |
| } VMMDevPageSharingStatusRequest; | |
| AssertCompileSize(VMMDevPageSharingStatusRequest, 24+4); | |
| /** | |
| * Page sharing status query (debug build only) | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Page address. */ | |
| RTGCPTR GCPtrPage; | |
| /** Page flags. */ | |
| uint64_t uPageFlags; | |
| /** Shared flag (out) */ | |
| bool fShared; | |
| /** Alignment */ | |
| bool fAlignment[3]; | |
| } VMMDevPageIsSharedRequest; | |
| /** | |
| * Session id request structure. | |
| * | |
| * Used by VMMDevReq_GetSessionId. | |
| */ | |
| typedef struct | |
| { | |
| /** Header */ | |
| VMMDevRequestHeader header; | |
| /** OUT: unique session id; the id will be different after each start, reset or restore of the VM */ | |
| uint64_t idSession; | |
| } VMMDevReqSessionId; | |
| AssertCompileSize(VMMDevReqSessionId, 24+8); | |
| /** | |
| * Write Core Dump request. | |
| * | |
| * Used by VMMDevReq_WriteCoreDump. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** Flags (reserved, MBZ). */ | |
| uint32_t fFlags; | |
| } VMMDevReqWriteCoreDump; | |
| AssertCompileSize(VMMDevReqWriteCoreDump, 24+4); | |
| /** Heart beat check state structure. | |
| * Used by VMMDevReq_HeartbeatConfigure. */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** OUT: Guest heartbeat interval in nanosec. */ | |
| uint64_t cNsInterval; | |
| /** Heartbeat check flag. */ | |
| bool fEnabled; | |
| } VMMDevReqHeartbeat; | |
| AssertCompileSize(VMMDevReqHeartbeat, 24+12); | |
| #ifdef VBOX_WITH_HGCM | |
| /** @name HGCM flags. | |
| * @{ | |
| */ | |
| # define VBOX_HGCM_REQ_DONE RT_BIT_32(VBOX_HGCM_REQ_DONE_BIT) | |
| # define VBOX_HGCM_REQ_DONE_BIT 0 | |
| # define VBOX_HGCM_REQ_CANCELLED (0x2) | |
| /** @} */ | |
| /** | |
| * HGCM request header. | |
| */ | |
| typedef struct VMMDevHGCMRequestHeader | |
| { | |
| /** Request header. */ | |
| VMMDevRequestHeader header; | |
| /** HGCM flags. */ | |
| uint32_t fu32Flags; | |
| /** Result code. */ | |
| int32_t result; | |
| } VMMDevHGCMRequestHeader; | |
| AssertCompileSize(VMMDevHGCMRequestHeader, 24+8); | |
| /** | |
| * HGCM connect request structure. | |
| * | |
| * Used by VMMDevReq_HGCMConnect. | |
| */ | |
| typedef struct | |
| { | |
| /** HGCM request header. */ | |
| VMMDevHGCMRequestHeader header; | |
| /** IN: Description of service to connect to. */ | |
| HGCMServiceLocation loc; | |
| /** OUT: Client identifier assigned by local instance of HGCM. */ | |
| uint32_t u32ClientID; | |
| } VMMDevHGCMConnect; | |
| AssertCompileSize(VMMDevHGCMConnect, 32+132+4); | |
| /** | |
| * HGCM disconnect request structure. | |
| * | |
| * Used by VMMDevReq_HGCMDisconnect. | |
| */ | |
| typedef struct | |
| { | |
| /** HGCM request header. */ | |
| VMMDevHGCMRequestHeader header; | |
| /** IN: Client identifier. */ | |
| uint32_t u32ClientID; | |
| } VMMDevHGCMDisconnect; | |
| AssertCompileSize(VMMDevHGCMDisconnect, 32+4); | |
| /** | |
| * HGCM parameter type. | |
| */ | |
| typedef enum | |
| { | |
| VMMDevHGCMParmType_Invalid = 0, | |
| VMMDevHGCMParmType_32bit = 1, | |
| VMMDevHGCMParmType_64bit = 2, | |
| VMMDevHGCMParmType_PhysAddr = 3, /**< @deprecated Doesn't work, use PageList. */ | |
| VMMDevHGCMParmType_LinAddr = 4, /**< In and Out */ | |
| VMMDevHGCMParmType_LinAddr_In = 5, /**< In (read; host<-guest) */ | |
| VMMDevHGCMParmType_LinAddr_Out = 6, /**< Out (write; host->guest) */ | |
| VMMDevHGCMParmType_LinAddr_Locked = 7, /**< Locked In and Out */ | |
| VMMDevHGCMParmType_LinAddr_Locked_In = 8, /**< Locked In (read; host<-guest) */ | |
| VMMDevHGCMParmType_LinAddr_Locked_Out = 9, /**< Locked Out (write; host->guest) */ | |
| VMMDevHGCMParmType_PageList = 10, /**< Physical addresses of locked pages for a buffer. */ | |
| VMMDevHGCMParmType_SizeHack = 0x7fffffff | |
| } HGCMFunctionParameterType; | |
| AssertCompileSize(HGCMFunctionParameterType, 4); | |
| # ifdef VBOX_WITH_64_BITS_GUESTS | |
| /** | |
| * HGCM function parameter, 32-bit client. | |
| */ | |
| typedef struct | |
| { | |
| HGCMFunctionParameterType type; | |
| union | |
| { | |
| uint32_t value32; | |
| uint64_t value64; | |
| struct | |
| { | |
| uint32_t size; | |
| union | |
| { | |
| RTGCPHYS32 physAddr; | |
| RTGCPTR32 linearAddr; | |
| } u; | |
| } Pointer; | |
| struct | |
| { | |
| uint32_t size; /**< Size of the buffer described by the page list. */ | |
| uint32_t offset; /**< Relative to the request header, valid if size != 0. */ | |
| } PageList; | |
| } u; | |
| # ifdef __cplusplus | |
| void SetUInt32(uint32_t u32) | |
| { | |
| type = VMMDevHGCMParmType_32bit; | |
| u.value64 = 0; /* init unused bits to 0 */ | |
| u.value32 = u32; | |
| } | |
| int GetUInt32(uint32_t *pu32) | |
| { | |
| if (type == VMMDevHGCMParmType_32bit) | |
| { | |
| *pu32 = u.value32; | |
| return VINF_SUCCESS; | |
| } | |
| return VERR_INVALID_PARAMETER; | |
| } | |
| void SetUInt64(uint64_t u64) | |
| { | |
| type = VMMDevHGCMParmType_64bit; | |
| u.value64 = u64; | |
| } | |
| int GetUInt64(uint64_t *pu64) | |
| { | |
| if (type == VMMDevHGCMParmType_64bit) | |
| { | |
| *pu64 = u.value64; | |
| return VINF_SUCCESS; | |
| } | |
| return VERR_INVALID_PARAMETER; | |
| } | |
| void SetPtr(void *pv, uint32_t cb) | |
| { | |
| type = VMMDevHGCMParmType_LinAddr; | |
| u.Pointer.size = cb; | |
| u.Pointer.u.linearAddr = (RTGCPTR32)(uintptr_t)pv; | |
| } | |
| # endif /* __cplusplus */ | |
| } HGCMFunctionParameter32; | |
| AssertCompileSize(HGCMFunctionParameter32, 4+8); | |
| /** | |
| * HGCM function parameter, 64-bit client. | |
| */ | |
| typedef struct | |
| { | |
| HGCMFunctionParameterType type; | |
| union | |
| { | |
| uint32_t value32; | |
| uint64_t value64; | |
| struct | |
| { | |
| uint32_t size; | |
| union | |
| { | |
| RTGCPHYS64 physAddr; | |
| RTGCPTR64 linearAddr; | |
| } u; | |
| } Pointer; | |
| struct | |
| { | |
| uint32_t size; /**< Size of the buffer described by the page list. */ | |
| uint32_t offset; /**< Relative to the request header, valid if size != 0. */ | |
| } PageList; | |
| } u; | |
| # ifdef __cplusplus | |
| void SetUInt32(uint32_t u32) | |
| { | |
| type = VMMDevHGCMParmType_32bit; | |
| u.value64 = 0; /* init unused bits to 0 */ | |
| u.value32 = u32; | |
| } | |
| int GetUInt32(uint32_t *pu32) | |
| { | |
| if (type == VMMDevHGCMParmType_32bit) | |
| { | |
| *pu32 = u.value32; | |
| return VINF_SUCCESS; | |
| } | |
| return VERR_INVALID_PARAMETER; | |
| } | |
| void SetUInt64(uint64_t u64) | |
| { | |
| type = VMMDevHGCMParmType_64bit; | |
| u.value64 = u64; | |
| } | |
| int GetUInt64(uint64_t *pu64) | |
| { | |
| if (type == VMMDevHGCMParmType_64bit) | |
| { | |
| *pu64 = u.value64; | |
| return VINF_SUCCESS; | |
| } | |
| return VERR_INVALID_PARAMETER; | |
| } | |
| void SetPtr(void *pv, uint32_t cb) | |
| { | |
| type = VMMDevHGCMParmType_LinAddr; | |
| u.Pointer.size = cb; | |
| u.Pointer.u.linearAddr = (uintptr_t)pv; | |
| } | |
| # endif /** __cplusplus */ | |
| } HGCMFunctionParameter64; | |
| AssertCompileSize(HGCMFunctionParameter64, 4+12); | |
| /* Redefine the structure type for the guest code. */ | |
| # ifndef VBOX_HGCM_HOST_CODE | |
| # if ARCH_BITS == 64 | |
| # define HGCMFunctionParameter HGCMFunctionParameter64 | |
| # elif ARCH_BITS == 32 | |
| # define HGCMFunctionParameter HGCMFunctionParameter32 | |
| # else | |
| # error "Unsupported sizeof (void *)" | |
| # endif | |
| # endif /* !VBOX_HGCM_HOST_CODE */ | |
| # else /* !VBOX_WITH_64_BITS_GUESTS */ | |
| /** | |
| * HGCM function parameter, 32-bit client. | |
| * | |
| * @todo If this is the same as HGCMFunctionParameter32, why the duplication? | |
| */ | |
| typedef struct | |
| { | |
| HGCMFunctionParameterType type; | |
| union | |
| { | |
| uint32_t value32; | |
| uint64_t value64; | |
| struct | |
| { | |
| uint32_t size; | |
| union | |
| { | |
| RTGCPHYS32 physAddr; | |
| RTGCPTR32 linearAddr; | |
| } u; | |
| } Pointer; | |
| struct | |
| { | |
| uint32_t size; /**< Size of the buffer described by the page list. */ | |
| uint32_t offset; /**< Relative to the request header, valid if size != 0. */ | |
| } PageList; | |
| } u; | |
| # ifdef __cplusplus | |
| void SetUInt32(uint32_t u32) | |
| { | |
| type = VMMDevHGCMParmType_32bit; | |
| u.value64 = 0; /* init unused bits to 0 */ | |
| u.value32 = u32; | |
| } | |
| int GetUInt32(uint32_t *pu32) | |
| { | |
| if (type == VMMDevHGCMParmType_32bit) | |
| { | |
| *pu32 = u.value32; | |
| return VINF_SUCCESS; | |
| } | |
| return VERR_INVALID_PARAMETER; | |
| } | |
| void SetUInt64(uint64_t u64) | |
| { | |
| type = VMMDevHGCMParmType_64bit; | |
| u.value64 = u64; | |
| } | |
| int GetUInt64(uint64_t *pu64) | |
| { | |
| if (type == VMMDevHGCMParmType_64bit) | |
| { | |
| *pu64 = u.value64; | |
| return VINF_SUCCESS; | |
| } | |
| return VERR_INVALID_PARAMETER; | |
| } | |
| void SetPtr(void *pv, uint32_t cb) | |
| { | |
| type = VMMDevHGCMParmType_LinAddr; | |
| u.Pointer.size = cb; | |
| u.Pointer.u.linearAddr = (uintptr_t)pv; | |
| } | |
| # endif /* __cplusplus */ | |
| } HGCMFunctionParameter; | |
| AssertCompileSize(HGCMFunctionParameter, 4+8); | |
| # endif /* !VBOX_WITH_64_BITS_GUESTS */ | |
| /** | |
| * HGCM call request structure. | |
| * | |
| * Used by VMMDevReq_HGCMCall, VMMDevReq_HGCMCall32 and VMMDevReq_HGCMCall64. | |
| */ | |
| typedef struct | |
| { | |
| /* request header */ | |
| VMMDevHGCMRequestHeader header; | |
| /** IN: Client identifier. */ | |
| uint32_t u32ClientID; | |
| /** IN: Service function number. */ | |
| uint32_t u32Function; | |
| /** IN: Number of parameters. */ | |
| uint32_t cParms; | |
| /** Parameters follow in form: HGCMFunctionParameter aParms[X]; */ | |
| } VMMDevHGCMCall; | |
| AssertCompileSize(VMMDevHGCMCall, 32+12); | |
| /** @name Direction of data transfer (HGCMPageListInfo::flags). Bit flags. | |
| * @{ */ | |
| #define VBOX_HGCM_F_PARM_DIRECTION_NONE UINT32_C(0x00000000) | |
| #define VBOX_HGCM_F_PARM_DIRECTION_TO_HOST UINT32_C(0x00000001) | |
| #define VBOX_HGCM_F_PARM_DIRECTION_FROM_HOST UINT32_C(0x00000002) | |
| #define VBOX_HGCM_F_PARM_DIRECTION_BOTH UINT32_C(0x00000003) | |
| /** Macro for validating that the specified flags are valid. */ | |
| #define VBOX_HGCM_F_PARM_ARE_VALID(fFlags) \ | |
| ( (fFlags) > VBOX_HGCM_F_PARM_DIRECTION_NONE \ | |
| && (fFlags) < VBOX_HGCM_F_PARM_DIRECTION_BOTH ) | |
| /** @} */ | |
| /** | |
| * VMMDevHGCMParmType_PageList points to this structure to actually describe the | |
| * buffer. | |
| */ | |
| typedef struct | |
| { | |
| uint32_t flags; /**< VBOX_HGCM_F_PARM_*. */ | |
| uint16_t offFirstPage; /**< Offset in the first page where data begins. */ | |
| uint16_t cPages; /**< Number of pages. */ | |
| RTGCPHYS64 aPages[1]; /**< Page addresses. */ | |
| } HGCMPageListInfo; | |
| AssertCompileSize(HGCMPageListInfo, 4+2+2+8); | |
| /** Get the pointer to the first parmater of a HGCM call request. */ | |
| # define VMMDEV_HGCM_CALL_PARMS(a) ((HGCMFunctionParameter *)((uint8_t *)(a) + sizeof (VMMDevHGCMCall))) | |
| /** Get the pointer to the first parmater of a 32-bit HGCM call request. */ | |
| # define VMMDEV_HGCM_CALL_PARMS32(a) ((HGCMFunctionParameter32 *)((uint8_t *)(a) + sizeof (VMMDevHGCMCall))) | |
| # ifdef VBOX_WITH_64_BITS_GUESTS | |
| /* Explicit defines for the host code. */ | |
| # ifdef VBOX_HGCM_HOST_CODE | |
| # define VMMDEV_HGCM_CALL_PARMS32(a) ((HGCMFunctionParameter32 *)((uint8_t *)(a) + sizeof (VMMDevHGCMCall))) | |
| # define VMMDEV_HGCM_CALL_PARMS64(a) ((HGCMFunctionParameter64 *)((uint8_t *)(a) + sizeof (VMMDevHGCMCall))) | |
| # endif /* VBOX_HGCM_HOST_CODE */ | |
| # endif /* VBOX_WITH_64_BITS_GUESTS */ | |
| # define VBOX_HGCM_MAX_PARMS 32 | |
| /** | |
| * HGCM cancel request structure. | |
| * | |
| * The Cancel request is issued using the same physical memory address as was | |
| * used for the corresponding initial HGCMCall. | |
| * | |
| * Used by VMMDevReq_HGCMCancel. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevHGCMRequestHeader header; | |
| } VMMDevHGCMCancel; | |
| AssertCompileSize(VMMDevHGCMCancel, 32); | |
| /** | |
| * HGCM cancel request structure, version 2. | |
| * | |
| * Used by VMMDevReq_HGCMCancel2. | |
| * | |
| * VINF_SUCCESS when cancelled. | |
| * VERR_NOT_FOUND if the specified request cannot be found. | |
| * VERR_INVALID_PARAMETER if the address is invalid valid. | |
| */ | |
| typedef struct | |
| { | |
| /** Header. */ | |
| VMMDevRequestHeader header; | |
| /** The physical address of the request to cancel. */ | |
| RTGCPHYS32 physReqToCancel; | |
| } VMMDevHGCMCancel2; | |
| AssertCompileSize(VMMDevHGCMCancel2, 24+4); | |
| #endif /* VBOX_WITH_HGCM */ | |
| /** | |
| * Inline helper to determine the request size for the given operation. | |
| * Returns 0 if the given operation is not handled and/or supported. | |
| * | |
| * @returns Size. | |
| * @param requestType The VMMDev request type. | |
| */ | |
| DECLINLINE(size_t) vmmdevGetRequestSize(VMMDevRequestType requestType) | |
| { | |
| switch (requestType) | |
| { | |
| case VMMDevReq_GetMouseStatus: | |
| case VMMDevReq_SetMouseStatus: | |
| return sizeof(VMMDevReqMouseStatus); | |
| case VMMDevReq_SetPointerShape: | |
| return sizeof(VMMDevReqMousePointer); | |
| case VMMDevReq_GetHostVersion: | |
| return sizeof(VMMDevReqHostVersion); | |
| case VMMDevReq_Idle: | |
| return sizeof(VMMDevReqIdle); | |
| case VMMDevReq_GetHostTime: | |
| return sizeof(VMMDevReqHostTime); | |
| case VMMDevReq_GetHypervisorInfo: | |
| case VMMDevReq_SetHypervisorInfo: | |
| return sizeof(VMMDevReqHypervisorInfo); | |
| case VMMDevReq_RegisterPatchMemory: | |
| case VMMDevReq_DeregisterPatchMemory: | |
| return sizeof(VMMDevReqPatchMemory); | |
| case VMMDevReq_SetPowerStatus: | |
| return sizeof(VMMDevPowerStateRequest); | |
| case VMMDevReq_AcknowledgeEvents: | |
| return sizeof(VMMDevEvents); | |
| case VMMDevReq_ReportGuestInfo: | |
| return sizeof(VMMDevReportGuestInfo); | |
| case VMMDevReq_ReportGuestInfo2: | |
| return sizeof(VMMDevReportGuestInfo2); | |
| case VMMDevReq_ReportGuestStatus: | |
| return sizeof(VMMDevReportGuestStatus); | |
| case VMMDevReq_ReportGuestUserState: | |
| return sizeof(VMMDevReportGuestUserState); | |
| case VMMDevReq_GetDisplayChangeRequest: | |
| return sizeof(VMMDevDisplayChangeRequest); | |
| case VMMDevReq_GetDisplayChangeRequest2: | |
| return sizeof(VMMDevDisplayChangeRequest2); | |
| case VMMDevReq_GetDisplayChangeRequestEx: | |
| return sizeof(VMMDevDisplayChangeRequestEx); | |
| case VMMDevReq_VideoModeSupported: | |
| return sizeof(VMMDevVideoModeSupportedRequest); | |
| case VMMDevReq_GetHeightReduction: | |
| return sizeof(VMMDevGetHeightReductionRequest); | |
| case VMMDevReq_ReportGuestCapabilities: | |
| return sizeof(VMMDevReqGuestCapabilities); | |
| case VMMDevReq_SetGuestCapabilities: | |
| return sizeof(VMMDevReqGuestCapabilities2); | |
| #ifdef VBOX_WITH_HGCM | |
| case VMMDevReq_HGCMConnect: | |
| return sizeof(VMMDevHGCMConnect); | |
| case VMMDevReq_HGCMDisconnect: | |
| return sizeof(VMMDevHGCMDisconnect); | |
| #ifdef VBOX_WITH_64_BITS_GUESTS | |
| case VMMDevReq_HGCMCall32: | |
| return sizeof(VMMDevHGCMCall); | |
| case VMMDevReq_HGCMCall64: | |
| return sizeof(VMMDevHGCMCall); | |
| #else | |
| case VMMDevReq_HGCMCall: | |
| return sizeof(VMMDevHGCMCall); | |
| #endif /* VBOX_WITH_64_BITS_GUESTS */ | |
| case VMMDevReq_HGCMCancel: | |
| return sizeof(VMMDevHGCMCancel); | |
| #endif /* VBOX_WITH_HGCM */ | |
| case VMMDevReq_VideoAccelEnable: | |
| return sizeof(VMMDevVideoAccelEnable); | |
| case VMMDevReq_VideoAccelFlush: | |
| return sizeof(VMMDevVideoAccelFlush); | |
| case VMMDevReq_VideoSetVisibleRegion: | |
| /* The original protocol didn't consider a guest with NO visible | |
| * windows */ | |
| return sizeof(VMMDevVideoSetVisibleRegion) - sizeof(RTRECT); | |
| case VMMDevReq_GetSeamlessChangeRequest: | |
| return sizeof(VMMDevSeamlessChangeRequest); | |
| case VMMDevReq_QueryCredentials: | |
| return sizeof(VMMDevCredentials); | |
| case VMMDevReq_ReportGuestStats: | |
| return sizeof(VMMDevReportGuestStats); | |
| case VMMDevReq_GetMemBalloonChangeRequest: | |
| return sizeof(VMMDevGetMemBalloonChangeRequest); | |
| case VMMDevReq_GetStatisticsChangeRequest: | |
| return sizeof(VMMDevGetStatisticsChangeRequest); | |
| case VMMDevReq_ChangeMemBalloon: | |
| return sizeof(VMMDevChangeMemBalloon); | |
| case VMMDevReq_GetVRDPChangeRequest: | |
| return sizeof(VMMDevVRDPChangeRequest); | |
| case VMMDevReq_LogString: | |
| return sizeof(VMMDevReqLogString); | |
| case VMMDevReq_CtlGuestFilterMask: | |
| return sizeof(VMMDevCtlGuestFilterMask); | |
| case VMMDevReq_GetCpuHotPlugRequest: | |
| return sizeof(VMMDevGetCpuHotPlugRequest); | |
| case VMMDevReq_SetCpuHotPlugStatus: | |
| return sizeof(VMMDevCpuHotPlugStatusRequest); | |
| case VMMDevReq_RegisterSharedModule: | |
| return sizeof(VMMDevSharedModuleRegistrationRequest); | |
| case VMMDevReq_UnregisterSharedModule: | |
| return sizeof(VMMDevSharedModuleUnregistrationRequest); | |
| case VMMDevReq_CheckSharedModules: | |
| return sizeof(VMMDevSharedModuleCheckRequest); | |
| case VMMDevReq_GetPageSharingStatus: | |
| return sizeof(VMMDevPageSharingStatusRequest); | |
| case VMMDevReq_DebugIsPageShared: | |
| return sizeof(VMMDevPageIsSharedRequest); | |
| case VMMDevReq_GetSessionId: | |
| return sizeof(VMMDevReqSessionId); | |
| case VMMDevReq_HeartbeatConfigure: | |
| return sizeof(VMMDevReqHeartbeat); | |
| case VMMDevReq_GuestHeartbeat: | |
| return sizeof(VMMDevRequestHeader); | |
| default: | |
| break; | |
| } | |
| return 0; | |
| } | |
| /** | |
| * Initializes a request structure. | |
| * | |
| * @returns VBox status code. | |
| * @param req The request structure to initialize. | |
| * @param type The request type. | |
| */ | |
| DECLINLINE(int) vmmdevInitRequest(VMMDevRequestHeader *req, VMMDevRequestType type) | |
| { | |
| uint32_t requestSize; | |
| if (!req) | |
| return VERR_INVALID_PARAMETER; | |
| requestSize = (uint32_t)vmmdevGetRequestSize(type); | |
| if (!requestSize) | |
| return VERR_INVALID_PARAMETER; | |
| req->size = requestSize; | |
| req->version = VMMDEV_REQUEST_HEADER_VERSION; | |
| req->requestType = type; | |
| req->rc = VERR_GENERAL_FAILURE; | |
| req->reserved1 = 0; | |
| req->reserved2 = 0; | |
| return VINF_SUCCESS; | |
| } | |
| /** @} */ | |
| /** | |
| * VBVA command header. | |
| * | |
| * @todo Where does this fit in? | |
| */ | |
| typedef struct VBVACMDHDR | |
| { | |
| /** Coordinates of affected rectangle. */ | |
| int16_t x; | |
| int16_t y; | |
| uint16_t w; | |
| uint16_t h; | |
| } VBVACMDHDR; | |
| AssertCompileSize(VBVACMDHDR, 8); | |
| /** @name VBVA ring defines. | |
| * | |
| * The VBVA ring buffer is suitable for transferring large (< 2GB) amount of | |
| * data. For example big bitmaps which do not fit to the buffer. | |
| * | |
| * Guest starts writing to the buffer by initializing a record entry in the | |
| * aRecords queue. VBVA_F_RECORD_PARTIAL indicates that the record is being | |
| * written. As data is written to the ring buffer, the guest increases off32End | |
| * for the record. | |
| * | |
| * The host reads the aRecords on flushes and processes all completed records. | |
| * When host encounters situation when only a partial record presents and | |
| * cbRecord & ~VBVA_F_RECORD_PARTIAL >= VBVA_RING_BUFFER_SIZE - | |
| * VBVA_RING_BUFFER_THRESHOLD, the host fetched all record data and updates | |
| * off32Head. After that on each flush the host continues fetching the data | |
| * until the record is completed. | |
| * | |
| */ | |
| #define VBVA_RING_BUFFER_SIZE (_4M - _1K) | |
| #define VBVA_RING_BUFFER_THRESHOLD (4 * _1K) | |
| #define VBVA_MAX_RECORDS (64) | |
| #define VBVA_F_MODE_ENABLED (0x00000001) | |
| #define VBVA_F_MODE_VRDP (0x00000002) | |
| #define VBVA_F_MODE_VRDP_RESET (0x00000004) | |
| #define VBVA_F_MODE_VRDP_ORDER_MASK (0x00000008) | |
| #define VBVA_F_STATE_PROCESSING (0x00010000) | |
| #define VBVA_F_RECORD_PARTIAL (0x80000000) | |
| /** @} */ | |
| /** | |
| * VBVA record. | |
| */ | |
| typedef struct VBVARECORD | |
| { | |
| /** The length of the record. Changed by guest. */ | |
| uint32_t cbRecord; | |
| } VBVARECORD; | |
| AssertCompileSize(VBVARECORD, 4); | |
| /** | |
| * VBVA memory layout. | |
| * | |
| * This is a subsection of the VMMDevMemory structure. | |
| */ | |
| typedef struct VBVAMEMORY | |
| { | |
| /** VBVA_F_MODE_*. */ | |
| uint32_t fu32ModeFlags; | |
| /** The offset where the data start in the buffer. */ | |
| uint32_t off32Data; | |
| /** The offset where next data must be placed in the buffer. */ | |
| uint32_t off32Free; | |
| /** The ring buffer for data. */ | |
| uint8_t au8RingBuffer[VBVA_RING_BUFFER_SIZE]; | |
| /** The queue of record descriptions. */ | |
| VBVARECORD aRecords[VBVA_MAX_RECORDS]; | |
| uint32_t indexRecordFirst; | |
| uint32_t indexRecordFree; | |
| /** RDP orders supported by the client. The guest reports only them | |
| * and falls back to DIRTY rects for not supported ones. | |
| * | |
| * (1 << VBVA_VRDP_*) | |
| */ | |
| uint32_t fu32SupportedOrders; | |
| } VBVAMEMORY; | |
| AssertCompileSize(VBVAMEMORY, 12 + (_4M-_1K) + 4*64 + 12); | |
| /** | |
| * The layout of VMMDEV RAM region that contains information for guest. | |
| */ | |
| typedef struct VMMDevMemory | |
| { | |
| /** The size of this structure. */ | |
| uint32_t u32Size; | |
| /** The structure version. (VMMDEV_MEMORY_VERSION) */ | |
| uint32_t u32Version; | |
| union | |
| { | |
| struct | |
| { | |
| /** Flag telling that VMMDev set the IRQ and acknowlegment is required */ | |
| bool fHaveEvents; | |
| } V1_04; | |
| struct | |
| { | |
| /** Pending events flags, set by host. */ | |
| uint32_t u32HostEvents; | |
| /** Mask of events the guest wants to see, set by guest. */ | |
| uint32_t u32GuestEventMask; | |
| } V1_03; | |
| } V; | |
| VBVAMEMORY vbvaMemory; | |
| } VMMDevMemory; | |
| AssertCompileSize(VMMDevMemory, 8+8 + (12 + (_4M-_1K) + 4*64 + 12) ); | |
| AssertCompileMemberOffset(VMMDevMemory, vbvaMemory, 16); | |
| /** Version of VMMDevMemory structure (VMMDevMemory::u32Version). */ | |
| #define VMMDEV_MEMORY_VERSION (1) | |
| /** @} */ | |
| RT_C_DECLS_END | |
| #pragma pack() | |
| #endif | |