/* SPDX-License-Identifier: (GPL-2.0 OR CDDL-1.0) */ /* * Virtual Device for Guest <-> VMM/Host communication interface * * Copyright (C) 2006-2016 Oracle Corporation */ #ifndef __VBOX_VMMDEV_H__ #define __VBOX_VMMDEV_H__ #include <asm/bitsperlong.h> #include <linux/sizes.h> #include <linux/types.h> #include <linux/vbox_vmmdev_types.h> /* Port for generic request interface (relative offset). */ #define VMMDEV_PORT_OFF_REQUEST 0 /** Layout of VMMDEV RAM region that contains information for guest. */ struct vmmdev_memory { /** The size of this structure. */ u32 size; /** The structure version. (VMMDEV_MEMORY_VERSION) */ u32 version; union { struct { /** Flag telling that VMMDev has events pending. */ u8 have_events; /** Explicit padding, MBZ. */ u8 padding[3]; } V1_04; struct { /** Pending events flags, set by host. */ u32 host_events; /** Mask of events the guest wants, set by guest. */ u32 guest_event_mask; } V1_03; } V; /* struct vbva_memory, not used */ }; VMMDEV_ASSERT_SIZE(vmmdev_memory, 8 + 8); /** Version of vmmdev_memory structure (vmmdev_memory::version). */ #define VMMDEV_MEMORY_VERSION (1) /* Host mouse capabilities has been changed. */ #define VMMDEV_EVENT_MOUSE_CAPABILITIES_CHANGED BIT(0) /* HGCM event. */ #define VMMDEV_EVENT_HGCM BIT(1) /* A display change request has been issued. */ #define VMMDEV_EVENT_DISPLAY_CHANGE_REQUEST BIT(2) /* Credentials are available for judgement. */ #define VMMDEV_EVENT_JUDGE_CREDENTIALS BIT(3) /* The guest has been restored. */ #define VMMDEV_EVENT_RESTORED BIT(4) /* Seamless mode state changed. */ #define VMMDEV_EVENT_SEAMLESS_MODE_CHANGE_REQUEST BIT(5) /* Memory balloon size changed. */ #define VMMDEV_EVENT_BALLOON_CHANGE_REQUEST BIT(6) /* Statistics interval changed. */ #define VMMDEV_EVENT_STATISTICS_INTERVAL_CHANGE_REQUEST BIT(7) /* VRDP status changed. */ #define VMMDEV_EVENT_VRDP BIT(8) /* New mouse position data available. */ #define VMMDEV_EVENT_MOUSE_POSITION_CHANGED BIT(9) /* CPU hotplug event occurred. */ #define VMMDEV_EVENT_CPU_HOTPLUG BIT(10) /* The mask of valid events, for sanity checking. */ #define VMMDEV_EVENT_VALID_EVENT_MASK 0x000007ffU /* * Additions are allowed to work only if additions_major == vmmdev_current && * additions_minor <= vmmdev_current. Additions version is reported to host * (VMMDev) by VMMDEVREQ_REPORT_GUEST_INFO. */ #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 1048576 /* Version of vmmdev_request_header structure. */ #define VMMDEV_REQUEST_HEADER_VERSION 0x10001 /** struct vmmdev_request_header - Generic VMMDev request header. */ struct vmmdev_request_header { /** IN: Size of the structure in bytes (including body). */ u32 size; /** IN: Version of the structure. */ u32 version; /** IN: Type of the request. */ enum vmmdev_request_type request_type; /** OUT: Return code. */ s32 rc; /** Reserved field no.1. MBZ. */ u32 reserved1; /** IN: Requestor information (VMMDEV_REQUESTOR_*) */ u32 requestor; }; VMMDEV_ASSERT_SIZE(vmmdev_request_header, 24); /** * struct vmmdev_mouse_status - Mouse status request structure. * * Used by VMMDEVREQ_GET_MOUSE_STATUS and VMMDEVREQ_SET_MOUSE_STATUS. */ struct vmmdev_mouse_status { /** header */ struct vmmdev_request_header header; /** Mouse feature mask. See VMMDEV_MOUSE_*. */ u32 mouse_features; /** Mouse x position. */ s32 pointer_pos_x; /** Mouse y position. */ s32 pointer_pos_y; }; VMMDEV_ASSERT_SIZE(vmmdev_mouse_status, 24 + 12); /* The guest can (== wants to) handle absolute coordinates. */ #define VMMDEV_MOUSE_GUEST_CAN_ABSOLUTE BIT(0) /* * The host can (== wants to) send absolute coordinates. * (Input not captured.) */ #define VMMDEV_MOUSE_HOST_WANTS_ABSOLUTE 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 BIT(2) /* The host does NOT provide support for drawing the cursor itself. */ #define VMMDEV_MOUSE_HOST_CANNOT_HWPOINTER BIT(3) /* The guest can read VMMDev events to find out about pointer movement */ #define VMMDEV_MOUSE_NEW_PROTOCOL 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 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 BIT(6) /* The minimum 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 /** * struct vmmdev_host_version - VirtualBox host version request structure. * * VBG uses this to detect the precense of new features in the interface. */ struct vmmdev_host_version { /** Header. */ struct vmmdev_request_header header; /** Major version. */ u16 major; /** Minor version. */ u16 minor; /** Build number. */ u32 build; /** SVN revision. */ u32 revision; /** Feature mask. */ u32 features; }; VMMDEV_ASSERT_SIZE(vmmdev_host_version, 24 + 16); /* Physical page lists are supported by HGCM. */ #define VMMDEV_HVF_HGCM_PHYS_PAGE_LIST BIT(0) /** * struct vmmdev_mask - Structure to set / clear bits in a mask used for * VMMDEVREQ_SET_GUEST_CAPABILITIES and VMMDEVREQ_CTL_GUEST_FILTER_MASK. */ struct vmmdev_mask { /** Header. */ struct vmmdev_request_header header; /** Mask of bits to be set. */ u32 or_mask; /** Mask of bits to be cleared. */ u32 not_mask; }; VMMDEV_ASSERT_SIZE(vmmdev_mask, 24 + 8); /* The guest supports seamless display rendering. */ #define VMMDEV_GUEST_SUPPORTS_SEAMLESS BIT(0) /* The guest supports mapping guest to host windows. */ #define VMMDEV_GUEST_SUPPORTS_GUEST_HOST_WINDOW_MAPPING BIT(1) /* * The guest graphical additions are active. * Used for fast activation and deactivation of certain graphical operations * (e.g. resizing & seamless). The legacy VMMDEVREQ_REPORT_GUEST_CAPABILITIES * request sets this automatically, but VMMDEVREQ_SET_GUEST_CAPABILITIES does * not. */ #define VMMDEV_GUEST_SUPPORTS_GRAPHICS BIT(2) /* The mask of valid capabilities, for sanity checking. */ #define VMMDEV_GUEST_CAPABILITIES_MASK 0x00000007U /** struct vmmdev_hypervisorinfo - Hypervisor info structure. */ struct vmmdev_hypervisorinfo { /** Header. */ struct vmmdev_request_header header; /** * Guest virtual address of proposed hypervisor start. * Not used by VMMDEVREQ_GET_HYPERVISOR_INFO. */ u32 hypervisor_start; /** Hypervisor size in bytes. */ u32 hypervisor_size; }; VMMDEV_ASSERT_SIZE(vmmdev_hypervisorinfo, 24 + 8); /** struct vmmdev_events - Pending events structure. */ struct vmmdev_events { /** Header. */ struct vmmdev_request_header header; /** OUT: Pending event mask. */ u32 events; }; VMMDEV_ASSERT_SIZE(vmmdev_events, 24 + 4); #define VMMDEV_OSTYPE_LINUX26 0x53000 #define VMMDEV_OSTYPE_X64 BIT(8) /** struct vmmdev_guestinfo - Guest information report. */ struct vmmdev_guest_info { /** Header. */ struct vmmdev_request_header header; /** * The VMMDev interface version expected by additions. * *Deprecated*, do not use anymore! Will be removed. */ u32 interface_version; /** Guest OS type. */ u32 os_type; }; VMMDEV_ASSERT_SIZE(vmmdev_guest_info, 24 + 8); #define VMMDEV_GUEST_INFO2_ADDITIONS_FEATURES_REQUESTOR_INFO BIT(0) /** struct vmmdev_guestinfo2 - Guest information report, version 2. */ struct vmmdev_guest_info2 { /** Header. */ struct vmmdev_request_header header; /** Major version. */ u16 additions_major; /** Minor version. */ u16 additions_minor; /** Build number. */ u32 additions_build; /** SVN revision. */ u32 additions_revision; /** Feature mask. */ u32 additions_features; /** * 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: VBG_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 name[128]; }; VMMDEV_ASSERT_SIZE(vmmdev_guest_info2, 24 + 144); enum vmmdev_guest_facility_type { VBOXGUEST_FACILITY_TYPE_UNKNOWN = 0, VBOXGUEST_FACILITY_TYPE_VBOXGUEST_DRIVER = 20, /* VBoxGINA / VBoxCredProv / pam_vbox. */ VBOXGUEST_FACILITY_TYPE_AUTO_LOGON = 90, VBOXGUEST_FACILITY_TYPE_VBOX_SERVICE = 100, /* VBoxTray (Windows), VBoxClient (Linux, Unix). */ VBOXGUEST_FACILITY_TYPE_VBOX_TRAY_CLIENT = 101, VBOXGUEST_FACILITY_TYPE_SEAMLESS = 1000, VBOXGUEST_FACILITY_TYPE_GRAPHICS = 1100, VBOXGUEST_FACILITY_TYPE_ALL = 0x7ffffffe, /* Ensure the enum is a 32 bit data-type */ VBOXGUEST_FACILITY_TYPE_SIZEHACK = 0x7fffffff }; enum vmmdev_guest_facility_status { VBOXGUEST_FACILITY_STATUS_INACTIVE = 0, VBOXGUEST_FACILITY_STATUS_PAUSED = 1, VBOXGUEST_FACILITY_STATUS_PRE_INIT = 20, VBOXGUEST_FACILITY_STATUS_INIT = 30, VBOXGUEST_FACILITY_STATUS_ACTIVE = 50, VBOXGUEST_FACILITY_STATUS_TERMINATING = 100, VBOXGUEST_FACILITY_STATUS_TERMINATED = 101, VBOXGUEST_FACILITY_STATUS_FAILED = 800, VBOXGUEST_FACILITY_STATUS_UNKNOWN = 999, /* Ensure the enum is a 32 bit data-type */ VBOXGUEST_FACILITY_STATUS_SIZEHACK = 0x7fffffff }; /** struct vmmdev_guest_status - Guest Additions status structure. */ struct vmmdev_guest_status { /** Header. */ struct vmmdev_request_header header; /** Facility the status is indicated for. */ enum vmmdev_guest_facility_type facility; /** Current guest status. */ enum vmmdev_guest_facility_status status; /** Flags, not used at the moment. */ u32 flags; }; VMMDEV_ASSERT_SIZE(vmmdev_guest_status, 24 + 12); #define VMMDEV_MEMORY_BALLOON_CHUNK_SIZE (1048576) #define VMMDEV_MEMORY_BALLOON_CHUNK_PAGES (1048576 / 4096) /** struct vmmdev_memballoon_info - Memory-balloon info structure. */ struct vmmdev_memballoon_info { /** Header. */ struct vmmdev_request_header header; /** Balloon size in megabytes. */ u32 balloon_chunks; /** Guest ram size in megabytes. */ u32 phys_mem_chunks; /** * Setting this to VMMDEV_EVENT_BALLOON_CHANGE_REQUEST indicates that * the request is a response to that event. * (Don't confuse this with VMMDEVREQ_ACKNOWLEDGE_EVENTS.) */ u32 event_ack; }; VMMDEV_ASSERT_SIZE(vmmdev_memballoon_info, 24 + 12); /** struct vmmdev_memballoon_change - Change the size of the balloon. */ struct vmmdev_memballoon_change { /** Header. */ struct vmmdev_request_header header; /** The number of pages in the array. */ u32 pages; /** true = inflate, false = deflate. */ u32 inflate; /** Physical address (u64) of each page. */ u64 phys_page[VMMDEV_MEMORY_BALLOON_CHUNK_PAGES]; }; /** struct vmmdev_write_core_dump - Write Core Dump request data. */ struct vmmdev_write_core_dump { /** Header. */ struct vmmdev_request_header header; /** Flags (reserved, MBZ). */ u32 flags; }; VMMDEV_ASSERT_SIZE(vmmdev_write_core_dump, 24 + 4); /** struct vmmdev_heartbeat - Heart beat check state structure. */ struct vmmdev_heartbeat { /** Header. */ struct vmmdev_request_header header; /** OUT: Guest heartbeat interval in nanosec. */ u64 interval_ns; /** Heartbeat check flag. */ u8 enabled; /** Explicit padding, MBZ. */ u8 padding[3]; } __packed; VMMDEV_ASSERT_SIZE(vmmdev_heartbeat, 24 + 12); #define VMMDEV_HGCM_REQ_DONE BIT(0) #define VMMDEV_HGCM_REQ_CANCELLED BIT(1) /** struct vmmdev_hgcmreq_header - vmmdev HGCM requests header. */ struct vmmdev_hgcmreq_header { /** Request header. */ struct vmmdev_request_header header; /** HGCM flags. */ u32 flags; /** Result code. */ s32 result; }; VMMDEV_ASSERT_SIZE(vmmdev_hgcmreq_header, 24 + 8); /** struct vmmdev_hgcm_connect - HGCM connect request structure. */ struct vmmdev_hgcm_connect { /** HGCM request header. */ struct vmmdev_hgcmreq_header header; /** IN: Description of service to connect to. */ struct vmmdev_hgcm_service_location loc; /** OUT: Client identifier assigned by local instance of HGCM. */ u32 client_id; }; VMMDEV_ASSERT_SIZE(vmmdev_hgcm_connect, 32 + 132 + 4); /** struct vmmdev_hgcm_disconnect - HGCM disconnect request structure. */ struct vmmdev_hgcm_disconnect { /** HGCM request header. */ struct vmmdev_hgcmreq_header header; /** IN: Client identifier. */ u32 client_id; }; VMMDEV_ASSERT_SIZE(vmmdev_hgcm_disconnect, 32 + 4); #define VMMDEV_HGCM_MAX_PARMS 32 /** struct vmmdev_hgcm_call - HGCM call request structure. */ struct vmmdev_hgcm_call { /* request header */ struct vmmdev_hgcmreq_header header; /** IN: Client identifier. */ u32 client_id; /** IN: Service function number. */ u32 function; /** IN: Number of parameters. */ u32 parm_count; /** Parameters follow in form: HGCMFunctionParameter32|64 parms[X]; */ }; VMMDEV_ASSERT_SIZE(vmmdev_hgcm_call, 32 + 12); /** * struct vmmdev_hgcm_cancel2 - HGCM cancel request structure, version 2. * * After the request header.rc will be: * * VINF_SUCCESS when cancelled. * VERR_NOT_FOUND if the specified request cannot be found. * VERR_INVALID_PARAMETER if the address is invalid valid. */ struct vmmdev_hgcm_cancel2 { /** Header. */ struct vmmdev_request_header header; /** The physical address of the request to cancel. */ u32 phys_req_to_cancel; }; VMMDEV_ASSERT_SIZE(vmmdev_hgcm_cancel2, 24 + 4); #endif