VBoxVideo.h revision 0b2a52ce74bcda1068bacc978648f7a4fa4f83fa
d46ee884c41b808b239563b1978468aae12e33a2vboxsync/** @file
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * VirtualBox Video interface.
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync/*
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * Copyright (C) 2006-2012 Oracle Corporation
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync *
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * This file is part of VirtualBox Open Source Edition (OSE), as
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * available from http://www.virtualbox.org. This file is free software;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * you can redistribute it and/or modify it under the terms of the GNU
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * General Public License (GPL) as published by the Free Software
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * Foundation, in version 2 as it comes in the "COPYING" file of the
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync *
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * The contents of this file may alternatively be used under the terms
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * of the Common Development and Distribution License Version 1.0
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * VirtualBox OSE distribution, in which case the provisions of the
e64031e20c39650a7bc902a3e1aba613b9415deevboxsync * CDDL are applicable instead of those of the GPL.
d46ee884c41b808b239563b1978468aae12e33a2vboxsync *
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * You may elect to license modified versions of this file under the
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * terms and conditions of either the GPL or the CDDL or both.
d46ee884c41b808b239563b1978468aae12e33a2vboxsync */
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync#ifndef ___VBox_VBoxVideo_h
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync#define ___VBox_VBoxVideo_h
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync#include <VBox/VMMDev.h>
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync#include <VBox/Hardware/VBoxVideoVBE.h>
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync#include <iprt/cdefs.h>
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync#include <iprt/types.h>
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync/*
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync * The last 4096 bytes of the guest VRAM contains the generic info for all
1c94c0a63ba68be1a7b2c640e70d7a06464e4fcavboxsync * DualView chunks: sizes and offsets of chunks. This is filled by miniport.
d46ee884c41b808b239563b1978468aae12e33a2vboxsync *
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * Last 4096 bytes of each chunk contain chunk specific data: framebuffer info,
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * etc. This is used exclusively by the corresponding instance of a display driver.
d46ee884c41b808b239563b1978468aae12e33a2vboxsync *
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * The VRAM layout:
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * Last 4096 bytes - Adapter information area.
3b70c9ab3cea93ab1a771d2db319311282041382vboxsync * 4096 bytes aligned miniport heap (value specified in the config rouded up).
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * Slack - what left after dividing the VRAM.
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * 4096 bytes aligned framebuffers:
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * last 4096 bytes of each framebuffer is the display information area.
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync *
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * The Virtual Graphics Adapter information in the guest VRAM is stored by the
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * guest video driver using structures prepended by VBOXVIDEOINFOHDR.
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync *
2a229554eb081e98411c81dcdef146c35a000f80vboxsync * When the guest driver writes dword 0 to the VBE_DISPI_INDEX_VBOX_VIDEO
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * the host starts to process the info. The first element at the start of
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * the 4096 bytes region should be normally be a LINK that points to
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * actual information chain. That way the guest driver can have some
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * fixed layout of the information memory block and just rewrite
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync * the link to point to relevant memory chain.
d46ee884c41b808b239563b1978468aae12e33a2vboxsync *
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * The processing stops at the END element.
d46ee884c41b808b239563b1978468aae12e33a2vboxsync *
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * The host can access the memory only when the port IO is processed.
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync * All data that will be needed later must be copied from these 4096 bytes.
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * But other VRAM can be used by host until the mode is disabled.
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync *
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * The guest driver writes dword 0xffffffff to the VBE_DISPI_INDEX_VBOX_VIDEO
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * to disable the mode.
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync *
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync * VBE_DISPI_INDEX_VBOX_VIDEO is used to read the configuration information
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * from the host and issue commands to the host.
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync *
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * The guest writes the VBE_DISPI_INDEX_VBOX_VIDEO index register, the the
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * following operations with the VBE data register can be performed:
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync *
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * Operation Result
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * write 16 bit value NOP
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * read 16 bit value count of monitors
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * write 32 bit value sets the vbox command value and the command processed by the host
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * read 32 bit value result of the last vbox command is returned
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_PRIMARY_SCREEN 0
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_NO_SCREEN ~0
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* The size of the information. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/*
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * The minimum HGSMI heap size is PAGE_SIZE (4096 bytes) and is a restriction of the
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * runtime heapsimple API. Use minimum 2 pages here, because the info area also may
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync * contain other data (for example HGSMIHOSTFLAGS structure).
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#ifndef VBOX_XPDM_MINIPORT
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync# define VBVA_ADAPTER_INFORMATION_SIZE (64*_1K)
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#else
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBVA_ADAPTER_INFORMATION_SIZE (16*_1K)
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBVA_DISPLAY_INFORMATION_SIZE (64*_1K)
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#endif
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBVA_MIN_BUFFER_SIZE (64*_1K)
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* The value for port IO to let the adapter to interpret the adapter memory. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_DISABLE_ADAPTER_MEMORY 0xFFFFFFFF
64836f6a22eea42b83b0ec64abcb3aa7ccc27f25vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* The value for port IO to let the adapter to interpret the adapter memory. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOX_VIDEO_INTERPRET_ADAPTER_MEMORY 0x00000000
71e8510a26b72d539cf6d7d7157bd87a53de8cf4vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync/* The value for port IO to let the adapter to interpret the display memory.
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync * The display number is encoded in low 16 bits.
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INTERPRET_DISPLAY_MEMORY_BASE 0x00010000
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* The end of the information. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INFO_TYPE_END 0
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* Instructs the host to fetch the next VBOXVIDEOINFOHDR at the given offset of VRAM. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INFO_TYPE_LINK 1
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* Information about a display memory position. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INFO_TYPE_DISPLAY 2
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* Information about a screen. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INFO_TYPE_SCREEN 3
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* Information about host notifications for the driver. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INFO_TYPE_HOST_EVENTS 4
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* Information about non-volatile guest VRAM heap. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INFO_TYPE_NV_HEAP 5
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* VBVA enable/disable. */
64836f6a22eea42b83b0ec64abcb3aa7ccc27f25vboxsync#define VBOX_VIDEO_INFO_TYPE_VBVA_STATUS 6
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* VBVA flush. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INFO_TYPE_VBVA_FLUSH 7
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* Query configuration value. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#define VBOX_VIDEO_INFO_TYPE_QUERY_CONF32 8
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync#pragma pack(1)
d8523ff7d948462e328eec88b602effe2e7f7080vboxsynctypedef struct VBOXVIDEOINFOHDR
b099c6398b85f527d7343cb1da573e1e95f9fd10vboxsync{
b099c6398b85f527d7343cb1da573e1e95f9fd10vboxsync uint8_t u8Type;
b099c6398b85f527d7343cb1da573e1e95f9fd10vboxsync uint8_t u8Reserved;
b099c6398b85f527d7343cb1da573e1e95f9fd10vboxsync uint16_t u16Length;
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync} VBOXVIDEOINFOHDR;
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsynctypedef struct VBOXVIDEOINFOLINK
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync{
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync /* Relative offset in VRAM */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync int32_t i32Offset;
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync} VBOXVIDEOINFOLINK;
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* Resides in adapter info memory. Describes a display VRAM chunk. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsynctypedef struct VBOXVIDEOINFODISPLAY
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* Index of the framebuffer assigned by guest. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32Index;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* Absolute offset in VRAM of the framebuffer to be displayed on the monitor. */
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync uint32_t u32Offset;
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync /* The size of the memory that can be used for the screen. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32FramebufferSize;
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync /* The size of the memory that is used for the Display information.
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * The information is at u32Offset + u32FramebufferSize
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32InformationSize;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync} VBOXVIDEOINFODISPLAY;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync/* Resides in display info area, describes the current video mode. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOX_VIDEO_INFO_SCREEN_F_NONE 0x00
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync#define VBOX_VIDEO_INFO_SCREEN_F_ACTIVE 0x01
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
e33247bff4fddfdba92538374bcc9e2753044a38vboxsynctypedef struct VBOXVIDEOINFOSCREEN
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
64836f6a22eea42b83b0ec64abcb3aa7ccc27f25vboxsync /* Physical X origin relative to the primary screen. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync int32_t xOrigin;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync /* Physical Y origin relative to the primary screen. */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync int32_t yOrigin;
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
e33247bff4fddfdba92538374bcc9e2753044a38vboxsync /* The scan line size in bytes. */
ec037c82be3787508e228c537bd15ad9de28bac0vboxsync uint32_t u32LineSize;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsync /* Width of the screen. */
64836f6a22eea42b83b0ec64abcb3aa7ccc27f25vboxsync uint16_t u16Width;
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* Height of the screen. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint16_t u16Height;
ee00a0b29854e7f513198772bccb6650f6dd2184vboxsync
ee00a0b29854e7f513198772bccb6650f6dd2184vboxsync /* Color depth. */
ee00a0b29854e7f513198772bccb6650f6dd2184vboxsync uint8_t bitsPerPixel;
ee00a0b29854e7f513198772bccb6650f6dd2184vboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync /* VBOX_VIDEO_INFO_SCREEN_F_* */
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync uint8_t u8Flags;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVIDEOINFOSCREEN;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync/* The guest initializes the structure to 0. The positions of the structure in the
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * display info area must not be changed, host will update the structure. Guest checks
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * the events and modifies the structure as a response to host.
23fcbbebf3d2e4d3bf386a8b347ed271078cb9c8vboxsync */
23fcbbebf3d2e4d3bf386a8b347ed271078cb9c8vboxsync#define VBOX_VIDEO_INFO_HOST_EVENTS_F_NONE 0x00000000
23fcbbebf3d2e4d3bf386a8b347ed271078cb9c8vboxsync#define VBOX_VIDEO_INFO_HOST_EVENTS_F_VRDP_RESET 0x00000080
23fcbbebf3d2e4d3bf386a8b347ed271078cb9c8vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVIDEOINFOHOSTEVENTS
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
d46ee884c41b808b239563b1978468aae12e33a2vboxsync /* Host events. */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t fu32Events;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync} VBOXVIDEOINFOHOSTEVENTS;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync/* Resides in adapter info memory. Describes the non-volatile VRAM heap. */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBOXVIDEOINFONVHEAP
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync /* Absolute offset in VRAM of the start of the heap. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32HeapOffset;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* The size of the heap. */
d46ee884c41b808b239563b1978468aae12e33a2vboxsync uint32_t u32HeapSize;
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVIDEOINFONVHEAP;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync/* Display information area. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVIDEOINFOVBVASTATUS
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* Absolute offset in VRAM of the start of the VBVA QUEUE. 0 to disable VBVA. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32QueueOffset;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
3933885bc0c2c93436d858a14564c6179ec72872vboxsync /* The size of the VBVA QUEUE. 0 to disable VBVA. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32QueueSize;
9ca017ceee656f9d33f2cb6652e401b5f17fcfb7vboxsync
fd0cf98cb3eafc5c96b7e95d934b01c5df4785fbvboxsync} VBOXVIDEOINFOVBVASTATUS;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsynctypedef struct VBOXVIDEOINFOVBVAFLUSH
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32DataStart;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32DataEnd;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVIDEOINFOVBVAFLUSH;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync#define VBOX_VIDEO_QCI32_MONITOR_COUNT 0
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOX_VIDEO_QCI32_OFFSCREEN_HEAP_SIZE 1
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVIDEOINFOQUERYCONF32
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32Index;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32Value;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVIDEOINFOQUERYCONF32;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#pragma pack()
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#ifdef VBOX_WITH_VIDEOHWACCEL
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#pragma pack(1)
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_VERSION_MAJ 0
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_VERSION_MIN 0
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_VERSION_BLD 6
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_VERSION_RSV 0
6c2e2f2be39d679eb8e2e371afd146099f8dc5e7vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef enum
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_SURF_CANCREATE = 1,
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync VBOXVHWACMD_TYPE_SURF_CREATE,
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_SURF_DESTROY,
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_SURF_LOCK,
64836f6a22eea42b83b0ec64abcb3aa7ccc27f25vboxsync VBOXVHWACMD_TYPE_SURF_UNLOCK,
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_SURF_BLT,
5ff3fa0492332325f57e80636321619e2224027evboxsync VBOXVHWACMD_TYPE_SURF_FLIP,
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_SURF_OVERLAY_UPDATE,
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_SURF_OVERLAY_SETPOSITION,
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_SURF_COLORKEY_SET,
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_QUERY_INFO1,
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE_QUERY_INFO2,
5ff3fa0492332325f57e80636321619e2224027evboxsync VBOXVHWACMD_TYPE_ENABLE,
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBOXVHWACMD_TYPE_DISABLE,
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBOXVHWACMD_TYPE_HH_CONSTRUCT,
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBOXVHWACMD_TYPE_HH_RESET
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#ifdef VBOX_WITH_WDDM
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync , VBOXVHWACMD_TYPE_SURF_GETINFO
3933885bc0c2c93436d858a14564c6179ec72872vboxsync , VBOXVHWACMD_TYPE_SURF_COLORFILL
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#endif
3933885bc0c2c93436d858a14564c6179ec72872vboxsync , VBOXVHWACMD_TYPE_HH_DISABLE
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync , VBOXVHWACMD_TYPE_HH_ENABLE
3933885bc0c2c93436d858a14564c6179ec72872vboxsync , VBOXVHWACMD_TYPE_HH_SAVESTATE_SAVEBEGIN
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync , VBOXVHWACMD_TYPE_HH_SAVESTATE_SAVEEND
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync , VBOXVHWACMD_TYPE_HH_SAVESTATE_SAVEPERFORM
060f7ec6ae5c99df18341ef2e1f3e91f4b0c89f1vboxsync , VBOXVHWACMD_TYPE_HH_SAVESTATE_LOADPERFORM
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVHWACMD_TYPE;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
3933885bc0c2c93436d858a14564c6179ec72872vboxsync/* the command processing was asynch, set by the host to indicate asynch command completion
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * must not be cleared once set, the command completion is performed by issuing a host->guest completion command
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * while keeping this flag unchanged */
3933885bc0c2c93436d858a14564c6179ec72872vboxsync#define VBOXVHWACMD_FLAG_HG_ASYNCH 0x00010000
fd0cf98cb3eafc5c96b7e95d934b01c5df4785fbvboxsync/* asynch completion is performed by issuing the event */
6e25221ce8ef8e656d1e15eb7ec5cf8ae758ceb2vboxsync#define VBOXVHWACMD_FLAG_GH_ASYNCH_EVENT 0x00000001
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync/* issue interrupt on asynch completion */
060f7ec6ae5c99df18341ef2e1f3e91f4b0c89f1vboxsync#define VBOXVHWACMD_FLAG_GH_ASYNCH_IRQ 0x00000002
9ca017ceee656f9d33f2cb6652e401b5f17fcfb7vboxsync/* guest does not do any op on completion of this command, the host may copy the command and indicate that it does not need the command anymore
fc60d7c6501c5e676e41b11c042d4358d9faa81dvboxsync * by setting the VBOXVHWACMD_FLAG_HG_ASYNCH_RETURNED flag */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWACMD_FLAG_GH_ASYNCH_NOCOMPLETION 0x00000004
5ff3fa0492332325f57e80636321619e2224027evboxsync/* the host has copied the VBOXVHWACMD_FLAG_GH_ASYNCH_NOCOMPLETION command and returned it to the guest */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWACMD_FLAG_HG_ASYNCH_RETURNED 0x00020000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync/* this is the host->host cmd, i.e. a configuration command posted by the host to the framebuffer */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWACMD_FLAG_HH_CMD 0x10000000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBOXVHWACMD
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWACMD_TYPE enmCmd; /* command type */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync volatile int32_t rc; /* command result */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync int32_t iDisplay; /* display index */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync volatile int32_t Flags; /* ored VBOXVHWACMD_FLAG_xxx values */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint64_t GuestVBVAReserved1; /* field internally used by the guest VBVA cmd handling, must NOT be modified by clients */
a12929133f77ffa755a13a7d5d2ff3d87c41c9c5vboxsync uint64_t GuestVBVAReserved2; /* field internally used by the guest VBVA cmd handling, must NOT be modified by clients */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync volatile uint32_t cRefs;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync int32_t Reserved;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync union
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync {
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync struct VBOXVHWACMD *pNext;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t offNext;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint64_t Data; /* the body is 64-bit aligned */
52262a1f2eed7acaf08d8a169159e8201c9da661vboxsync } u;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync char body[1];
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVHWACMD;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWACMD_HEADSIZE() (RT_OFFSETOF(VBOXVHWACMD, body))
fd0cf98cb3eafc5c96b7e95d934b01c5df4785fbvboxsync#define VBOXVHWACMD_SIZE_FROMBODYSIZE(_s) (VBOXVHWACMD_HEADSIZE() + (_s))
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWACMD_SIZE(_tCmd) (VBOXVHWACMD_SIZE_FROMBODYSIZE(sizeof(_tCmd)))
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef unsigned int VBOXVHWACMD_LENGTH;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef uint64_t VBOXVHWA_SURFHANDLE;
10153a147e7cb38821b5e7404bd2ef6b9af5be4avboxsync#define VBOXVHWA_SURFHANDLE_INVALID 0ULL
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWACMD_BODY(_p, _t) ((_t*)(_p)->body)
5ff3fa0492332325f57e80636321619e2224027evboxsync#define VBOXVHWACMD_HEAD(_pb) ((VBOXVHWACMD*)((uint8_t *)(_pb) - RT_OFFSETOF(VBOXVHWACMD, body)))
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBOXVHWA_RECTL
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync int32_t left;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync int32_t top;
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync int32_t right;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync int32_t bottom;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVHWA_RECTL;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVHWA_COLORKEY
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t low;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t high;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync} VBOXVHWA_COLORKEY;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVHWA_PIXELFORMAT
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t flags;
5ff3fa0492332325f57e80636321619e2224027evboxsync uint32_t fourCC;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync union
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync {
4d7634b748d791c1b985e04664cc5d00c6c120f0vboxsync uint32_t rgbBitCount;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t yuvBitCount;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync } c;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync
4d7634b748d791c1b985e04664cc5d00c6c120f0vboxsync union
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync {
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t rgbRBitMask;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t yuvYBitMask;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync } m1;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync union
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync {
4d7634b748d791c1b985e04664cc5d00c6c120f0vboxsync uint32_t rgbGBitMask;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t yuvUBitMask;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync } m2;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync union
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync {
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t rgbBBitMask;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t yuvVBitMask;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync } m3;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync union
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync {
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t rgbABitMask;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync } m4;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t Reserved;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync} VBOXVHWA_PIXELFORMAT;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsynctypedef struct VBOXVHWA_SURFACEDESC
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync{
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t flags;
5d02e7a489b8a8a87f2ab2a3f866ba88794a45a9vboxsync uint32_t height;
5d02e7a489b8a8a87f2ab2a3f866ba88794a45a9vboxsync uint32_t width;
5d02e7a489b8a8a87f2ab2a3f866ba88794a45a9vboxsync uint32_t pitch;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t sizeX;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t sizeY;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t cBackBuffers;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t Reserved;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync VBOXVHWA_COLORKEY DstOverlayCK;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync VBOXVHWA_COLORKEY DstBltCK;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync VBOXVHWA_COLORKEY SrcOverlayCK;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync VBOXVHWA_COLORKEY SrcBltCK;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync VBOXVHWA_PIXELFORMAT PixelFormat;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t surfCaps;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t Reserved2;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync VBOXVHWA_SURFHANDLE hSurf;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint64_t offSurface;
62a515eec8de1b7804ec6997c0f2013fef5c5a6bvboxsync} VBOXVHWA_SURFACEDESC;
62a515eec8de1b7804ec6997c0f2013fef5c5a6bvboxsync
62a515eec8de1b7804ec6997c0f2013fef5c5a6bvboxsynctypedef struct VBOXVHWA_BLTFX
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync{
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t flags;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t rop;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t rotationOp;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t rotation;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t fillColor;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t Reserved;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync VBOXVHWA_COLORKEY DstCK;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync VBOXVHWA_COLORKEY SrcCK;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync} VBOXVHWA_BLTFX;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsynctypedef struct VBOXVHWA_OVERLAYFX
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync{
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t flags;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t Reserved1;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync uint32_t fxFlags;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync uint32_t Reserved2;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync VBOXVHWA_COLORKEY DstCK;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync VBOXVHWA_COLORKEY SrcCK;
85d78ebc068381ca25c84242e38ec4b2be4843a5vboxsync} VBOXVHWA_OVERLAYFX;
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync
cebc93936b5bb4d867e1c086dd1b206db33c31dcvboxsync#define VBOXVHWA_CAPS_BLT 0x00000040
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CAPS_BLTCOLORFILL 0x04000000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CAPS_BLTFOURCC 0x00000100
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CAPS_BLTSTRETCH 0x00000200
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CAPS_BLTQUEUE 0x00000080
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync#define VBOXVHWA_CAPS_OVERLAY 0x00000800
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CAPS_OVERLAYFOURCC 0x00002000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CAPS_OVERLAYSTRETCH 0x00004000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CAPS_OVERLAYCANTCLIP 0x00001000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CAPS_COLORKEY 0x00400000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CAPS_COLORKEYHWASSIST 0x01000000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SCAPS_BACKBUFFER 0x00000004
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_SCAPS_COMPLEX 0x00000008
f62342e2cc901a67e27fa69c0e712ee35e9c4c68vboxsync#define VBOXVHWA_SCAPS_FLIP 0x00000010
53bacf663b35a1570295a15a6eecf2b01b480fd4vboxsync#define VBOXVHWA_SCAPS_FRONTBUFFER 0x00000020
e9f450f285e82c45c58bba8d6d485f62c0561643vboxsync#define VBOXVHWA_SCAPS_OFFSCREENPLAIN 0x00000040
e9f450f285e82c45c58bba8d6d485f62c0561643vboxsync#define VBOXVHWA_SCAPS_OVERLAY 0x00000080
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_SCAPS_PRIMARYSURFACE 0x00000200
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_SCAPS_SYSTEMMEMORY 0x00000800
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_SCAPS_VIDEOMEMORY 0x00004000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_SCAPS_VISIBLE 0x00008000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_SCAPS_LOCALVIDMEM 0x10000000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_PF_PALETTEINDEXED8 0x00000020
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_PF_RGB 0x00000040
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_PF_RGBTOYUV 0x00000100
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_PF_YUV 0x00000200
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_PF_FOURCC 0x00000004
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_LOCK_DISCARDCONTENTS 0x00002000
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_CFG_ENABLED 0x00000001
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SD_BACKBUFFERCOUNT 0x00000020
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SD_CAPS 0x00000001
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SD_CKDESTBLT 0x00004000
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SD_CKDESTOVERLAY 0x00002000
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SD_CKSRCBLT 0x00010000
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SD_CKSRCOVERLAY 0x00008000
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SD_HEIGHT 0x00000002
b604fbf16eda38d14b4999c245f032bfaa5aa85avboxsync#define VBOXVHWA_SD_PITCH 0x00000008
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_SD_PIXELFORMAT 0x00001000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync/*#define VBOXVHWA_SD_REFRESHRATE 0x00040000*/
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#define VBOXVHWA_SD_WIDTH 0x00000004
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CKEYCAPS_DESTBLT 0x00000001
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CKEYCAPS_DESTBLTCLRSPACE 0x00000002
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CKEYCAPS_DESTBLTCLRSPACEYUV 0x00000004
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CKEYCAPS_DESTBLTYUV 0x00000008
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync#define VBOXVHWA_CKEYCAPS_DESTOVERLAY 0x00000010
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#define VBOXVHWA_CKEYCAPS_DESTOVERLAYCLRSPACE 0x00000020
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEYCAPS_DESTOVERLAYCLRSPACEYUV 0x00000040
d3bef44ac7674167abeada174f0d6cf0572249c5vboxsync#define VBOXVHWA_CKEYCAPS_DESTOVERLAYONEACTIVE 0x00000080
d3bef44ac7674167abeada174f0d6cf0572249c5vboxsync#define VBOXVHWA_CKEYCAPS_DESTOVERLAYYUV 0x00000100
cbc68a61f0aa44b3f2b8a24217de2091c3ca2258vboxsync#define VBOXVHWA_CKEYCAPS_SRCBLT 0x00000200
cbc68a61f0aa44b3f2b8a24217de2091c3ca2258vboxsync#define VBOXVHWA_CKEYCAPS_SRCBLTCLRSPACE 0x00000400
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEYCAPS_SRCBLTCLRSPACEYUV 0x00000800
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEYCAPS_SRCBLTYUV 0x00001000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEYCAPS_SRCOVERLAY 0x00002000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEYCAPS_SRCOVERLAYCLRSPACE 0x00004000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CKEYCAPS_SRCOVERLAYCLRSPACEYUV 0x00008000
d3bef44ac7674167abeada174f0d6cf0572249c5vboxsync#define VBOXVHWA_CKEYCAPS_SRCOVERLAYONEACTIVE 0x00010000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEYCAPS_SRCOVERLAYYUV 0x00020000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEYCAPS_NOCOSTOVERLAY 0x00040000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fd0cf98cb3eafc5c96b7e95d934b01c5df4785fbvboxsync#define VBOXVHWA_BLT_COLORFILL 0x00000400
fd0cf98cb3eafc5c96b7e95d934b01c5df4785fbvboxsync#define VBOXVHWA_BLT_DDFX 0x00000800
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_BLT_EXTENDED_FLAGS 0x40000000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_BLT_EXTENDED_LINEAR_CONTENT 0x00000004
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_BLT_EXTENDED_PRESENTATION_STRETCHFACTOR 0x00000010
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_BLT_KEYDESTOVERRIDE 0x00004000
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_BLT_KEYSRCOVERRIDE 0x00010000
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#define VBOXVHWA_BLT_LAST_PRESENTATION 0x20000000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_BLT_PRESENTATION 0x10000000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_BLT_ROP 0x00020000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_OVER_DDFX 0x00080000
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync#define VBOXVHWA_OVER_HIDE 0x00000200
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_OVER_KEYDEST 0x00000400
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_OVER_KEYDESTOVERRIDE 0x00000800
04ee5d908f45a7883257fa7e40fb42bbdbaf24b9vboxsync#define VBOXVHWA_OVER_KEYSRC 0x00001000
04ee5d908f45a7883257fa7e40fb42bbdbaf24b9vboxsync#define VBOXVHWA_OVER_KEYSRCOVERRIDE 0x00002000
04ee5d908f45a7883257fa7e40fb42bbdbaf24b9vboxsync#define VBOXVHWA_OVER_SHOW 0x00004000
04ee5d908f45a7883257fa7e40fb42bbdbaf24b9vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEY_COLORSPACE 0x00000001
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEY_DESTBLT 0x00000002
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CKEY_DESTOVERLAY 0x00000004
04ee5d908f45a7883257fa7e40fb42bbdbaf24b9vboxsync#define VBOXVHWA_CKEY_SRCBLT 0x00000008
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_CKEY_SRCOVERLAY 0x00000010
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_BLT_ARITHSTRETCHY 0x00000001
fd0cf98cb3eafc5c96b7e95d934b01c5df4785fbvboxsync#define VBOXVHWA_BLT_MIRRORLEFTRIGHT 0x00000002
fd0cf98cb3eafc5c96b7e95d934b01c5df4785fbvboxsync#define VBOXVHWA_BLT_MIRRORUPDOWN 0x00000004
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_OVERFX_ARITHSTRETCHY 0x00000001
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_OVERFX_MIRRORLEFTRIGHT 0x00000002
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#define VBOXVHWA_OVERFX_MIRRORUPDOWN 0x00000004
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CAPS2_CANRENDERWINDOWED 0x00080000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CAPS2_WIDESURFACES 0x00001000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_CAPS2_COPYFOURCC 0x00008000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync/*#define VBOXVHWA_CAPS2_FLIPINTERVAL 0x00200000*/
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync/*#define VBOXVHWA_CAPS2_FLIPNOVSYNC 0x00400000*/
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWA_OFFSET64_VOID (UINT64_MAX)
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVHWA_VERSION
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t maj;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t min;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t bld;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t reserved;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync} VBOXVHWA_VERSION;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_VERSION_INIT(_pv) do { \
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync (_pv)->maj = VBOXVHWA_VERSION_MAJ; \
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync (_pv)->min = VBOXVHWA_VERSION_MIN; \
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync (_pv)->bld = VBOXVHWA_VERSION_BLD; \
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync (_pv)->reserved = VBOXVHWA_VERSION_RSV; \
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync } while(0)
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVHWACMD_QUERYINFO1
d46ee884c41b808b239563b1978468aae12e33a2vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync union
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync {
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync struct
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync {
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBOXVHWA_VERSION guestVersion;
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync } in;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync struct
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync {
f1301dd8b6870b5a25c7dbdd46e0a0671bb62031vboxsync uint32_t cfgFlags;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t caps;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t caps2;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t colorKeyCaps;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t stretchCaps;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t surfaceCaps;
f1301dd8b6870b5a25c7dbdd46e0a0671bb62031vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t numOverlays;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t curOverlays;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t numFourCC;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t reserved;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync } out;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync } u;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync} VBOXVHWACMD_QUERYINFO1;
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVHWACMD_QUERYINFO2
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t numFourCC;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t FourCC[1];
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVHWACMD_QUERYINFO2;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWAINFO2_SIZE(_cFourCC) RT_OFFSETOF(VBOXVHWACMD_QUERYINFO2, FourCC[_cFourCC])
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVHWACMD_SURF_CANCREATE
fd0cf98cb3eafc5c96b7e95d934b01c5df4785fbvboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWA_SURFACEDESC SurfInfo;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync union
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync {
d46ee884c41b808b239563b1978468aae12e33a2vboxsync struct
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync {
d46ee884c41b808b239563b1978468aae12e33a2vboxsync uint32_t bIsDifferentPixelFormat;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t Reserved;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync } in;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync struct
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync {
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync int32_t ErrInfo;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync } out;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync } u;
1ea22ca610c19eb455275a4398575b6291c27629vboxsync} VBOXVHWACMD_SURF_CANCREATE;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsynctypedef struct VBOXVHWACMD_SURF_CREATE
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync{
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync VBOXVHWA_SURFACEDESC SurfInfo;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync} VBOXVHWACMD_SURF_CREATE;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#ifdef VBOX_WITH_WDDM
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBOXVHWACMD_SURF_GETINFO
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBOXVHWA_SURFACEDESC SurfInfo;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync} VBOXVHWACMD_SURF_GETINFO;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#endif
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBOXVHWACMD_SURF_DESTROY
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync union
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync {
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync struct
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync {
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync VBOXVHWA_SURFHANDLE hSurf;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync } in;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync } u;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync} VBOXVHWACMD_SURF_DESTROY;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsynctypedef struct VBOXVHWACMD_SURF_LOCK
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync union
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync {
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync struct
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync {
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBOXVHWA_SURFHANDLE hSurf;
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync uint64_t offSurface;
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync uint32_t flags;
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync uint32_t rectValid;
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync VBOXVHWA_RECTL rect;
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync } in;
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync } u;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync} VBOXVHWACMD_SURF_LOCK;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBOXVHWACMD_SURF_UNLOCK
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync union
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync {
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync struct
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync {
6e12ccc60ac657fb87e27b7a2b26e0a63bebe024vboxsync VBOXVHWA_SURFHANDLE hSurf;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint32_t xUpdatedMemValid;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint32_t reserved;
63b785c3291332a86a9bc473e68f08121368898bvboxsync VBOXVHWA_RECTL xUpdatedMemRect;
63b785c3291332a86a9bc473e68f08121368898bvboxsync } in;
63b785c3291332a86a9bc473e68f08121368898bvboxsync } u;
63b785c3291332a86a9bc473e68f08121368898bvboxsync} VBOXVHWACMD_SURF_UNLOCK;
63b785c3291332a86a9bc473e68f08121368898bvboxsync
63b785c3291332a86a9bc473e68f08121368898bvboxsynctypedef struct VBOXVHWACMD_SURF_BLT
63b785c3291332a86a9bc473e68f08121368898bvboxsync{
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint64_t DstGuestSurfInfo;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint64_t SrcGuestSurfInfo;
63b785c3291332a86a9bc473e68f08121368898bvboxsync union
63b785c3291332a86a9bc473e68f08121368898bvboxsync {
63b785c3291332a86a9bc473e68f08121368898bvboxsync struct
63b785c3291332a86a9bc473e68f08121368898bvboxsync {
63b785c3291332a86a9bc473e68f08121368898bvboxsync VBOXVHWA_SURFHANDLE hDstSurf;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint64_t offDstSurface;
63b785c3291332a86a9bc473e68f08121368898bvboxsync VBOXVHWA_RECTL dstRect;
63b785c3291332a86a9bc473e68f08121368898bvboxsync VBOXVHWA_SURFHANDLE hSrcSurf;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint64_t offSrcSurface;
63b785c3291332a86a9bc473e68f08121368898bvboxsync VBOXVHWA_RECTL srcRect;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint32_t flags;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint32_t xUpdatedSrcMemValid;
63b785c3291332a86a9bc473e68f08121368898bvboxsync VBOXVHWA_BLTFX desc;
63b785c3291332a86a9bc473e68f08121368898bvboxsync VBOXVHWA_RECTL xUpdatedSrcMemRect;
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync } in;
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync } u;
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync} VBOXVHWACMD_SURF_BLT;
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync#ifdef VBOX_WITH_WDDM
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsynctypedef struct VBOXVHWACMD_SURF_COLORFILL
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync{
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync union
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync {
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync struct
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync {
63b785c3291332a86a9bc473e68f08121368898bvboxsync VBOXVHWA_SURFHANDLE hSurf;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint64_t offSurface;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint32_t u32Reserved;
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync uint32_t cRects;
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync VBOXVHWA_RECTL aRects[1];
63b785c3291332a86a9bc473e68f08121368898bvboxsync } in;
63b785c3291332a86a9bc473e68f08121368898bvboxsync } u;
63b785c3291332a86a9bc473e68f08121368898bvboxsync} VBOXVHWACMD_SURF_COLORFILL;
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync#endif
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsynctypedef struct VBOXVHWACMD_SURF_FLIP
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync{
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync uint64_t TargGuestSurfInfo;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync uint64_t CurrGuestSurfInfo;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync union
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync {
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync struct
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync {
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync VBOXVHWA_SURFHANDLE hTargSurf;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync uint64_t offTargSurface;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync VBOXVHWA_SURFHANDLE hCurrSurf;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync uint64_t offCurrSurface;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync uint32_t flags;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync uint32_t xUpdatedTargMemValid;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync VBOXVHWA_RECTL xUpdatedTargMemRect;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync } in;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync } u;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync} VBOXVHWACMD_SURF_FLIP;
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsynctypedef struct VBOXVHWACMD_SURF_COLORKEY_SET
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync{
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync union
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync {
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync struct
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync {
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsync VBOXVHWA_SURFHANDLE hSurf;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint64_t offSurface;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBOXVHWA_COLORKEY CKey;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t flags;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t reserved;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync } in;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync } u;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync} VBOXVHWACMD_SURF_COLORKEY_SET;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync#define VBOXVHWACMD_SURF_OVERLAY_UPDATE_F_SRCMEMRECT 0x00000001
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOXVHWACMD_SURF_OVERLAY_UPDATE_F_DSTMEMRECT 0x00000002
606bf1f8cb2c02eb19f231f75e56417f0439951fvboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsynctypedef struct VBOXVHWACMD_SURF_OVERLAY_UPDATE
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync union
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync {
ad9e5a61fea617d40d07390ff1737277d6aef869vboxsync struct
d46ee884c41b808b239563b1978468aae12e33a2vboxsync {
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWA_SURFHANDLE hDstSurf;
2c744347b35ec425c206a25ca4095d30a12474d9vboxsync uint64_t offDstSurface;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWA_RECTL dstRect;
c33fc49611f2444dade533488bf431e29eb88bcdvboxsync VBOXVHWA_SURFHANDLE hSrcSurf;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint64_t offSrcSurface;
0f8a368b17f9c3e1ef58be06f4bf290d4bb0a729vboxsync VBOXVHWA_RECTL srcRect;
7119861e2c17e0a4e0638b06a544cc571cf6804avboxsync uint32_t flags;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t xFlags;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWA_OVERLAYFX desc;
7a5aa60c341d7f14da337f31a3ed1afcee98bc8avboxsync VBOXVHWA_RECTL xUpdatedSrcMemRect;
7a5aa60c341d7f14da337f31a3ed1afcee98bc8avboxsync VBOXVHWA_RECTL xUpdatedDstMemRect;
7a5aa60c341d7f14da337f31a3ed1afcee98bc8avboxsync } in;
657b2c9f6d33f08001e5fa6f6e0572dcf0391013vboxsync } u;
7a5aa60c341d7f14da337f31a3ed1afcee98bc8avboxsync}VBOXVHWACMD_SURF_OVERLAY_UPDATE;
34aaaf212fe61ccafbae15eb832d6062ba548799vboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsynctypedef struct VBOXVHWACMD_SURF_OVERLAY_SETPOSITION
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
d46ee884c41b808b239563b1978468aae12e33a2vboxsync union
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync {
d46ee884c41b808b239563b1978468aae12e33a2vboxsync struct
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync {
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWA_SURFHANDLE hDstSurf;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint64_t offDstSurface;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync VBOXVHWA_SURFHANDLE hSrcSurf;
b35e3948f1287430503b6b432945b8cf4bfd3a23vboxsync uint64_t offSrcSurface;
7a5aa60c341d7f14da337f31a3ed1afcee98bc8avboxsync uint32_t xPos;
c606fa3531314e32f0ae90495618aeae47418477vboxsync uint32_t yPos;
c606fa3531314e32f0ae90495618aeae47418477vboxsync uint32_t flags;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync uint32_t reserved;
d70f332ce412cf75187ceda26709e58e4edc69ecvboxsync } in;
d70f332ce412cf75187ceda26709e58e4edc69ecvboxsync } u;
3933885bc0c2c93436d858a14564c6179ec72872vboxsync} VBOXVHWACMD_SURF_OVERLAY_SETPOSITION;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVHWACMD_HH_CONSTRUCT
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync void *pVM;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* VRAM info for the backend to be able to properly translate VRAM offsets */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync void *pvVRAM;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t cbVRAM;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync} VBOXVHWACMD_HH_CONSTRUCT;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBOXVHWACMD_HH_SAVESTATE_SAVEPERFORM
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync struct SSMHANDLE * pSSM;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync} VBOXVHWACMD_HH_SAVESTATE_SAVEPERFORM;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
60be873116377f59c5b5380ecfe531760eb3308cvboxsynctypedef struct VBOXVHWACMD_HH_SAVESTATE_LOADPERFORM
d46ee884c41b808b239563b1978468aae12e33a2vboxsync{
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync struct SSMHANDLE * pSSM;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBOXVHWACMD_HH_SAVESTATE_LOADPERFORM;
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsync
2dad255b092a5659ea0274b9385e2019ad040ea7vboxsynctypedef DECLCALLBACK(void) FNVBOXVHWA_HH_CALLBACK(void*);
342d1c2e846281e0bcbde2e97218273216b3fb32vboxsynctypedef FNVBOXVHWA_HH_CALLBACK *PFNVBOXVHWA_HH_CALLBACK;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#define VBOXVHWA_HH_CALLBACK_SET(_pCmd, _pfn, _parg) \
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync do { \
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync (_pCmd)->GuestVBVAReserved1 = (uint64_t)(uintptr_t)(_pfn); \
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync (_pCmd)->GuestVBVAReserved2 = (uint64_t)(uintptr_t)(_parg); \
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync }while(0)
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_HH_CALLBACK_GET(_pCmd) ((PFNVBOXVHWA_HH_CALLBACK)(_pCmd)->GuestVBVAReserved1)
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBOXVHWA_HH_CALLBACK_GET_ARG(_pCmd) ((void*)(_pCmd)->GuestVBVAReserved2)
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#pragma pack()
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync#endif /* #ifdef VBOX_WITH_VIDEOHWACCEL */
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync/* All structures are without alignment. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#pragma pack(1)
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsynctypedef struct VBVAHOSTFLAGS
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint32_t u32HostEvents;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32SupportedOrders;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBVAHOSTFLAGS;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBVABUFFER
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync{
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync VBVAHOSTFLAGS hostFlags;
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync /* The offset where the data start in the buffer. */
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync uint32_t off32Data;
10153a147e7cb38821b5e7404bd2ef6b9af5be4avboxsync /* The offset where next data must be placed in the buffer. */
10153a147e7cb38821b5e7404bd2ef6b9af5be4avboxsync uint32_t off32Free;
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync /* The queue of record descriptions. */
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync VBVARECORD aRecords[VBVA_MAX_RECORDS];
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync uint32_t indexRecordFirst;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t indexRecordFree;
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync /* Space to leave free in the buffer when large partial records are transferred. */
fc148a6b23d25a87561beaffe0ba06c3ba93bf5avboxsync uint32_t cbPartialWriteThreshold;
63b785c3291332a86a9bc473e68f08121368898bvboxsync
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint32_t cbData;
63b785c3291332a86a9bc473e68f08121368898bvboxsync uint8_t au8Data[1]; /* variable size for the rest of the VBVABUFFER area in VRAM. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync} VBVABUFFER;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsync/* guest->host commands */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_QUERY_CONF32 1
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_SET_CONF32 2
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_INFO_VIEW 3
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_INFO_HEAP 4
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_FLUSH 5
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync#define VBVA_INFO_SCREEN 6
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVA_ENABLE 7
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVA_MOUSE_POINTER_SHAPE 8
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#ifdef VBOX_WITH_VIDEOHWACCEL
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync# define VBVA_VHWA_CMD 9
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#endif /* # ifdef VBOX_WITH_VIDEOHWACCEL */
c8faf7a704e698dec3679d7df43ae55b1bab3eadvboxsync#ifdef VBOX_WITH_VDMA
aceec09dd145a4d6fb14f2ea75a459cc88b334abvboxsync# define VBVA_VDMA_CTL 10 /* setup G<->H DMA channel info */
bf88068260ded16af90b7da4867240fbdd9c8017vboxsync# define VBVA_VDMA_CMD 11 /* G->H DMA command */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#endif
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVA_INFO_CAPS 12 /* informs host about HGSMI caps. see VBVACAPS below */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVA_SCANLINE_CFG 13 /* configures scanline, see VBVASCANLINECFG below */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVA_SCANLINE_INFO 14 /* requests scanline info, see VBVASCANLINEINFO below */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVA_CMDVBVA_SUBMIT 16 /* inform host about VBVA Command submission */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVA_CMDVBVA_FLUSH 17 /* inform host about VBVA Command submission */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_CMDVBVA_CTL 18 /* G->H DMA command */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync/* host->guest commands */
89de31eab6e960abcacfb70916598ae1c2e7f737vboxsync#define VBVAHG_EVENT 1
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVAHG_DISPLAY_CUSTOM 2
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#ifdef VBOX_WITH_VDMA
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVAHG_SHGSMI_COMPLETION 3
aceec09dd145a4d6fb14f2ea75a459cc88b334abvboxsync#endif
bf88068260ded16af90b7da4867240fbdd9c8017vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#ifdef VBOX_WITH_VIDEOHWACCEL
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVAHG_DCUSTOM_VHWA_CMDCOMPLETE 1
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#pragma pack(1)
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBVAHOSTCMDVHWACMDCOMPLETE
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t offCmd;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync}VBVAHOSTCMDVHWACMDCOMPLETE;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#pragma pack()
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#endif /* # ifdef VBOX_WITH_VIDEOHWACCEL */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#pragma pack(1)
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef enum
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBVAHOSTCMD_OP_EVENT = 1,
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync VBVAHOSTCMD_OP_CUSTOM
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync}VBVAHOSTCMD_OP_TYPE;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBVAHOSTCMDEVENT
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync{
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync uint64_t pEvent;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync}VBVAHOSTCMDEVENT;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBVAHOSTCMD
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync{
d46ee884c41b808b239563b1978468aae12e33a2vboxsync /* destination ID if >=0 specifies display index, otherwize the command is directed to the miniport */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync int32_t iDstID;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync int32_t customOpCode;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync union
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync {
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync struct VBVAHOSTCMD *pNext;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint32_t offNext;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync uint64_t Data; /* the body is 64-bit aligned */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync } u;
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync char body[1];
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync}VBVAHOSTCMD;
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVAHOSTCMD_SIZE(_size) (sizeof(VBVAHOSTCMD) + (_size))
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVAHOSTCMD_BODY(_pCmd, _tBody) ((_tBody*)(_pCmd)->body)
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVAHOSTCMD_HDR(_pBody) ((VBVAHOSTCMD*)(((uint8_t*)_pBody) - RT_OFFSETOF(VBVAHOSTCMD, body)))
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBVAHOSTCMD_HDRSIZE (RT_OFFSETOF(VBVAHOSTCMD, body))
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsync#pragma pack()
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d46ee884c41b808b239563b1978468aae12e33a2vboxsync/* VBVACONF32::u32Index */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOX_VBVA_CONF32_MONITOR_COUNT 0
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync#define VBOX_VBVA_CONF32_HOST_HEAP_SIZE 1
d46ee884c41b808b239563b1978468aae12e33a2vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsynctypedef struct VBVACONF32
d46ee884c41b808b239563b1978468aae12e33a2vboxsync{
d46ee884c41b808b239563b1978468aae12e33a2vboxsync uint32_t u32Index;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync uint32_t u32Value;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync} VBVACONF32;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsynctypedef struct VBVAINFOVIEW
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync{
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync /* Index of the screen, assigned by the guest. */
861809c36a5178c28e231b90288d3461e358553fvboxsync uint32_t u32ViewIndex;
26ae7f0cac38c33d90eb69a15baef5fbdf7ca376vboxsync
19cf10f137c0ec4522dff998b88e98f6e423d56dvboxsync /* The screen offset in VRAM, the framebuffer starts here. */
19cf10f137c0ec4522dff998b88e98f6e423d56dvboxsync uint32_t u32ViewOffset;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync /* The size of the VRAM memory that can be used for the view. */
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync uint32_t u32ViewSize;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync /* The recommended maximum size of the VRAM memory for the screen. */
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync uint32_t u32MaxScreenSize;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync} VBVAINFOVIEW;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsynctypedef struct VBVAINFOHEAP
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync{
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync /* Absolute offset in VRAM of the start of the heap. */
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync uint32_t u32HeapOffset;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
861809c36a5178c28e231b90288d3461e358553fvboxsync /* The size of the heap. */
861809c36a5178c28e231b90288d3461e358553fvboxsync uint32_t u32HeapSize;
26ae7f0cac38c33d90eb69a15baef5fbdf7ca376vboxsync
861809c36a5178c28e231b90288d3461e358553fvboxsync} VBVAINFOHEAP;
2da39c8916d8c980fc544cdbae725ca57ee5949cvboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsynctypedef struct VBVAFLUSH
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync{
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync uint32_t u32Reserved;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync} VBVAFLUSH;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsynctypedef struct VBVACMDVBVASUBMIT
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync{
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync uint32_t u32Reserved;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync} VBVACMDVBVASUBMIT;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync/* flush is requested because due to guest command buffer overflow */
861809c36a5178c28e231b90288d3461e358553fvboxsync#define VBVACMDVBVAFLUSH_F_GUEST_BUFFER_OVERFLOW 1
861809c36a5178c28e231b90288d3461e358553fvboxsync
861809c36a5178c28e231b90288d3461e358553fvboxsynctypedef struct VBVACMDVBVAFLUSH
2da39c8916d8c980fc544cdbae725ca57ee5949cvboxsync{
26ae7f0cac38c33d90eb69a15baef5fbdf7ca376vboxsync uint32_t u32Flags;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync} VBVACMDVBVAFLUSH;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync/* VBVAINFOSCREEN::u8Flags */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_SCREEN_F_NONE 0x0000
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_SCREEN_F_ACTIVE 0x0001
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync/** The virtual monitor has been disabled by the guest and should be blacked
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync * out by the host and ignored for purposes of pointer position calculation. */
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync#define VBVA_SCREEN_F_DISABLED 0x0002
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsync
8cd393943ea52545c4d063f5a94436639f0f80b6vboxsynctypedef struct VBVAINFOSCREEN
358a99c385080f7f31166943f3ac3a2aea6b5263vboxsync{
d46ee884c41b808b239563b1978468aae12e33a2vboxsync /* Which view contains the screen. */
d46ee884c41b808b239563b1978468aae12e33a2vboxsync uint32_t u32ViewIndex;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* Physical X origin relative to the primary screen. */
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync int32_t i32OriginX;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync /* Physical Y origin relative to the primary screen. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync int32_t i32OriginY;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* Offset of visible framebuffer relative to the framebuffer start. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32StartOffset;
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync
e48239695d41f806ff02d8a60b97dc20d4822d7avboxsync /* The scan line size in bytes. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32LineSize;
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync /* Width of the screen. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32Width;
64836f6a22eea42b83b0ec64abcb3aa7ccc27f25vboxsync
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync /* Height of the screen. */
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync uint32_t u32Height;
d46ee884c41b808b239563b1978468aae12e33a2vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync /* Color depth. */
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync uint16_t u16BitsPerPixel;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync /* VBVA_SCREEN_F_* */
b099c6398b85f527d7343cb1da573e1e95f9fd10vboxsync uint16_t u16Flags;
b099c6398b85f527d7343cb1da573e1e95f9fd10vboxsync} VBVAINFOSCREEN;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync/* VBVAENABLE::u32Flags */
ec037c82be3787508e228c537bd15ad9de28bac0vboxsync#define VBVA_F_NONE 0x00000000
ec037c82be3787508e228c537bd15ad9de28bac0vboxsync#define VBVA_F_ENABLE 0x00000001
ec037c82be3787508e228c537bd15ad9de28bac0vboxsync#define VBVA_F_DISABLE 0x00000002
ec037c82be3787508e228c537bd15ad9de28bac0vboxsync/* extended VBVA to be used with WDDM */
248bc375de5b09204f70b5de2e029800f28da4b5vboxsync#define VBVA_F_EXTENDED 0x00000004
d8523ff7d948462e328eec88b602effe2e7f7080vboxsync/* vbva offset is absolute VRAM offset */
f8bda775706ea71db79e09a408aacf2a949d6bc6vboxsync#define VBVA_F_ABSOFFSET 0x00000008
f8bda775706ea71db79e09a408aacf2a949d6bc6vboxsync
ec037c82be3787508e228c537bd15ad9de28bac0vboxsynctypedef struct VBVAENABLE
6a801286d1ede5d68a7490a9cd2a6ba0634ff18avboxsync{
6a801286d1ede5d68a7490a9cd2a6ba0634ff18avboxsync uint32_t u32Flags;
6a801286d1ede5d68a7490a9cd2a6ba0634ff18avboxsync uint32_t u32Offset;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync int32_t i32Result;
5f3798b1abe94e5828f28821c234d9e86d77e4a3vboxsync} VBVAENABLE;
5f3798b1abe94e5828f28821c234d9e86d77e4a3vboxsync
5f3798b1abe94e5828f28821c234d9e86d77e4a3vboxsynctypedef struct VBVAENABLE_EX
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync{
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync VBVAENABLE Base;
13770a1ab6adae6f0f7792bd79881e049e410d45vboxsync uint32_t u32ScreenId;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync} VBVAENABLE_EX;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsynctypedef struct VBVAMOUSEPOINTERSHAPE
5f3798b1abe94e5828f28821c234d9e86d77e4a3vboxsync{
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync /* The host result. */
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync int32_t i32Result;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync /* VBOX_MOUSE_POINTER_* bit flags. */
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync uint32_t fu32Flags;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync /* X coordinate of the hot spot. */
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync uint32_t u32HotX;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f2490dbf97c8247439446844458461b00e50beb0vboxsync /* Y coordinate of the hot spot. */
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync uint32_t u32HotY;
13770a1ab6adae6f0f7792bd79881e049e410d45vboxsync
6a801286d1ede5d68a7490a9cd2a6ba0634ff18avboxsync /* Width of the pointer in pixels. */
6a801286d1ede5d68a7490a9cd2a6ba0634ff18avboxsync uint32_t u32Width;
6a801286d1ede5d68a7490a9cd2a6ba0634ff18avboxsync
6a801286d1ede5d68a7490a9cd2a6ba0634ff18avboxsync /* Height of the pointer in scanlines. */
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync uint32_t u32Height;
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync /* Pointer data.
f7c0f913c4c22ee18059ff97055442566d0f14a1vboxsync *
f2490dbf97c8247439446844458461b00e50beb0vboxsync ****
fe06619ae576367ff3568e6abd99fb8ad28cc73avboxsync * The data consists of 1 bpp AND mask followed by 32 bpp XOR (color) mask.
d46ee884c41b808b239563b1978468aae12e33a2vboxsync *
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * For pointers without alpha channel the XOR mask pixels are 32 bit values: (lsb)BGR0(msb).
d46ee884c41b808b239563b1978468aae12e33a2vboxsync * 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->au8Data.
*/
uint8_t au8Data[4];
} VBVAMOUSEPOINTERSHAPE;
/* the guest driver can handle asynch guest cmd completion by reading the command offset from io port */
#define VBVACAPS_COMPLETEGCMD_BY_IOREAD 0x00000001
/* the guest driver can handle video adapter IRQs */
#define VBVACAPS_IRQ 0x00000002
typedef struct VBVACAPS
{
int32_t rc;
uint32_t fCaps;
} VBVACAPS;
/* makes graphics device generate IRQ on VSYNC */
#define VBVASCANLINECFG_ENABLE_VSYNC_IRQ 0x00000001
/* guest driver may request the current scanline */
#define VBVASCANLINECFG_ENABLE_SCANLINE_INFO 0x00000002
/* request the current refresh period, returned in u32RefreshPeriodMs */
#define VBVASCANLINECFG_QUERY_REFRESH_PERIOD 0x00000004
/* set new refresh period specified in u32RefreshPeriodMs.
* if used with VBVASCANLINECFG_QUERY_REFRESH_PERIOD,
* u32RefreshPeriodMs is set to the previous refresh period on return */
#define VBVASCANLINECFG_SET_REFRESH_PERIOD 0x00000008
typedef struct VBVASCANLINECFG
{
int32_t rc;
uint32_t fFlags;
uint32_t u32RefreshPeriodMs;
uint32_t u32Reserved;
} VBVASCANLINECFG;
typedef struct VBVASCANLINEINFO
{
int32_t rc;
uint32_t u32ScreenId;
uint32_t u32InVBlank;
uint32_t u32ScanLine;
} VBVASCANLINEINFO;
#pragma pack()
typedef uint64_t VBOXVIDEOOFFSET;
#define VBOXVIDEOOFFSET_VOID ((VBOXVIDEOOFFSET)~0)
#pragma pack(1)
/*
* VBOXSHGSMI made on top HGSMI and allows receiving notifications
* about G->H command completion
*/
/* SHGSMI command header */
typedef struct VBOXSHGSMIHEADER
{
uint64_t pvNext; /*<- completion processing queue */
uint32_t fFlags; /*<- see VBOXSHGSMI_FLAG_XXX Flags */
uint32_t cRefs; /*<- command referece count */
uint64_t u64Info1; /*<- contents depends on the fFlags value */
uint64_t u64Info2; /*<- contents depends on the fFlags value */
} VBOXSHGSMIHEADER, *PVBOXSHGSMIHEADER;
typedef enum
{
VBOXVDMACMD_TYPE_UNDEFINED = 0,
VBOXVDMACMD_TYPE_DMA_PRESENT_BLT = 1,
VBOXVDMACMD_TYPE_DMA_BPB_TRANSFER,
VBOXVDMACMD_TYPE_DMA_BPB_FILL,
VBOXVDMACMD_TYPE_DMA_PRESENT_SHADOW2PRIMARY,
VBOXVDMACMD_TYPE_DMA_PRESENT_CLRFILL,
VBOXVDMACMD_TYPE_DMA_PRESENT_FLIP,
VBOXVDMACMD_TYPE_DMA_NOP,
VBOXVDMACMD_TYPE_CHROMIUM_CMD, /* chromium cmd */
VBOXVDMACMD_TYPE_DMA_BPB_TRANSFER_VRAMSYS,
VBOXVDMACMD_TYPE_CHILD_STATUS_IRQ /* make the device notify child (monitor) state change IRQ */
} VBOXVDMACMD_TYPE;
#pragma pack()
/* the command processing was asynch, set by the host to indicate asynch command completion
* must not be cleared once set, the command completion is performed by issuing a host->guest completion command
* while keeping this flag unchanged */
#define VBOXSHGSMI_FLAG_HG_ASYNCH 0x00010000
#if 0
/* if set - asynch completion is performed by issuing the event,
* if cleared - asynch completion is performed by calling a callback */
#define VBOXSHGSMI_FLAG_GH_ASYNCH_EVENT 0x00000001
#endif
/* issue interrupt on asynch completion, used for critical G->H commands,
* i.e. for completion of which guest is waiting. */
#define VBOXSHGSMI_FLAG_GH_ASYNCH_IRQ 0x00000002
/* guest does not do any op on completion of this command,
* the host may copy the command and indicate that it does not need the command anymore
* by not setting VBOXSHGSMI_FLAG_HG_ASYNCH */
#define VBOXSHGSMI_FLAG_GH_ASYNCH_NOCOMPLETION 0x00000004
/* guest requires the command to be processed asynchronously,
* not setting VBOXSHGSMI_FLAG_HG_ASYNCH by the host in this case is treated as command failure */
#define VBOXSHGSMI_FLAG_GH_ASYNCH_FORCE 0x00000008
/* force IRQ on cmd completion */
#define VBOXSHGSMI_FLAG_GH_ASYNCH_IRQ_FORCE 0x00000010
/* an IRQ-level callback is associated with the command */
#define VBOXSHGSMI_FLAG_GH_ASYNCH_CALLBACK_IRQ 0x00000020
/* guest expects this command to be completed synchronously */
#define VBOXSHGSMI_FLAG_GH_SYNCH 0x00000040
DECLINLINE(uint8_t *) VBoxSHGSMIBufferData (const VBOXSHGSMIHEADER* pHeader)
{
return (uint8_t *)pHeader + sizeof (VBOXSHGSMIHEADER);
}
#define VBoxSHGSMIBufferHeaderSize() (sizeof (VBOXSHGSMIHEADER))
DECLINLINE(PVBOXSHGSMIHEADER) VBoxSHGSMIBufferHeader (const void *pvData)
{
return (PVBOXSHGSMIHEADER)((uint8_t *)pvData - sizeof (VBOXSHGSMIHEADER));
}
#ifdef VBOX_WITH_VDMA
# pragma pack(1)
/* VDMA - Video DMA */
/* VDMA Control API */
/* VBOXVDMA_CTL::u32Flags */
typedef enum
{
VBOXVDMA_CTL_TYPE_NONE = 0,
VBOXVDMA_CTL_TYPE_ENABLE,
VBOXVDMA_CTL_TYPE_DISABLE,
VBOXVDMA_CTL_TYPE_FLUSH,
VBOXVDMA_CTL_TYPE_WATCHDOG
} VBOXVDMA_CTL_TYPE;
typedef struct VBOXVDMA_CTL
{
VBOXVDMA_CTL_TYPE enmCtl;
uint32_t u32Offset;
int32_t i32Result;
} VBOXVDMA_CTL, *PVBOXVDMA_CTL;
typedef struct VBOXVDMA_RECTL
{
int16_t left;
int16_t top;
uint16_t width;
uint16_t height;
} VBOXVDMA_RECTL, *PVBOXVDMA_RECTL;
typedef enum
{
VBOXVDMA_PIXEL_FORMAT_UNKNOWN = 0,
VBOXVDMA_PIXEL_FORMAT_R8G8B8 = 20,
VBOXVDMA_PIXEL_FORMAT_A8R8G8B8 = 21,
VBOXVDMA_PIXEL_FORMAT_X8R8G8B8 = 22,
VBOXVDMA_PIXEL_FORMAT_R5G6B5 = 23,
VBOXVDMA_PIXEL_FORMAT_X1R5G5B5 = 24,
VBOXVDMA_PIXEL_FORMAT_A1R5G5B5 = 25,
VBOXVDMA_PIXEL_FORMAT_A4R4G4B4 = 26,
VBOXVDMA_PIXEL_FORMAT_R3G3B2 = 27,
VBOXVDMA_PIXEL_FORMAT_A8 = 28,
VBOXVDMA_PIXEL_FORMAT_A8R3G3B2 = 29,
VBOXVDMA_PIXEL_FORMAT_X4R4G4B4 = 30,
VBOXVDMA_PIXEL_FORMAT_A2B10G10R10 = 31,
VBOXVDMA_PIXEL_FORMAT_A8B8G8R8 = 32,
VBOXVDMA_PIXEL_FORMAT_X8B8G8R8 = 33,
VBOXVDMA_PIXEL_FORMAT_G16R16 = 34,
VBOXVDMA_PIXEL_FORMAT_A2R10G10B10 = 35,
VBOXVDMA_PIXEL_FORMAT_A16B16G16R16 = 36,
VBOXVDMA_PIXEL_FORMAT_A8P8 = 40,
VBOXVDMA_PIXEL_FORMAT_P8 = 41,
VBOXVDMA_PIXEL_FORMAT_L8 = 50,
VBOXVDMA_PIXEL_FORMAT_A8L8 = 51,
VBOXVDMA_PIXEL_FORMAT_A4L4 = 52,
VBOXVDMA_PIXEL_FORMAT_V8U8 = 60,
VBOXVDMA_PIXEL_FORMAT_L6V5U5 = 61,
VBOXVDMA_PIXEL_FORMAT_X8L8V8U8 = 62,
VBOXVDMA_PIXEL_FORMAT_Q8W8V8U8 = 63,
VBOXVDMA_PIXEL_FORMAT_V16U16 = 64,
VBOXVDMA_PIXEL_FORMAT_W11V11U10 = 65,
VBOXVDMA_PIXEL_FORMAT_A2W10V10U10 = 67
} VBOXVDMA_PIXEL_FORMAT;
typedef struct VBOXVDMA_SURF_DESC
{
uint32_t width;
uint32_t height;
VBOXVDMA_PIXEL_FORMAT format;
uint32_t bpp;
uint32_t pitch;
uint32_t fFlags;
} VBOXVDMA_SURF_DESC, *PVBOXVDMA_SURF_DESC;
/*typedef uint64_t VBOXVDMAPHADDRESS;*/
typedef uint64_t VBOXVDMASURFHANDLE;
/* region specified as a rectangle, otherwize it is a size of memory pointed to by phys address */
#define VBOXVDMAOPERAND_FLAGS_RECTL 0x1
/* Surface handle is valid */
#define VBOXVDMAOPERAND_FLAGS_PRIMARY 0x2
/* address is offset in VRAM */
#define VBOXVDMAOPERAND_FLAGS_VRAMOFFSET 0x4
/* VBOXVDMACBUF_DR::phBuf specifies offset in VRAM */
#define VBOXVDMACBUF_FLAG_BUF_VRAM_OFFSET 0x00000001
/* command buffer follows the VBOXVDMACBUF_DR in VRAM, VBOXVDMACBUF_DR::phBuf is ignored */
#define VBOXVDMACBUF_FLAG_BUF_FOLLOWS_DR 0x00000002
/*
* We can not submit the DMA command via VRAM since we do not have control over
* DMA command buffer [de]allocation, i.e. we only control the buffer contents.
* In other words the system may call one of our callbacks to fill a command buffer
* with the necessary commands and then discard the buffer w/o any notification.
*
* We have only DMA command buffer physical address at submission time.
*
* so the only way is to */
typedef struct VBOXVDMACBUF_DR
{
uint16_t fFlags;
uint16_t cbBuf;
/* RT_SUCCESS() - on success
* VERR_INTERRUPTED - on preemption
* VERR_xxx - on error */
int32_t rc;
union
{
uint64_t phBuf;
VBOXVIDEOOFFSET offVramBuf;
} Location;
uint64_t aGuestData[7];
} VBOXVDMACBUF_DR, *PVBOXVDMACBUF_DR;
#define VBOXVDMACBUF_DR_TAIL(_pCmd, _t) ( (_t*)(((uint8_t*)(_pCmd)) + sizeof (VBOXVDMACBUF_DR)) )
#define VBOXVDMACBUF_DR_FROM_TAIL(_pCmd) ( (VBOXVDMACBUF_DR*)(((uint8_t*)(_pCmd)) - sizeof (VBOXVDMACBUF_DR)) )
typedef struct VBOXVDMACMD
{
VBOXVDMACMD_TYPE enmType;
uint32_t u32CmdSpecific;
} VBOXVDMACMD, *PVBOXVDMACMD;
#define VBOXVDMACMD_HEADER_SIZE() sizeof (VBOXVDMACMD)
#define VBOXVDMACMD_SIZE_FROMBODYSIZE(_s) (VBOXVDMACMD_HEADER_SIZE() + (_s))
#define VBOXVDMACMD_SIZE(_t) (VBOXVDMACMD_SIZE_FROMBODYSIZE(sizeof (_t)))
#define VBOXVDMACMD_BODY(_pCmd, _t) ( (_t*)(((uint8_t*)(_pCmd)) + VBOXVDMACMD_HEADER_SIZE()) )
#define VBOXVDMACMD_BODY_SIZE(_s) ( (_s) - VBOXVDMACMD_HEADER_SIZE() )
#define VBOXVDMACMD_FROM_BODY(_pCmd) ( (VBOXVDMACMD*)(((uint8_t*)(_pCmd)) - VBOXVDMACMD_HEADER_SIZE()) )
#define VBOXVDMACMD_BODY_FIELD_OFFSET(_ot, _t, _f) ( (_ot)(uintptr_t)( VBOXVDMACMD_BODY(0, uint8_t) + RT_OFFSETOF(_t, _f) ) )
typedef struct VBOXVDMACMD_DMA_PRESENT_BLT
{
VBOXVIDEOOFFSET offSrc;
VBOXVIDEOOFFSET offDst;
VBOXVDMA_SURF_DESC srcDesc;
VBOXVDMA_SURF_DESC dstDesc;
VBOXVDMA_RECTL srcRectl;
VBOXVDMA_RECTL dstRectl;
uint32_t u32Reserved;
uint32_t cDstSubRects;
VBOXVDMA_RECTL aDstSubRects[1];
} VBOXVDMACMD_DMA_PRESENT_BLT, *PVBOXVDMACMD_DMA_PRESENT_BLT;
typedef struct VBOXVDMACMD_DMA_PRESENT_SHADOW2PRIMARY
{
VBOXVDMA_RECTL Rect;
} VBOXVDMACMD_DMA_PRESENT_SHADOW2PRIMARY, *PVBOXVDMACMD_DMA_PRESENT_SHADOW2PRIMARY;
#define VBOXVDMACMD_DMA_BPB_TRANSFER_F_SRC_VRAMOFFSET 0x00000001
#define VBOXVDMACMD_DMA_BPB_TRANSFER_F_DST_VRAMOFFSET 0x00000002
typedef struct VBOXVDMACMD_DMA_BPB_TRANSFER
{
uint32_t cbTransferSize;
uint32_t fFlags;
union
{
uint64_t phBuf;
VBOXVIDEOOFFSET offVramBuf;
} Src;
union
{
uint64_t phBuf;
VBOXVIDEOOFFSET offVramBuf;
} Dst;
} VBOXVDMACMD_DMA_BPB_TRANSFER, *PVBOXVDMACMD_DMA_BPB_TRANSFER;
#define VBOXVDMACMD_SYSMEMEL_F_PAGELIST 0x00000001
typedef struct VBOXVDMACMD_SYSMEMEL
{
uint32_t cPages;
uint32_t fFlags;
uint64_t phBuf[1];
} VBOXVDMACMD_SYSMEMEL, *PVBOXVDMACMD_SYSMEMEL;
#define VBOXVDMACMD_SYSMEMEL_NEXT(_pEl) (((_pEl)->fFlags & VBOXVDMACMD_SYSMEMEL_F_PAGELIST) ? \
((PVBOXVDMACMD_SYSMEMEL)(((uint8_t*)(_pEl))+RT_OFFSETOF(VBOXVDMACMD_SYSMEMEL, phBuf[(_pEl)->cPages]))) \
: \
((_pEl)+1)
#define VBOXVDMACMD_DMA_BPB_TRANSFER_VRAMSYS_SYS2VRAM 0x00000001
typedef struct VBOXVDMACMD_DMA_BPB_TRANSFER_VRAMSYS
{
uint32_t cTransferPages;
uint32_t fFlags;
VBOXVIDEOOFFSET offVramBuf;
VBOXVDMACMD_SYSMEMEL FirstEl;
} VBOXVDMACMD_DMA_BPB_TRANSFER_VRAMSYS, *PVBOXVDMACMD_DMA_BPB_TRANSFER_VRAMSYS;
typedef struct VBOXVDMACMD_DMA_BPB_FILL
{
VBOXVIDEOOFFSET offSurf;
uint32_t cbFillSize;
uint32_t u32FillPattern;
} VBOXVDMACMD_DMA_BPB_FILL, *PVBOXVDMACMD_DMA_BPB_FILL;
#define VBOXVDMA_CHILD_STATUS_F_CONNECTED 0x01
#define VBOXVDMA_CHILD_STATUS_F_DISCONNECTED 0x02
#define VBOXVDMA_CHILD_STATUS_F_ROTATED 0x04
typedef struct VBOXVDMA_CHILD_STATUS
{
uint32_t iChild;
uint8_t fFlags;
uint8_t u8RotationAngle;
uint16_t u16Reserved;
} VBOXVDMA_CHILD_STATUS, *PVBOXVDMA_CHILD_STATUS;
/* apply the aInfos are applied to all targets, the iTarget is ignored */
#define VBOXVDMACMD_CHILD_STATUS_IRQ_F_APPLY_TO_ALL 0x00000001
typedef struct VBOXVDMACMD_CHILD_STATUS_IRQ
{
uint32_t cInfos;
uint32_t fFlags;
VBOXVDMA_CHILD_STATUS aInfos[1];
} VBOXVDMACMD_CHILD_STATUS_IRQ, *PVBOXVDMACMD_CHILD_STATUS_IRQ;
# pragma pack()
#endif /* #ifdef VBOX_WITH_VDMA */
#pragma pack(1)
typedef struct VBOXVDMACMD_CHROMIUM_BUFFER
{
VBOXVIDEOOFFSET offBuffer;
uint32_t cbBuffer;
uint32_t u32GuestData;
uint64_t u64GuestData;
} VBOXVDMACMD_CHROMIUM_BUFFER, *PVBOXVDMACMD_CHROMIUM_BUFFER;
typedef struct VBOXVDMACMD_CHROMIUM_CMD
{
uint32_t cBuffers;
uint32_t u32Reserved;
VBOXVDMACMD_CHROMIUM_BUFFER aBuffers[1];
} VBOXVDMACMD_CHROMIUM_CMD, *PVBOXVDMACMD_CHROMIUM_CMD;
typedef enum
{
VBOXVDMACMD_CHROMIUM_CTL_TYPE_UNKNOWN = 0,
VBOXVDMACMD_CHROMIUM_CTL_TYPE_CRHGSMI_SETUP,
VBOXVDMACMD_CHROMIUM_CTL_TYPE_SAVESTATE_BEGIN,
VBOXVDMACMD_CHROMIUM_CTL_TYPE_SAVESTATE_END,
VBOXVDMACMD_CHROMIUM_CTL_TYPE_CRHGSMI_SETUP_MAINCB,
VBOXVDMACMD_CHROMIUM_CTL_TYPE_CRCONNECT,
VBOXVDMACMD_CHROMIUM_CTL_TYPE_SIZEHACK = 0xfffffffe
} VBOXVDMACMD_CHROMIUM_CTL_TYPE;
typedef struct VBOXVDMACMD_CHROMIUM_CTL
{
VBOXVDMACMD_CHROMIUM_CTL_TYPE enmType;
uint32_t cbCmd;
} VBOXVDMACMD_CHROMIUM_CTL, *PVBOXVDMACMD_CHROMIUM_CTL;
typedef struct PDMIDISPLAYVBVACALLBACKS *HCRHGSMICMDCOMPLETION;
typedef DECLCALLBACK(int) FNCRHGSMICMDCOMPLETION(HCRHGSMICMDCOMPLETION hCompletion, PVBOXVDMACMD_CHROMIUM_CMD pCmd, int rc);
typedef FNCRHGSMICMDCOMPLETION *PFNCRHGSMICMDCOMPLETION;
typedef DECLCALLBACK(bool) FNCROGLHASDATA();
typedef FNCROGLHASDATA *PFNCROGLHASDATA;
/* callbacks chrogl gives to main */
typedef struct CR_MAIN_INTERFACE
{
PFNCROGLHASDATA pfnHasData;
} CR_MAIN_INTERFACE;
typedef struct VBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP_MAINCB
{
VBOXVDMACMD_CHROMIUM_CTL Hdr;
/*in*/
HCRHGSMICMDCOMPLETION hCompletion;
PFNCRHGSMICMDCOMPLETION pfnCompletion;
/*out*/
CR_MAIN_INTERFACE MainInterface;
} VBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP_MAINCB, *PVBOXVDMACMD_CHROMIUM_CTL_CRHGSMI_SETUP_MAINCB;
typedef struct VBOXCRCON_SERVER *HVBOXCRCON_SERVER;
typedef struct PDMIDISPLAYVBVACALLBACKS* HVBOXCRCON_CLIENT;
typedef struct VBOXCRCON_3DRGN_CLIENT* HVBOXCRCON_3DRGN_CLIENT;
typedef struct VBOXCRCON_3DRGN_ASYNCCLIENT* HVBOXCRCON_3DRGN_ASYNCCLIENT;
/* server callbacks */
/* submit chromium cmd */
typedef DECLCALLBACK(int) FNVBOXCRCON_SVR_CRCMD(HVBOXCRCON_SERVER hServer, PVBOXVDMACMD_CHROMIUM_CMD pCmd, uint32_t cbCmd);
typedef FNVBOXCRCON_SVR_CRCMD *PFNVBOXCRCON_SVR_CRCMD;
/* submit chromium control cmd */
typedef DECLCALLBACK(int) FNVBOXCRCON_SVR_CRCTL(HVBOXCRCON_SERVER hServer, PVBOXVDMACMD_CHROMIUM_CTL pCtl, uint32_t cbCmd);
typedef FNVBOXCRCON_SVR_CRCTL *PFNVBOXCRCON_SVR_CRCTL;
/* request 3D data.
* The protocol is the following:
* 1. if there is no 3D data displayed on screen, returns VINF_EOF immediately w/o calling any PFNVBOXCRCON_3DRGN_XXX callbacks
* 2. otherwise calls PFNVBOXCRCON_3DRGN_ONSUBMIT, submits the "regions get" request to the CrOpenGL server to process it asynchronously and returns VINF_SUCCESS
* 2.a on "regions get" request processing calls PFNVBOXCRCON_3DRGN_BEGIN,
* 2.b then PFNVBOXCRCON_3DRGN_REPORT zero or more times for each 3D region,
* 2.c and then PFNVBOXCRCON_3DRGN_END
* 3. returns VERR_XXX code on failure
* */
typedef DECLCALLBACK(int) FNVBOXCRCON_SVR_3DRGN_GET(HVBOXCRCON_SERVER hServer, HVBOXCRCON_3DRGN_CLIENT hRgnClient, uint32_t idScreen);
typedef FNVBOXCRCON_SVR_3DRGN_GET *PFNVBOXCRCON_SVR_3DRGN_GET;
/* 3D Regions Client callbacks */
/* called from the PFNVBOXCRCON_SVR_3DRGN_GET callback in case server has 3D data and is going to process the request asynchronously,
* see comments for PFNVBOXCRCON_SVR_3DRGN_GET above */
typedef DECLCALLBACK(int) FNVBOXCRCON_3DRGN_ONSUBMIT(HVBOXCRCON_3DRGN_CLIENT hRgnClient, uint32_t idScreen, HVBOXCRCON_3DRGN_ASYNCCLIENT *phRgnAsyncClient);
typedef FNVBOXCRCON_3DRGN_ONSUBMIT *PFNVBOXCRCON_3DRGN_ONSUBMIT;
/* called from the "regions get" command processing thread, to indicate that the "regions get" is started.
* see comments for PFNVBOXCRCON_SVR_3DRGN_GET above */
typedef DECLCALLBACK(int) FNVBOXCRCON_3DRGN_BEGIN(HVBOXCRCON_3DRGN_ASYNCCLIENT hRgnAsyncClient, uint32_t idScreen);
typedef FNVBOXCRCON_3DRGN_BEGIN *PFNVBOXCRCON_3DRGN_BEGIN;
/* called from the "regions get" command processing thread, to report a 3D region.
* see comments for PFNVBOXCRCON_SVR_3DRGN_GET above */
typedef DECLCALLBACK(int) FNVBOXCRCON_3DRGN_REPORT(HVBOXCRCON_3DRGN_ASYNCCLIENT hRgnAsyncClient, uint32_t idScreen, void *pvData, uint32_t cbStride, const RTRECT *pRect);
typedef FNVBOXCRCON_3DRGN_REPORT *PFNVBOXCRCON_3DRGN_REPORT;
/* called from the "regions get" command processing thread, to indicate that the "regions get" is completed.
* see comments for PFNVBOXCRCON_SVR_3DRGN_GET above */
typedef DECLCALLBACK(int) FNVBOXCRCON_3DRGN_END(HVBOXCRCON_3DRGN_ASYNCCLIENT hRgnAsyncClient, uint32_t idScreen);
typedef FNVBOXCRCON_3DRGN_END *PFNVBOXCRCON_3DRGN_END;
/* client callbacks */
/* complete chromium cmd */
typedef DECLCALLBACK(int) FNVBOXCRCON_CLT_CRCTL_COMPLETE(HVBOXCRCON_CLIENT hClient, PVBOXVDMACMD_CHROMIUM_CTL pCtl, int rc);
typedef FNVBOXCRCON_CLT_CRCTL_COMPLETE *PFNVBOXCRCON_CLT_CRCTL_COMPLETE;
/* complete chromium control cmd */
typedef DECLCALLBACK(int) FNVBOXCRCON_CLT_CRCMD_COMPLETE(HVBOXCRCON_CLIENT hClient, PVBOXVDMACMD_CHROMIUM_CMD pCmd, int rc);
typedef FNVBOXCRCON_CLT_CRCMD_COMPLETE *PFNVBOXCRCON_CLT_CRCMD_COMPLETE;
typedef struct VBOXCRCON_SERVER_CALLBACKS
{
HVBOXCRCON_SERVER hServer;
PFNVBOXCRCON_SVR_CRCMD pfnCrCmd;
PFNVBOXCRCON_SVR_CRCTL pfnCrCtl;
PFNVBOXCRCON_SVR_3DRGN_GET pfn3DRgnGet;
} VBOXCRCON_SERVER_CALLBACKS, *PVBOXCRCON_SERVER_CALLBACKS;
typedef struct VBOXCRCON_CLIENT_CALLBACKS
{
HVBOXCRCON_CLIENT hClient;
PFNVBOXCRCON_CLT_CRCMD_COMPLETE pfnCrCmdComplete;
PFNVBOXCRCON_CLT_CRCTL_COMPLETE pfnCrCtlComplete;
PFNVBOXCRCON_3DRGN_ONSUBMIT pfn3DRgnOnSubmit;
PFNVBOXCRCON_3DRGN_BEGIN pfn3DRgnBegin;
PFNVBOXCRCON_3DRGN_REPORT pfn3DRgnReport;
PFNVBOXCRCON_3DRGN_END pfn3DRgnEnd;
} VBOXCRCON_CLIENT_CALLBACKS, *PVBOXCRCON_CLIENT_CALLBACKS;
/* issued by Main to establish connection between Main and CrOpenGL service */
typedef struct VBOXVDMACMD_CHROMIUM_CTL_CRCONNECT
{
VBOXVDMACMD_CHROMIUM_CTL Hdr;
/*input (filled by Client) :*/
/*class VMMDev*/void *pVMMDev;
VBOXCRCON_CLIENT_CALLBACKS ClientCallbacks;
/*output (filled by Server) :*/
VBOXCRCON_SERVER_CALLBACKS ServerCallbacks;
} VBOXVDMACMD_CHROMIUM_CTL_CRCONNECT, *PVBOXVDMACMD_CHROMIUM_CTL_CRCONNECT;
/* ring command buffer dr */
#define VBOXCMDVBVA_STATE_SUBMITTED 1
#define VBOXCMDVBVA_STATE_CANCELLED 2
#define VBOXCMDVBVA_STATE_IN_PROGRESS 3
/* the "completed" state is signalled via the ring buffer values */
/* CrHgsmi command */
#define VBOXCMDVBVA_OPTYPE_CRCMD 1
/* blit command that does blitting of allocations identified by VRAM offset or host id
* for VRAM-offset ones the size and format are same as primary */
#define VBOXCMDVBVA_OPTYPE_BLT_OFFPRIMSZFMT_OR_ID 2
/* flip */
#define VBOXCMDVBVA_OPTYPE_FLIP 3
/* ColorFill */
#define VBOXCMDVBVA_OPTYPE_CLRFILL 4
/* allocation paging transfer request */
#define VBOXCMDVBVA_OPTYPE_PAGING_TRANSFER 5
/* allocation paging fill request */
#define VBOXCMDVBVA_OPTYPE_PAGING_FILL 6
/* same as VBOXCMDVBVA_OPTYPE_NOP, but contains VBOXCMDVBVA_HDR data */
#define VBOXCMDVBVA_OPTYPE_NOPCMD 7
/* nop - is a one-bit command. The buffer size to skip is determined by VBVA buffer size */
#define VBOXCMDVBVA_OPTYPE_NOP 0x80
/* u8Flags flags */
/* source allocation is specified with the host id. if not set - source allocation is specified with VRAM offset */
#define VBOXCMDVBVA_OPF_ALLOC_SRCID 0x80
/* destination allocation is specified with the host id. if not set - destination allocation is specified with VRAM offset */
#define VBOXCMDVBVA_OPF_ALLOC_DSTID 0x40
/* transfer from RAM to Allocation */
#define VBOXCMDVBVA_OPF_PAGING_TRANSFER_IN 0x20
/* VBOXCMDVBVA_OPTYPE_BLT_PRIMARY specific flags*/
/* if set - src is a primary id */
#define VBOXCMDVBVA_OPF_ALLOC_SRCPRIMARY 0x20
/* if set - dst is a primary id */
#define VBOXCMDVBVA_OPF_ALLOC_DSTPRIMARY 0x10
/* trying to make the header as small as possible,
* we'd have pretty few op codes actually, so 8bit is quite enough,
* we will be able to extend it in any way. */
typedef struct VBOXCMDVBVA_HDR
{
/* one VBOXCMDVBVA_OPTYPE_XXX, except NOP, see comments above */
uint8_t u8OpCode;
/* command-specific
* VBOXCMDVBVA_OPTYPE_CRCMD - must be null
* VBOXCMDVBVA_OPTYPE_BLT_PRIMARY - OR-ed VBOXCMDVBVA_OPF_ALLOC_XXX flags
* VBOXCMDVBVA_OPTYPE_BLT_OFFPRIMSZFMT_OR_ID - OR-ed VBOXCMDVBVA_OPF_ALLOC_XXX flags
* VBOXCMDVBVA_OPTYPE_PAGING_TRANSFER - must be null
* VBOXCMDVBVA_OPTYPE_PAGING_FILL - must be null
* VBOXCMDVBVA_OPTYPE_NOPCMD - must be null
* VBOXCMDVBVA_OPTYPE_NOP - not applicable (as the entire VBOXCMDVBVA_HDR is not valid) */
uint8_t u8Flags;
/* one of VBOXCMDVBVA_STATE_XXX*/
volatile uint8_t u8State;
union
{
/* result, 0 on success, otherwise contains the failure code TBD */
int8_t i8Result;
uint8_t u8PrimaryID;
};
/* DXGK DDI fence ID */
volatile uint32_t u32FenceID;
} VBOXCMDVBVA_HDR;
typedef uint32_t VBOXCMDVBVAOFFSET;
typedef uint64_t VBOXCMDVBVAPHADDR;
typedef struct VBOXCMDVBVA_CRCMD_BUFFER
{
uint32_t cbBuffer;
VBOXCMDVBVAOFFSET offBuffer;
} VBOXCMDVBVA_CRCMD_BUFFER;
typedef struct VBOXCMDVBVA_CRCMD_CMD
{
uint32_t cBuffers;
VBOXCMDVBVA_CRCMD_BUFFER aBuffers[1];
} VBOXCMDVBVA_CRCMD_CMD;
typedef struct VBOXCMDVBVA_CRCMD
{
VBOXCMDVBVA_HDR Hdr;
VBOXCMDVBVA_CRCMD_CMD Cmd;
} VBOXCMDVBVA_CRCMD;
typedef struct VBOXCMDVBVA_ALLOCINFO
{
union
{
VBOXCMDVBVAOFFSET offVRAM;
uint32_t id;
};
} VBOXCMDVBVA_ALLOCINFO;
typedef struct VBOXCMDVBVA_RECT
{
/** Coordinates of affected rectangle. */
int16_t xLeft;
int16_t yTop;
int16_t xRight;
int16_t yBottom;
} VBOXCMDVBVA_RECT;
typedef struct VBOXCMDVBVA_POINT
{
int16_t x;
int16_t y;
} VBOXCMDVBVA_POINT;
typedef struct VBOXCMDVBVA_BLT_PRIMARY
{
VBOXCMDVBVA_HDR Hdr;
VBOXCMDVBVA_ALLOCINFO alloc;
VBOXCMDVBVA_POINT Pos;
/* the rects count is determined from the command size */
VBOXCMDVBVA_RECT aRects[1];
} VBOXCMDVBVA_BLT_PRIMARY;
typedef struct VBOXCMDVBVA_BLT_OFFPRIMSZFMT_OR_ID
{
VBOXCMDVBVA_HDR Hdr;
VBOXCMDVBVA_ALLOCINFO src;
VBOXCMDVBVA_ALLOCINFO dst;
VBOXCMDVBVA_POINT Pos;
/* the rects count is determined from the command size */
VBOXCMDVBVA_RECT aRects[1];
} VBOXCMDVBVA_BLT_OFFPRIMSZFMT_OR_ID;
typedef struct VBOXCMDVBVA_FLIP
{
VBOXCMDVBVA_HDR Hdr;
VBOXCMDVBVA_ALLOCINFO src;
} VBOXCMDVBVA_FLIP;
typedef struct VBOXCMDVBVA_CLRFILL
{
VBOXCMDVBVA_HDR Hdr;
VBOXCMDVBVA_ALLOCINFO dst;
VBOXCMDVBVA_RECT aRects[1];
} VBOXCMDVBVA_CLRFILL;
#define VBOXCMDVBVA_SYSMEMEL_CPAGES_MAX 0x1000
typedef struct VBOXCMDVBVA_SYSMEMEL
{
uint32_t cPagesAfterFirst : 12;
VBOXCMDVBVAPHADDR iPage : 52;
} VBOXCMDVBVA_SYSMEMEL;
typedef struct VBOXCMDVBVA_PAGING_TRANSFER
{
VBOXCMDVBVA_HDR Hdr;
/* for now can only contain offVRAM.
* paging transfer can NOT be initiated for allocations having host 3D object (hostID) associated */
VBOXCMDVBVA_ALLOCINFO Alloc;
uint32_t cSysMem;
VBOXCMDVBVA_SYSMEMEL aSysMem[1];
} VBOXCMDVBVA_PAGING_TRANSFER;
typedef struct VBOXCMDVBVA_PAGING_FILL
{
VBOXCMDVBVA_HDR Hdr;
uint32_t cbFill;
uint32_t Pattern;
/* paging transfer can NOT be initiated for allocations having host 3D object (hostID) associated */
VBOXCMDVBVAOFFSET offVRAM;
} VBOXCMDVBVA_PAGING_FILL;
#define VBOXCMDVBVACTL_TYPE_ENABLE 1
#define VBOXCMDVBVACTL_TYPE_3DCTL 2
typedef struct VBOXCMDVBVA_CTL
{
uint32_t u32Type;
int32_t i32Result;
} VBOXCMDVBVA_CTL;
typedef struct VBOXCMDVBVA_CTL_ENABLE
{
VBOXCMDVBVA_CTL Hdr;
VBVAENABLE Enable;
} VBOXCMDVBVA_CTL_ENABLE;
#pragma pack()
#ifdef VBOXVDMA_WITH_VBVA
# pragma pack(1)
typedef struct VBOXVDMAVBVACMD
{
HGSMIOFFSET offCmd;
} VBOXVDMAVBVACMD;
#pragma pack()
#endif
#endif