qemu/include/standard-headers/linux/vhost_types.h
<<
>>
Prefs
   1/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
   2#ifndef _LINUX_VHOST_TYPES_H
   3#define _LINUX_VHOST_TYPES_H
   4/* Userspace interface for in-kernel virtio accelerators. */
   5
   6/* vhost is used to reduce the number of system calls involved in virtio.
   7 *
   8 * Existing virtio net code is used in the guest without modification.
   9 *
  10 * This header includes interface used by userspace hypervisor for
  11 * device configuration.
  12 */
  13
  14#include "standard-headers/linux/types.h"
  15
  16#include "standard-headers/linux/virtio_config.h"
  17#include "standard-headers/linux/virtio_ring.h"
  18
  19struct vhost_vring_state {
  20        unsigned int index;
  21        unsigned int num;
  22};
  23
  24struct vhost_vring_file {
  25        unsigned int index;
  26        int fd; /* Pass -1 to unbind from file. */
  27
  28};
  29
  30struct vhost_vring_addr {
  31        unsigned int index;
  32        /* Option flags. */
  33        unsigned int flags;
  34        /* Flag values: */
  35        /* Whether log address is valid. If set enables logging. */
  36#define VHOST_VRING_F_LOG 0
  37
  38        /* Start of array of descriptors (virtually contiguous) */
  39        uint64_t desc_user_addr;
  40        /* Used structure address. Must be 32 bit aligned */
  41        uint64_t used_user_addr;
  42        /* Available structure address. Must be 16 bit aligned */
  43        uint64_t avail_user_addr;
  44        /* Logging support. */
  45        /* Log writes to used structure, at offset calculated from specified
  46         * address. Address must be 32 bit aligned. */
  47        uint64_t log_guest_addr;
  48};
  49
  50/* no alignment requirement */
  51struct vhost_iotlb_msg {
  52        uint64_t iova;
  53        uint64_t size;
  54        uint64_t uaddr;
  55#define VHOST_ACCESS_RO      0x1
  56#define VHOST_ACCESS_WO      0x2
  57#define VHOST_ACCESS_RW      0x3
  58        uint8_t perm;
  59#define VHOST_IOTLB_MISS           1
  60#define VHOST_IOTLB_UPDATE         2
  61#define VHOST_IOTLB_INVALIDATE     3
  62#define VHOST_IOTLB_ACCESS_FAIL    4
  63/*
  64 * VHOST_IOTLB_BATCH_BEGIN and VHOST_IOTLB_BATCH_END allow modifying
  65 * multiple mappings in one go: beginning with
  66 * VHOST_IOTLB_BATCH_BEGIN, followed by any number of
  67 * VHOST_IOTLB_UPDATE messages, and ending with VHOST_IOTLB_BATCH_END.
  68 * When one of these two values is used as the message type, the rest
  69 * of the fields in the message are ignored. There's no guarantee that
  70 * these changes take place automatically in the device.
  71 */
  72#define VHOST_IOTLB_BATCH_BEGIN    5
  73#define VHOST_IOTLB_BATCH_END      6
  74        uint8_t type;
  75};
  76
  77#define VHOST_IOTLB_MSG 0x1
  78#define VHOST_IOTLB_MSG_V2 0x2
  79
  80struct vhost_msg {
  81        int type;
  82        union {
  83                struct vhost_iotlb_msg iotlb;
  84                uint8_t padding[64];
  85        };
  86};
  87
  88struct vhost_msg_v2 {
  89        uint32_t type;
  90        uint32_t reserved;
  91        union {
  92                struct vhost_iotlb_msg iotlb;
  93                uint8_t padding[64];
  94        };
  95};
  96
  97struct vhost_memory_region {
  98        uint64_t guest_phys_addr;
  99        uint64_t memory_size; /* bytes */
 100        uint64_t userspace_addr;
 101        uint64_t flags_padding; /* No flags are currently specified. */
 102};
 103
 104/* All region addresses and sizes must be 4K aligned. */
 105#define VHOST_PAGE_SIZE 0x1000
 106
 107struct vhost_memory {
 108        uint32_t nregions;
 109        uint32_t padding;
 110        struct vhost_memory_region regions[0];
 111};
 112
 113/* VHOST_SCSI specific definitions */
 114
 115/*
 116 * Used by QEMU userspace to ensure a consistent vhost-scsi ABI.
 117 *
 118 * ABI Rev 0: July 2012 version starting point for v3.6-rc merge candidate +
 119 *            RFC-v2 vhost-scsi userspace.  Add GET_ABI_VERSION ioctl usage
 120 * ABI Rev 1: January 2013. Ignore vhost_tpgt field in struct vhost_scsi_target.
 121 *            All the targets under vhost_wwpn can be seen and used by guset.
 122 */
 123
 124#define VHOST_SCSI_ABI_VERSION  1
 125
 126struct vhost_scsi_target {
 127        int abi_version;
 128        char vhost_wwpn[224]; /* TRANSPORT_IQN_LEN */
 129        unsigned short vhost_tpgt;
 130        unsigned short reserved;
 131};
 132
 133/* VHOST_VDPA specific definitions */
 134
 135struct vhost_vdpa_config {
 136        uint32_t off;
 137        uint32_t len;
 138        uint8_t buf[0];
 139};
 140
 141/* vhost vdpa IOVA range
 142 * @first: First address that can be mapped by vhost-vDPA
 143 * @last: Last address that can be mapped by vhost-vDPA
 144 */
 145struct vhost_vdpa_iova_range {
 146        uint64_t first;
 147        uint64_t last;
 148};
 149
 150/* Feature bits */
 151/* Log all write descriptors. Can be changed while device is active. */
 152#define VHOST_F_LOG_ALL 26
 153/* vhost-net should add virtio_net_hdr for RX, and strip for TX packets. */
 154#define VHOST_NET_F_VIRTIO_NET_HDR 27
 155
 156#endif
 157