2016-08-15 16:26:29 +02:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Virtio GPU Device specific type and macro definitions.
|
|
|
|
|
|
|
|
At the time of this writing, the Virtio 1.0 specification has not
|
|
|
|
incorporated the GPU device yet. The following work-in-progress specification
|
|
|
|
is used as basis for the implementation:
|
|
|
|
|
|
|
|
- https://lists.oasis-open.org/archives/virtio-dev/201605/msg00002.html
|
|
|
|
- https://www.kraxel.org/virtio/
|
|
|
|
|
|
|
|
This header file is minimal, and only defines the types and macros that are
|
|
|
|
necessary for the OvmfPkg implementation.
|
|
|
|
|
|
|
|
Copyright (C) 2016, Red Hat, Inc.
|
|
|
|
|
2019-04-04 01:06:33 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2016-08-15 16:26:29 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _VIRTIO_GPU_H_
|
|
|
|
#define _VIRTIO_GPU_H_
|
|
|
|
|
|
|
|
#include <IndustryStandard/Virtio.h>
|
|
|
|
|
|
|
|
//
|
|
|
|
// Queue number for sending control commands.
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
#define VIRTIO_GPU_CONTROL_QUEUE 0
|
2016-08-15 16:26:29 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Command and response types.
|
|
|
|
//
|
|
|
|
typedef enum {
|
|
|
|
//
|
|
|
|
// Commands related to mode setup:
|
|
|
|
//
|
|
|
|
// - create/release a host-side 2D resource,
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
VirtioGpuCmdResourceCreate2d = 0x0101,
|
|
|
|
VirtioGpuCmdResourceUnref = 0x0102,
|
2016-08-15 16:26:29 +02:00
|
|
|
//
|
|
|
|
// - attach/detach guest RAM to/from a host-side 2D resource,
|
|
|
|
//
|
|
|
|
VirtioGpuCmdResourceAttachBacking = 0x0106,
|
|
|
|
VirtioGpuCmdResourceDetachBacking = 0x0107,
|
|
|
|
//
|
|
|
|
// - assign/unassign a host-side 2D resource to/from a scanout ("head").
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
VirtioGpuCmdSetScanout = 0x0103,
|
2016-08-15 16:26:29 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Commands related to drawing:
|
|
|
|
//
|
|
|
|
// - transfer a guest RAM update to the host-side 2D resource (does not imply
|
|
|
|
// host display refresh),
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
VirtioGpuCmdTransferToHost2d = 0x0105,
|
2016-08-15 16:26:29 +02:00
|
|
|
//
|
|
|
|
// - trigger a host display refresh from the 2D resource.
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
VirtioGpuCmdResourceFlush = 0x0104,
|
2016-08-15 16:26:29 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Success code for all of the above commands.
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
VirtioGpuRespOkNodata = 0x1100,
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_CONTROL_TYPE;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Common request/response header.
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
#define VIRTIO_GPU_FLAG_FENCE BIT0
|
2016-08-15 16:26:29 +02:00
|
|
|
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
|
|
|
//
|
|
|
|
// The guest sets Type to VirtioGpuCmd* in the requests. The host sets Type
|
|
|
|
// to VirtioGpuResp* in the responses.
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
UINT32 Type;
|
2016-08-15 16:26:29 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Fencing forces the host to complete the command before producing a
|
|
|
|
// response.
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
UINT32 Flags;
|
|
|
|
UINT64 FenceId;
|
2016-08-15 16:26:29 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Unused.
|
|
|
|
//
|
2021-12-05 23:54:09 +01:00
|
|
|
UINT32 CtxId;
|
|
|
|
UINT32 Padding;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_CONTROL_HEADER;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
//
|
|
|
|
// Rectangle structure used by several operations.
|
|
|
|
//
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
UINT32 X;
|
|
|
|
UINT32 Y;
|
|
|
|
UINT32 Width;
|
|
|
|
UINT32 Height;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_RECTANGLE;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
//
|
|
|
|
// Request structure for VirtioGpuCmdResourceCreate2d.
|
|
|
|
//
|
|
|
|
typedef enum {
|
|
|
|
//
|
|
|
|
// 32-bit depth, BGRX component order, X component ignored.
|
|
|
|
//
|
|
|
|
VirtioGpuFormatB8G8R8X8Unorm = 2,
|
|
|
|
} VIRTIO_GPU_FORMATS;
|
|
|
|
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
VIRTIO_GPU_CONTROL_HEADER Header;
|
|
|
|
UINT32 ResourceId; // note: 0 is invalid
|
|
|
|
UINT32 Format; // from VIRTIO_GPU_FORMATS
|
|
|
|
UINT32 Width;
|
|
|
|
UINT32 Height;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_RESOURCE_CREATE_2D;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
//
|
|
|
|
// Request structure for VirtioGpuCmdResourceUnref.
|
|
|
|
//
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
VIRTIO_GPU_CONTROL_HEADER Header;
|
|
|
|
UINT32 ResourceId;
|
|
|
|
UINT32 Padding;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_RESOURCE_UNREF;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
//
|
|
|
|
// Request structure for VirtioGpuCmdResourceAttachBacking.
|
|
|
|
//
|
|
|
|
// The spec allows for a scatter-gather list, but for simplicity we hard-code a
|
|
|
|
// single guest buffer.
|
|
|
|
//
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
UINT64 Addr;
|
|
|
|
UINT32 Length;
|
|
|
|
UINT32 Padding;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_MEM_ENTRY;
|
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
VIRTIO_GPU_CONTROL_HEADER Header;
|
|
|
|
UINT32 ResourceId;
|
|
|
|
UINT32 NrEntries; // number of entries: constant 1
|
|
|
|
VIRTIO_GPU_MEM_ENTRY Entry;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_RESOURCE_ATTACH_BACKING;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
//
|
|
|
|
// Request structure for VirtioGpuCmdResourceDetachBacking.
|
|
|
|
//
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
VIRTIO_GPU_CONTROL_HEADER Header;
|
|
|
|
UINT32 ResourceId;
|
|
|
|
UINT32 Padding;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_RESOURCE_DETACH_BACKING;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
//
|
|
|
|
// Request structure for VirtioGpuCmdSetScanout.
|
|
|
|
//
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
VIRTIO_GPU_CONTROL_HEADER Header;
|
|
|
|
VIRTIO_GPU_RECTANGLE Rectangle;
|
|
|
|
UINT32 ScanoutId;
|
|
|
|
UINT32 ResourceId;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_SET_SCANOUT;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
//
|
|
|
|
// Request structure for VirtioGpuCmdTransferToHost2d.
|
|
|
|
//
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
VIRTIO_GPU_CONTROL_HEADER Header;
|
|
|
|
VIRTIO_GPU_RECTANGLE Rectangle;
|
|
|
|
UINT64 Offset;
|
|
|
|
UINT32 ResourceId;
|
|
|
|
UINT32 Padding;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_CMD_TRANSFER_TO_HOST_2D;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
//
|
|
|
|
// Request structure for VirtioGpuCmdResourceFlush.
|
|
|
|
//
|
|
|
|
#pragma pack (1)
|
|
|
|
typedef struct {
|
2021-12-05 23:54:09 +01:00
|
|
|
VIRTIO_GPU_CONTROL_HEADER Header;
|
|
|
|
VIRTIO_GPU_RECTANGLE Rectangle;
|
|
|
|
UINT32 ResourceId;
|
|
|
|
UINT32 Padding;
|
2016-08-15 16:26:29 +02:00
|
|
|
} VIRTIO_GPU_RESOURCE_FLUSH;
|
|
|
|
#pragma pack ()
|
|
|
|
|
|
|
|
#endif // _VIRTIO_GPU_H_
|