contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
/*
|
|
|
|
* Vhost User library
|
|
|
|
*
|
|
|
|
* Copyright (c) 2016 Red Hat, Inc.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Victor Kaplansky <victork@redhat.com>
|
|
|
|
* Marc-André Lureau <mlureau@redhat.com>
|
|
|
|
*
|
|
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or
|
|
|
|
* later. See the COPYING file in the top-level directory.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef LIBVHOST_USER_H
|
|
|
|
#define LIBVHOST_USER_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stddef.h>
|
2021-01-18 09:38:01 +03:00
|
|
|
#include <poll.h>
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
#include <linux/vhost.h>
|
2019-03-01 14:18:30 +03:00
|
|
|
#include <pthread.h>
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
#include "standard-headers/linux/virtio_ring.h"
|
|
|
|
|
|
|
|
/* Based on qemu/hw/virtio/vhost-user.c */
|
|
|
|
#define VHOST_USER_F_PROTOCOL_FEATURES 30
|
|
|
|
#define VHOST_LOG_PAGE 4096
|
|
|
|
|
|
|
|
#define VIRTQUEUE_MAX_SIZE 1024
|
|
|
|
|
2020-05-21 08:00:59 +03:00
|
|
|
#define VHOST_MEMORY_BASELINE_NREGIONS 8
|
|
|
|
|
|
|
|
/*
|
libvhost-user: Bump up VHOST_USER_MAX_RAM_SLOTS to 509
Let's support up to 509 mem slots, just like vhost in the kernel usually
does and the rust vhost-user implementation recently [1] started doing.
This is required to properly support memory hotplug, either using
multiple DIMMs (ACPI supports up to 256) or using virtio-mem.
The 509 used to be the KVM limit, it supported 512, but 3 were
used for internal purposes. Currently, KVM supports more than 512, but
it usually doesn't make use of more than ~260 (i.e., 256 DIMMs + boot
memory), except when other memory devices like PCI devices with BARs are
used. So, 509 seems to work well for vhost in the kernel.
Details can be found in the QEMU change that made virtio-mem consume
up to 256 mem slots across all virtio-mem devices. [2]
509 mem slots implies 509 VMAs/mappings in the worst case (even though,
in practice with virtio-mem we won't be seeing more than ~260 in most
setups).
With max_map_count under Linux defaulting to 64k, 509 mem slots
still correspond to less than 1% of the maximum number of mappings.
There are plenty left for the application to consume.
[1] https://github.com/rust-vmm/vhost/pull/224
[2] https://lore.kernel.org/all/20230926185738.277351-1-david@redhat.com/
Reviewed-by: Raphael Norwitz <raphael@enfabrica.net>
Acked-by: Stefano Garzarella <sgarzare@redhat.com>
Signed-off-by: David Hildenbrand <david@redhat.com>
Message-Id: <20240214151701.29906-3-david@redhat.com>
Tested-by: Mario Casquero <mcasquer@redhat.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2024-02-14 18:16:49 +03:00
|
|
|
* vhost in the kernel usually supports 509 mem slots. 509 used to be the
|
|
|
|
* KVM limit, it supported 512, but 3 were used for internal purposes. This
|
|
|
|
* limit is sufficient to support many DIMMs and virtio-mem in
|
|
|
|
* "dynamic-memslots" mode.
|
2020-05-21 08:00:59 +03:00
|
|
|
*/
|
libvhost-user: Bump up VHOST_USER_MAX_RAM_SLOTS to 509
Let's support up to 509 mem slots, just like vhost in the kernel usually
does and the rust vhost-user implementation recently [1] started doing.
This is required to properly support memory hotplug, either using
multiple DIMMs (ACPI supports up to 256) or using virtio-mem.
The 509 used to be the KVM limit, it supported 512, but 3 were
used for internal purposes. Currently, KVM supports more than 512, but
it usually doesn't make use of more than ~260 (i.e., 256 DIMMs + boot
memory), except when other memory devices like PCI devices with BARs are
used. So, 509 seems to work well for vhost in the kernel.
Details can be found in the QEMU change that made virtio-mem consume
up to 256 mem slots across all virtio-mem devices. [2]
509 mem slots implies 509 VMAs/mappings in the worst case (even though,
in practice with virtio-mem we won't be seeing more than ~260 in most
setups).
With max_map_count under Linux defaulting to 64k, 509 mem slots
still correspond to less than 1% of the maximum number of mappings.
There are plenty left for the application to consume.
[1] https://github.com/rust-vmm/vhost/pull/224
[2] https://lore.kernel.org/all/20230926185738.277351-1-david@redhat.com/
Reviewed-by: Raphael Norwitz <raphael@enfabrica.net>
Acked-by: Stefano Garzarella <sgarzare@redhat.com>
Signed-off-by: David Hildenbrand <david@redhat.com>
Message-Id: <20240214151701.29906-3-david@redhat.com>
Tested-by: Mario Casquero <mcasquer@redhat.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2024-02-14 18:16:49 +03:00
|
|
|
#define VHOST_USER_MAX_RAM_SLOTS 509
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
|
2020-09-18 11:09:06 +03:00
|
|
|
#define VHOST_USER_HDR_SIZE offsetof(VhostUserMsg, payload.u64)
|
|
|
|
|
2018-01-04 04:53:33 +03:00
|
|
|
typedef enum VhostSetConfigType {
|
2023-06-13 11:08:48 +03:00
|
|
|
VHOST_SET_CONFIG_TYPE_FRONTEND = 0,
|
2018-01-04 04:53:33 +03:00
|
|
|
VHOST_SET_CONFIG_TYPE_MIGRATION = 1,
|
|
|
|
} VhostSetConfigType;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Maximum size of virtio device config space
|
|
|
|
*/
|
|
|
|
#define VHOST_USER_MAX_CONFIG_SIZE 256
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
enum VhostUserProtocolFeature {
|
|
|
|
VHOST_USER_PROTOCOL_F_MQ = 0,
|
|
|
|
VHOST_USER_PROTOCOL_F_LOG_SHMFD = 1,
|
|
|
|
VHOST_USER_PROTOCOL_F_RARP = 2,
|
2017-10-02 22:15:20 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_REPLY_ACK = 3,
|
|
|
|
VHOST_USER_PROTOCOL_F_NET_MTU = 4,
|
2023-02-08 23:32:58 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_BACKEND_REQ = 5,
|
2017-10-02 22:15:20 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_CROSS_ENDIAN = 6,
|
2018-03-12 20:21:00 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_CRYPTO_SESSION = 7,
|
|
|
|
VHOST_USER_PROTOCOL_F_PAGEFAULT = 8,
|
2018-03-30 05:46:16 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_CONFIG = 9,
|
2023-02-08 23:32:58 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_BACKEND_SEND_FD = 10,
|
2018-05-24 13:33:35 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_HOST_NOTIFIER = 11,
|
2019-02-28 11:53:52 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_INFLIGHT_SHMFD = 12,
|
2020-01-23 11:17:08 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_INBAND_NOTIFICATIONS = 14,
|
2020-05-21 08:00:59 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_CONFIGURE_MEM_SLOTS = 15,
|
2023-10-02 09:57:06 +03:00
|
|
|
/* Feature 16 is reserved for VHOST_USER_PROTOCOL_F_STATUS. */
|
vhost-user: Fix protocol feature bit conflict
The VHOST_USER_PROTOCOL_F_XEN_MMAP feature bit was defined in
f21e95ee97d, which has been part of qemu's 8.1.0 release. However, it
seems it was never added to qemu's code, but it is well possible that it
is already used by different front-ends outside of qemu (i.e., Xen).
VHOST_USER_PROTOCOL_F_SHARED_OBJECT in contrast was added to qemu's code
in 16094766627, but never defined in the vhost-user specification. As a
consequence, both bits were defined to be 17, which cannot work.
Regardless of whether actual code or the specification should take
precedence, F_XEN_MMAP is already part of a qemu release, while
F_SHARED_OBJECT is not. Therefore, bump the latter to take number 18
instead of 17, and add this to the specification.
Take the opportunity to add at least a little note on the
VhostUserShared structure to the specification. This structure is
referenced by the new commands introduced in 16094766627, but was not
defined.
Fixes: 160947666276c5b7f6bca4d746bcac2966635d79
("vhost-user: add shared_object msg")
Signed-off-by: Hanna Czenczek <hreitz@redhat.com>
Message-Id: <20231016083201.23736-1-hreitz@redhat.com>
Reviewed-by: Emmanouil Pitsidianakis <manos.pitsidianakis@linaro.org>
Reviewed-by: Stefano Garzarella <sgarzare@redhat.com>
Reviewed-by: Viresh Kumar <viresh.kumar@linaro.org>
Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2023-10-16 11:32:01 +03:00
|
|
|
/* Feature 17 reserved for VHOST_USER_PROTOCOL_F_XEN_MMAP. */
|
|
|
|
VHOST_USER_PROTOCOL_F_SHARED_OBJECT = 18,
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
VHOST_USER_PROTOCOL_F_MAX
|
|
|
|
};
|
|
|
|
|
|
|
|
#define VHOST_USER_PROTOCOL_FEATURE_MASK ((1 << VHOST_USER_PROTOCOL_F_MAX) - 1)
|
|
|
|
|
|
|
|
typedef enum VhostUserRequest {
|
|
|
|
VHOST_USER_NONE = 0,
|
|
|
|
VHOST_USER_GET_FEATURES = 1,
|
|
|
|
VHOST_USER_SET_FEATURES = 2,
|
|
|
|
VHOST_USER_SET_OWNER = 3,
|
|
|
|
VHOST_USER_RESET_OWNER = 4,
|
|
|
|
VHOST_USER_SET_MEM_TABLE = 5,
|
|
|
|
VHOST_USER_SET_LOG_BASE = 6,
|
|
|
|
VHOST_USER_SET_LOG_FD = 7,
|
|
|
|
VHOST_USER_SET_VRING_NUM = 8,
|
|
|
|
VHOST_USER_SET_VRING_ADDR = 9,
|
|
|
|
VHOST_USER_SET_VRING_BASE = 10,
|
|
|
|
VHOST_USER_GET_VRING_BASE = 11,
|
|
|
|
VHOST_USER_SET_VRING_KICK = 12,
|
|
|
|
VHOST_USER_SET_VRING_CALL = 13,
|
|
|
|
VHOST_USER_SET_VRING_ERR = 14,
|
|
|
|
VHOST_USER_GET_PROTOCOL_FEATURES = 15,
|
|
|
|
VHOST_USER_SET_PROTOCOL_FEATURES = 16,
|
|
|
|
VHOST_USER_GET_QUEUE_NUM = 17,
|
|
|
|
VHOST_USER_SET_VRING_ENABLE = 18,
|
|
|
|
VHOST_USER_SEND_RARP = 19,
|
2017-10-02 22:15:20 +03:00
|
|
|
VHOST_USER_NET_SET_MTU = 20,
|
2023-02-08 23:32:58 +03:00
|
|
|
VHOST_USER_SET_BACKEND_REQ_FD = 21,
|
2017-10-02 22:15:20 +03:00
|
|
|
VHOST_USER_IOTLB_MSG = 22,
|
|
|
|
VHOST_USER_SET_VRING_ENDIAN = 23,
|
2018-01-04 04:53:33 +03:00
|
|
|
VHOST_USER_GET_CONFIG = 24,
|
|
|
|
VHOST_USER_SET_CONFIG = 25,
|
2018-03-12 20:21:01 +03:00
|
|
|
VHOST_USER_CREATE_CRYPTO_SESSION = 26,
|
|
|
|
VHOST_USER_CLOSE_CRYPTO_SESSION = 27,
|
|
|
|
VHOST_USER_POSTCOPY_ADVISE = 28,
|
2018-03-12 20:21:06 +03:00
|
|
|
VHOST_USER_POSTCOPY_LISTEN = 29,
|
2018-03-12 20:21:19 +03:00
|
|
|
VHOST_USER_POSTCOPY_END = 30,
|
2019-02-28 11:53:52 +03:00
|
|
|
VHOST_USER_GET_INFLIGHT_FD = 31,
|
|
|
|
VHOST_USER_SET_INFLIGHT_FD = 32,
|
2019-05-24 16:09:38 +03:00
|
|
|
VHOST_USER_GPU_SET_SOCKET = 33,
|
2020-01-23 11:17:08 +03:00
|
|
|
VHOST_USER_VRING_KICK = 35,
|
2020-05-21 08:00:50 +03:00
|
|
|
VHOST_USER_GET_MAX_MEM_SLOTS = 36,
|
2020-05-21 08:00:52 +03:00
|
|
|
VHOST_USER_ADD_MEM_REG = 37,
|
2020-05-21 08:00:56 +03:00
|
|
|
VHOST_USER_REM_MEM_REG = 38,
|
2023-10-02 09:57:06 +03:00
|
|
|
VHOST_USER_GET_SHARED_OBJECT = 41,
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
VHOST_USER_MAX
|
|
|
|
} VhostUserRequest;
|
|
|
|
|
2023-06-13 11:08:48 +03:00
|
|
|
typedef enum VhostUserBackendRequest {
|
2023-02-08 23:32:58 +03:00
|
|
|
VHOST_USER_BACKEND_NONE = 0,
|
|
|
|
VHOST_USER_BACKEND_IOTLB_MSG = 1,
|
|
|
|
VHOST_USER_BACKEND_CONFIG_CHANGE_MSG = 2,
|
|
|
|
VHOST_USER_BACKEND_VRING_HOST_NOTIFIER_MSG = 3,
|
|
|
|
VHOST_USER_BACKEND_VRING_CALL = 4,
|
|
|
|
VHOST_USER_BACKEND_VRING_ERR = 5,
|
2023-10-02 09:57:06 +03:00
|
|
|
VHOST_USER_BACKEND_SHARED_OBJECT_ADD = 6,
|
|
|
|
VHOST_USER_BACKEND_SHARED_OBJECT_REMOVE = 7,
|
|
|
|
VHOST_USER_BACKEND_SHARED_OBJECT_LOOKUP = 8,
|
2023-02-08 23:32:58 +03:00
|
|
|
VHOST_USER_BACKEND_MAX
|
2023-06-13 11:08:48 +03:00
|
|
|
} VhostUserBackendRequest;
|
2018-05-24 13:33:35 +03:00
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
typedef struct VhostUserMemoryRegion {
|
|
|
|
uint64_t guest_phys_addr;
|
|
|
|
uint64_t memory_size;
|
|
|
|
uint64_t userspace_addr;
|
|
|
|
uint64_t mmap_offset;
|
|
|
|
} VhostUserMemoryRegion;
|
|
|
|
|
2022-01-17 07:12:24 +03:00
|
|
|
#define VHOST_USER_MEM_REG_SIZE (sizeof(VhostUserMemoryRegion))
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
typedef struct VhostUserMemory {
|
|
|
|
uint32_t nregions;
|
|
|
|
uint32_t padding;
|
2020-05-21 08:00:59 +03:00
|
|
|
VhostUserMemoryRegion regions[VHOST_MEMORY_BASELINE_NREGIONS];
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
} VhostUserMemory;
|
|
|
|
|
2020-05-21 08:00:52 +03:00
|
|
|
typedef struct VhostUserMemRegMsg {
|
2020-11-09 20:43:55 +03:00
|
|
|
uint64_t padding;
|
2020-05-21 08:00:52 +03:00
|
|
|
VhostUserMemoryRegion region;
|
|
|
|
} VhostUserMemRegMsg;
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
typedef struct VhostUserLog {
|
|
|
|
uint64_t mmap_size;
|
|
|
|
uint64_t mmap_offset;
|
|
|
|
} VhostUserLog;
|
|
|
|
|
2018-01-04 04:53:33 +03:00
|
|
|
typedef struct VhostUserConfig {
|
|
|
|
uint32_t offset;
|
|
|
|
uint32_t size;
|
|
|
|
uint32_t flags;
|
|
|
|
uint8_t region[VHOST_USER_MAX_CONFIG_SIZE];
|
|
|
|
} VhostUserConfig;
|
|
|
|
|
|
|
|
static VhostUserConfig c __attribute__ ((unused));
|
|
|
|
#define VHOST_USER_CONFIG_HDR_SIZE (sizeof(c.offset) \
|
|
|
|
+ sizeof(c.size) \
|
|
|
|
+ sizeof(c.flags))
|
|
|
|
|
2018-05-24 13:33:35 +03:00
|
|
|
typedef struct VhostUserVringArea {
|
|
|
|
uint64_t u64;
|
|
|
|
uint64_t size;
|
|
|
|
uint64_t offset;
|
|
|
|
} VhostUserVringArea;
|
|
|
|
|
2019-02-28 11:53:52 +03:00
|
|
|
typedef struct VhostUserInflight {
|
|
|
|
uint64_t mmap_size;
|
|
|
|
uint64_t mmap_offset;
|
|
|
|
uint16_t num_queues;
|
|
|
|
uint16_t queue_size;
|
|
|
|
} VhostUserInflight;
|
|
|
|
|
2023-10-02 09:57:06 +03:00
|
|
|
#define UUID_LEN 16
|
|
|
|
|
|
|
|
typedef struct VhostUserShared {
|
|
|
|
unsigned char uuid[UUID_LEN];
|
|
|
|
} VhostUserShared;
|
|
|
|
|
2019-05-07 14:55:02 +03:00
|
|
|
#if defined(_WIN32) && (defined(__x86_64__) || defined(__i386__))
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
# define VU_PACKED __attribute__((gcc_struct, packed))
|
|
|
|
#else
|
|
|
|
# define VU_PACKED __attribute__((packed))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
typedef struct VhostUserMsg {
|
2019-03-08 17:04:43 +03:00
|
|
|
int request;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
|
|
|
|
#define VHOST_USER_VERSION_MASK (0x3)
|
|
|
|
#define VHOST_USER_REPLY_MASK (0x1 << 2)
|
2018-05-24 13:33:35 +03:00
|
|
|
#define VHOST_USER_NEED_REPLY_MASK (0x1 << 3)
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
uint32_t flags;
|
|
|
|
uint32_t size; /* the following payload size */
|
|
|
|
|
|
|
|
union {
|
|
|
|
#define VHOST_USER_VRING_IDX_MASK (0xff)
|
|
|
|
#define VHOST_USER_VRING_NOFD_MASK (0x1 << 8)
|
|
|
|
uint64_t u64;
|
|
|
|
struct vhost_vring_state state;
|
|
|
|
struct vhost_vring_addr addr;
|
|
|
|
VhostUserMemory memory;
|
2020-05-21 08:00:52 +03:00
|
|
|
VhostUserMemRegMsg memreg;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
VhostUserLog log;
|
2018-01-04 04:53:33 +03:00
|
|
|
VhostUserConfig config;
|
2018-05-24 13:33:35 +03:00
|
|
|
VhostUserVringArea area;
|
2019-02-28 11:53:52 +03:00
|
|
|
VhostUserInflight inflight;
|
2023-10-02 09:57:06 +03:00
|
|
|
VhostUserShared object;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
} payload;
|
|
|
|
|
2020-05-21 08:00:59 +03:00
|
|
|
int fds[VHOST_MEMORY_BASELINE_NREGIONS];
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
int fd_num;
|
|
|
|
uint8_t *data;
|
|
|
|
} VU_PACKED VhostUserMsg;
|
|
|
|
|
|
|
|
typedef struct VuDevRegion {
|
|
|
|
/* Guest Physical address. */
|
|
|
|
uint64_t gpa;
|
|
|
|
/* Memory region size. */
|
|
|
|
uint64_t size;
|
|
|
|
/* QEMU virtual address (userspace). */
|
|
|
|
uint64_t qva;
|
|
|
|
/* Starting offset in our mmaped space. */
|
|
|
|
uint64_t mmap_offset;
|
|
|
|
/* Start address of mmaped space. */
|
|
|
|
uint64_t mmap_addr;
|
|
|
|
} VuDevRegion;
|
|
|
|
|
|
|
|
typedef struct VuDev VuDev;
|
|
|
|
|
|
|
|
typedef uint64_t (*vu_get_features_cb) (VuDev *dev);
|
|
|
|
typedef void (*vu_set_features_cb) (VuDev *dev, uint64_t features);
|
|
|
|
typedef int (*vu_process_msg_cb) (VuDev *dev, VhostUserMsg *vmsg,
|
|
|
|
int *do_reply);
|
2020-09-18 11:09:06 +03:00
|
|
|
typedef bool (*vu_read_msg_cb) (VuDev *dev, int sock, VhostUserMsg *vmsg);
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
typedef void (*vu_queue_set_started_cb) (VuDev *dev, int qidx, bool started);
|
2017-08-29 18:27:50 +03:00
|
|
|
typedef bool (*vu_queue_is_processed_in_order_cb) (VuDev *dev, int qidx);
|
2018-01-04 04:53:33 +03:00
|
|
|
typedef int (*vu_get_config_cb) (VuDev *dev, uint8_t *config, uint32_t len);
|
|
|
|
typedef int (*vu_set_config_cb) (VuDev *dev, const uint8_t *data,
|
|
|
|
uint32_t offset, uint32_t size,
|
|
|
|
uint32_t flags);
|
2023-10-02 09:57:06 +03:00
|
|
|
typedef int (*vu_get_shared_object_cb) (VuDev *dev, const unsigned char *uuid);
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
|
|
|
|
typedef struct VuDevIface {
|
|
|
|
/* called by VHOST_USER_GET_FEATURES to get the features bitmask */
|
|
|
|
vu_get_features_cb get_features;
|
|
|
|
/* enable vhost implementation features */
|
|
|
|
vu_set_features_cb set_features;
|
|
|
|
/* get the protocol feature bitmask from the underlying vhost
|
|
|
|
* implementation */
|
|
|
|
vu_get_features_cb get_protocol_features;
|
|
|
|
/* enable protocol features in the underlying vhost implementation. */
|
|
|
|
vu_set_features_cb set_protocol_features;
|
|
|
|
/* process_msg is called for each vhost-user message received */
|
|
|
|
/* skip libvhost-user processing if return value != 0 */
|
|
|
|
vu_process_msg_cb process_msg;
|
|
|
|
/* tells when queues can be processed */
|
|
|
|
vu_queue_set_started_cb queue_set_started;
|
2017-08-29 18:27:50 +03:00
|
|
|
/*
|
|
|
|
* If the queue is processed in order, in which case it will be
|
|
|
|
* resumed to vring.used->idx. This can help to support resuming
|
|
|
|
* on unmanaged exit/crash.
|
|
|
|
*/
|
|
|
|
vu_queue_is_processed_in_order_cb queue_is_processed_in_order;
|
2018-01-04 04:53:33 +03:00
|
|
|
/* get the config space of the device */
|
|
|
|
vu_get_config_cb get_config;
|
|
|
|
/* set the config space of the device */
|
|
|
|
vu_set_config_cb set_config;
|
2023-10-02 09:57:06 +03:00
|
|
|
/* get virtio shared object from the underlying vhost implementation. */
|
|
|
|
vu_get_shared_object_cb get_shared_object;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
} VuDevIface;
|
|
|
|
|
|
|
|
typedef void (*vu_queue_handler_cb) (VuDev *dev, int qidx);
|
|
|
|
|
|
|
|
typedef struct VuRing {
|
|
|
|
unsigned int num;
|
|
|
|
struct vring_desc *desc;
|
|
|
|
struct vring_avail *avail;
|
|
|
|
struct vring_used *used;
|
|
|
|
uint64_t log_guest_addr;
|
|
|
|
uint32_t flags;
|
|
|
|
} VuRing;
|
|
|
|
|
2019-02-28 11:53:52 +03:00
|
|
|
typedef struct VuDescStateSplit {
|
|
|
|
/* Indicate whether this descriptor is inflight or not.
|
|
|
|
* Only available for head-descriptor. */
|
|
|
|
uint8_t inflight;
|
|
|
|
|
|
|
|
/* Padding */
|
|
|
|
uint8_t padding[5];
|
|
|
|
|
|
|
|
/* Maintain a list for the last batch of used descriptors.
|
|
|
|
* Only available when batching is used for submitting */
|
|
|
|
uint16_t next;
|
|
|
|
|
|
|
|
/* Used to preserve the order of fetching available descriptors.
|
|
|
|
* Only available for head-descriptor. */
|
|
|
|
uint64_t counter;
|
|
|
|
} VuDescStateSplit;
|
|
|
|
|
|
|
|
typedef struct VuVirtqInflight {
|
|
|
|
/* The feature flags of this region. Now it's initialized to 0. */
|
|
|
|
uint64_t features;
|
|
|
|
|
|
|
|
/* The version of this region. It's 1 currently.
|
|
|
|
* Zero value indicates a vm reset happened. */
|
|
|
|
uint16_t version;
|
|
|
|
|
2023-06-13 11:08:48 +03:00
|
|
|
/*
|
|
|
|
* The size of VuDescStateSplit array. It's equal to the virtqueue size.
|
|
|
|
* Backend could get it from queue size field of VhostUserInflight.
|
|
|
|
*/
|
2019-02-28 11:53:52 +03:00
|
|
|
uint16_t desc_num;
|
|
|
|
|
|
|
|
/* The head of list that track the last batch of used descriptors. */
|
|
|
|
uint16_t last_batch_head;
|
|
|
|
|
|
|
|
/* Storing the idx value of used ring */
|
|
|
|
uint16_t used_idx;
|
|
|
|
|
|
|
|
/* Used to track the state of each descriptor in descriptor table */
|
misc: Replace zero-length arrays with flexible array member (automatic)
Description copied from Linux kernel commit from Gustavo A. R. Silva
(see [3]):
--v-- description start --v--
The current codebase makes use of the zero-length array language
extension to the C90 standard, but the preferred mechanism to
declare variable-length types such as these ones is a flexible
array member [1], introduced in C99:
struct foo {
int stuff;
struct boo array[];
};
By making use of the mechanism above, we will get a compiler
warning in case the flexible array does not occur last in the
structure, which will help us prevent some kind of undefined
behavior bugs from being unadvertenly introduced [2] to the
Linux codebase from now on.
--^-- description end --^--
Do the similar housekeeping in the QEMU codebase (which uses
C99 since commit 7be41675f7cb).
All these instances of code were found with the help of the
following Coccinelle script:
@@
identifier s, m, a;
type t, T;
@@
struct s {
...
t m;
- T a[0];
+ T a[];
};
@@
identifier s, m, a;
type t, T;
@@
struct s {
...
t m;
- T a[0];
+ T a[];
} QEMU_PACKED;
[1] https://gcc.gnu.org/onlinedocs/gcc/Zero-Length.html
[2] https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=76497732932f
[3] https://git.kernel.org/pub/scm/linux/kernel/git/gustavoars/linux.git/commit/?id=17642a2fbd2c1
Inspired-by: Gustavo A. R. Silva <gustavo@embeddedor.com>
Reviewed-by: David Hildenbrand <david@redhat.com>
Signed-off-by: Philippe Mathieu-Daudé <philmd@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
2020-03-04 18:38:15 +03:00
|
|
|
VuDescStateSplit desc[];
|
2019-02-28 11:53:52 +03:00
|
|
|
} VuVirtqInflight;
|
|
|
|
|
|
|
|
typedef struct VuVirtqInflightDesc {
|
|
|
|
uint16_t index;
|
|
|
|
uint64_t counter;
|
|
|
|
} VuVirtqInflightDesc;
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
typedef struct VuVirtq {
|
|
|
|
VuRing vring;
|
|
|
|
|
2019-02-28 11:53:52 +03:00
|
|
|
VuVirtqInflight *inflight;
|
|
|
|
|
|
|
|
VuVirtqInflightDesc *resubmit_list;
|
|
|
|
|
|
|
|
uint16_t resubmit_num;
|
|
|
|
|
|
|
|
uint64_t counter;
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
/* Next head to pop */
|
|
|
|
uint16_t last_avail_idx;
|
|
|
|
|
|
|
|
/* Last avail_idx read from VQ. */
|
|
|
|
uint16_t shadow_avail_idx;
|
|
|
|
|
|
|
|
uint16_t used_idx;
|
|
|
|
|
|
|
|
/* Last used index value we have signalled on */
|
|
|
|
uint16_t signalled_used;
|
|
|
|
|
|
|
|
/* Last used index value we have signalled on */
|
|
|
|
bool signalled_used_valid;
|
|
|
|
|
|
|
|
/* Notification enabled? */
|
|
|
|
bool notification;
|
|
|
|
|
2022-12-19 20:53:37 +03:00
|
|
|
unsigned int inuse;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
|
|
|
|
vu_queue_handler_cb handler;
|
|
|
|
|
|
|
|
int call_fd;
|
|
|
|
int kick_fd;
|
|
|
|
int err_fd;
|
|
|
|
unsigned int enable;
|
|
|
|
bool started;
|
2019-08-12 19:35:19 +03:00
|
|
|
|
|
|
|
/* Guest addresses of our ring */
|
|
|
|
struct vhost_vring_addr vra;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
} VuVirtq;
|
|
|
|
|
|
|
|
enum VuWatchCondtion {
|
vhost-user-scsi: Introduce a vhost-user-scsi sample application
This commit introduces a vhost-user-scsi backend sample application. It
must be linked with libiscsi and libvhost-user.
To use it, compile with:
$ make vhost-user-scsi
And run as follows:
$ ./vhost-user-scsi -u vus.sock -i iscsi://uri_to_target/
$ qemu-system-x86_64 --enable-kvm -m 512 \
-object memory-backend-file,id=mem,size=512m,share=on,mem-path=guestmem \
-numa node,memdev=mem \
-chardev socket,id=vhost-user-scsi,path=vus.sock \
-device vhost-user-scsi-pci,chardev=vhost-user-scsi \
The application is currently limited at one LUN only and it processes
requests synchronously (therefore only achieving QD1). The purpose of
the code is to show how a backend can be implemented and to test the
vhost-user-scsi Qemu implementation.
If a different instance of this vhost-user-scsi application is executed
at a remote host, a VM can be live migrated to such a host.
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Message-Id: <1488479153-21203-5-git-send-email-felipe@nutanix.com>
2017-03-02 21:25:53 +03:00
|
|
|
VU_WATCH_IN = POLLIN,
|
|
|
|
VU_WATCH_OUT = POLLOUT,
|
|
|
|
VU_WATCH_PRI = POLLPRI,
|
|
|
|
VU_WATCH_ERR = POLLERR,
|
|
|
|
VU_WATCH_HUP = POLLHUP,
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef void (*vu_panic_cb) (VuDev *dev, const char *err);
|
|
|
|
typedef void (*vu_watch_cb) (VuDev *dev, int condition, void *data);
|
|
|
|
typedef void (*vu_set_watch_cb) (VuDev *dev, int fd, int condition,
|
|
|
|
vu_watch_cb cb, void *data);
|
|
|
|
typedef void (*vu_remove_watch_cb) (VuDev *dev, int fd);
|
|
|
|
|
2019-02-28 11:53:52 +03:00
|
|
|
typedef struct VuDevInflightInfo {
|
|
|
|
int fd;
|
|
|
|
void *addr;
|
|
|
|
uint64_t size;
|
|
|
|
} VuDevInflightInfo;
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
struct VuDev {
|
|
|
|
int sock;
|
|
|
|
uint32_t nregions;
|
2024-02-14 18:16:48 +03:00
|
|
|
VuDevRegion *regions;
|
2019-06-26 10:48:13 +03:00
|
|
|
VuVirtq *vq;
|
2019-02-28 11:53:52 +03:00
|
|
|
VuDevInflightInfo inflight_info;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
int log_call_fd;
|
2023-06-13 11:08:48 +03:00
|
|
|
/* Must be held while using backend_fd */
|
|
|
|
pthread_mutex_t backend_mutex;
|
|
|
|
int backend_fd;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
uint64_t log_size;
|
|
|
|
uint8_t *log_table;
|
|
|
|
uint64_t features;
|
|
|
|
uint64_t protocol_features;
|
|
|
|
bool broken;
|
2019-06-26 10:48:13 +03:00
|
|
|
uint16_t max_queues;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
|
2020-10-27 20:35:17 +03:00
|
|
|
/*
|
|
|
|
* @read_msg: custom method to read vhost-user message
|
2020-09-18 11:09:06 +03:00
|
|
|
*
|
|
|
|
* Read data from vhost_user socket fd and fill up
|
|
|
|
* the passed VhostUserMsg *vmsg struct.
|
|
|
|
*
|
|
|
|
* If reading fails, it should close the received set of file
|
|
|
|
* descriptors as socket message's auxiliary data.
|
|
|
|
*
|
|
|
|
* For the details, please refer to vu_message_read in libvhost-user.c
|
|
|
|
* which will be used by default if not custom method is provided when
|
|
|
|
* calling vu_init
|
|
|
|
*
|
|
|
|
* Returns: true if vhost-user message successfully received,
|
|
|
|
* otherwise return false.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
vu_read_msg_cb read_msg;
|
2020-10-27 20:35:17 +03:00
|
|
|
|
|
|
|
/*
|
|
|
|
* @set_watch: add or update the given fd to the watch set,
|
|
|
|
* call cb when condition is met.
|
|
|
|
*/
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
vu_set_watch_cb set_watch;
|
|
|
|
|
|
|
|
/* @remove_watch: remove the given fd from the watch set */
|
|
|
|
vu_remove_watch_cb remove_watch;
|
|
|
|
|
2020-10-27 20:35:17 +03:00
|
|
|
/*
|
|
|
|
* @panic: encountered an unrecoverable error, you may try to re-initialize
|
|
|
|
*/
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
vu_panic_cb panic;
|
|
|
|
const VuDevIface *iface;
|
2018-03-12 20:21:03 +03:00
|
|
|
|
|
|
|
/* Postcopy data */
|
|
|
|
int postcopy_ufd;
|
2018-03-12 20:21:06 +03:00
|
|
|
bool postcopy_listening;
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct VuVirtqElement {
|
|
|
|
unsigned int index;
|
|
|
|
unsigned int out_num;
|
|
|
|
unsigned int in_num;
|
|
|
|
struct iovec *in_sg;
|
|
|
|
struct iovec *out_sg;
|
|
|
|
} VuVirtqElement;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_init:
|
|
|
|
* @dev: a VuDev context
|
2019-06-26 10:48:13 +03:00
|
|
|
* @max_queues: maximum number of virtqueues
|
2023-06-13 11:08:48 +03:00
|
|
|
* @socket: the socket connected to vhost-user frontend
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
* @panic: a panic callback
|
|
|
|
* @set_watch: a set_watch callback
|
|
|
|
* @remove_watch: a remove_watch callback
|
|
|
|
* @iface: a VuDevIface structure with vhost-user device callbacks
|
|
|
|
*
|
2020-09-17 10:50:29 +03:00
|
|
|
* Initializes a VuDev vhost-user context.
|
2019-06-26 10:48:13 +03:00
|
|
|
*
|
|
|
|
* Returns: true on success, false on failure.
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
**/
|
2019-06-26 10:48:13 +03:00
|
|
|
bool vu_init(VuDev *dev,
|
|
|
|
uint16_t max_queues,
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
int socket,
|
|
|
|
vu_panic_cb panic,
|
2020-09-18 11:09:06 +03:00
|
|
|
vu_read_msg_cb read_msg,
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
vu_set_watch_cb set_watch,
|
|
|
|
vu_remove_watch_cb remove_watch,
|
|
|
|
const VuDevIface *iface);
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_deinit:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
*
|
|
|
|
* Cleans up the VuDev context
|
|
|
|
*/
|
|
|
|
void vu_deinit(VuDev *dev);
|
|
|
|
|
2022-03-21 18:30:32 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_request_to_string: return string for vhost message request
|
|
|
|
* @req: VhostUserMsg request
|
|
|
|
*
|
|
|
|
* Returns a const string, do not free.
|
|
|
|
*/
|
|
|
|
const char *vu_request_to_string(unsigned int req);
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
/**
|
|
|
|
* vu_dispatch:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
*
|
|
|
|
* Process one vhost-user message.
|
|
|
|
*
|
|
|
|
* Returns: TRUE on success, FALSE on failure.
|
|
|
|
*/
|
|
|
|
bool vu_dispatch(VuDev *dev);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_gpa_to_va:
|
|
|
|
* @dev: a VuDev context
|
2018-01-18 19:04:05 +03:00
|
|
|
* @plen: guest memory size
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
* @guest_addr: guest address
|
|
|
|
*
|
|
|
|
* Translate a guest address to a pointer. Returns NULL on failure.
|
|
|
|
*/
|
2018-01-18 19:04:05 +03:00
|
|
|
void *vu_gpa_to_va(VuDev *dev, uint64_t *plen, uint64_t guest_addr);
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_get_queue:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @qidx: queue index
|
|
|
|
*
|
|
|
|
* Returns the queue number @qidx.
|
|
|
|
*/
|
|
|
|
VuVirtq *vu_get_queue(VuDev *dev, int qidx);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_set_queue_handler:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @handler: the queue handler callback
|
|
|
|
*
|
|
|
|
* Set the queue handler. This function may be called several times
|
|
|
|
* for the same queue. If called with NULL @handler, the handler is
|
|
|
|
* removed.
|
|
|
|
*/
|
|
|
|
void vu_set_queue_handler(VuDev *dev, VuVirtq *vq,
|
|
|
|
vu_queue_handler_cb handler);
|
|
|
|
|
2018-05-24 13:33:35 +03:00
|
|
|
/**
|
|
|
|
* vu_set_queue_host_notifier:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @fd: a file descriptor
|
|
|
|
* @size: host page size
|
|
|
|
* @offset: notifier offset in @fd file
|
|
|
|
*
|
|
|
|
* Set queue's host notifier. This function may be called several
|
|
|
|
* times for the same queue. If called with -1 @fd, the notifier
|
|
|
|
* is removed.
|
|
|
|
*/
|
|
|
|
bool vu_set_queue_host_notifier(VuDev *dev, VuVirtq *vq, int fd,
|
|
|
|
int size, int offset);
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
|
2023-10-02 09:57:06 +03:00
|
|
|
/**
|
|
|
|
* vu_lookup_shared_object:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @uuid: UUID of the shared object
|
|
|
|
* @dmabuf_fd: output dma-buf file descriptor
|
|
|
|
*
|
|
|
|
* Lookup for a virtio shared object (i.e., dma-buf fd) associated with the
|
|
|
|
* received UUID. Result, if found, is stored in the dmabuf_fd argument.
|
|
|
|
*
|
|
|
|
* Returns: whether the virtio object was found.
|
|
|
|
*/
|
|
|
|
bool vu_lookup_shared_object(VuDev *dev, unsigned char uuid[UUID_LEN],
|
|
|
|
int *dmabuf_fd);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_add_shared_object:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @uuid: UUID of the shared object
|
|
|
|
*
|
|
|
|
* Registers this back-end as the exporter for the object associated with
|
|
|
|
* the received UUID.
|
|
|
|
*
|
|
|
|
* Returns: TRUE on success, FALSE on failure.
|
|
|
|
*/
|
|
|
|
bool vu_add_shared_object(VuDev *dev, unsigned char uuid[UUID_LEN]);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_rm_shared_object:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @uuid: UUID of the shared object
|
|
|
|
*
|
|
|
|
* Removes a shared object entry (i.e., back-end entry) associated with the
|
|
|
|
* received UUID key from the hash table.
|
|
|
|
*
|
|
|
|
* Returns: TRUE on success, FALSE on failure.
|
|
|
|
*/
|
|
|
|
bool vu_rm_shared_object(VuDev *dev, unsigned char uuid[UUID_LEN]);
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
/**
|
|
|
|
* vu_queue_set_notification:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @enable: state
|
|
|
|
*
|
|
|
|
* Set whether the queue notifies (via event index or interrupt)
|
|
|
|
*/
|
|
|
|
void vu_queue_set_notification(VuDev *dev, VuVirtq *vq, int enable);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_queue_enabled:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
*
|
|
|
|
* Returns: whether the queue is enabled.
|
|
|
|
*/
|
|
|
|
bool vu_queue_enabled(VuDev *dev, VuVirtq *vq);
|
|
|
|
|
2017-10-02 22:15:18 +03:00
|
|
|
/**
|
|
|
|
* vu_queue_started:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
*
|
|
|
|
* Returns: whether the queue is started.
|
|
|
|
*/
|
|
|
|
bool vu_queue_started(const VuDev *dev, const VuVirtq *vq);
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
/**
|
2017-05-03 19:54:12 +03:00
|
|
|
* vu_queue_empty:
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
*
|
2017-05-03 19:54:12 +03:00
|
|
|
* Returns: true if the queue is empty or not ready.
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
*/
|
2017-05-03 19:54:12 +03:00
|
|
|
bool vu_queue_empty(VuDev *dev, VuVirtq *vq);
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_queue_notify:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
*
|
|
|
|
* Request to notify the queue via callfd (skipped if unnecessary)
|
|
|
|
*/
|
|
|
|
void vu_queue_notify(VuDev *dev, VuVirtq *vq);
|
|
|
|
|
2023-03-21 23:13:23 +03:00
|
|
|
void vu_config_change_msg(VuDev *dev);
|
|
|
|
|
2020-01-23 11:17:08 +03:00
|
|
|
/**
|
|
|
|
* vu_queue_notify_sync:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
*
|
|
|
|
* Request to notify the queue via callfd (skipped if unnecessary)
|
|
|
|
* or sync message if possible.
|
|
|
|
*/
|
|
|
|
void vu_queue_notify_sync(VuDev *dev, VuVirtq *vq);
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
/**
|
|
|
|
* vu_queue_pop:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @sz: the size of struct to return (must be >= VuVirtqElement)
|
|
|
|
*
|
2017-08-11 02:25:38 +03:00
|
|
|
* Returns: a VuVirtqElement filled from the queue or NULL. The
|
|
|
|
* returned element must be free()-d by the caller.
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
*/
|
|
|
|
void *vu_queue_pop(VuDev *dev, VuVirtq *vq, size_t sz);
|
|
|
|
|
2019-03-08 17:04:52 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_queue_unpop:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @elem: The #VuVirtqElement
|
|
|
|
* @len: number of bytes written
|
|
|
|
*
|
|
|
|
* Pretend the most recent element wasn't popped from the virtqueue. The next
|
|
|
|
* call to vu_queue_pop() will refetch the element.
|
|
|
|
*/
|
|
|
|
void vu_queue_unpop(VuDev *dev, VuVirtq *vq, VuVirtqElement *elem,
|
|
|
|
size_t len);
|
|
|
|
|
contrib: add libvhost-user
Add a library to help implementing vhost-user backend (or slave).
Dealing with vhost-user as an application developer isn't so easy: you
have all the trouble with any protocol: validation, unix ancillary data,
shared memory, eventfd, logging, and on top of that you need to deal
with virtio queues, if possible efficiently.
qemu test has a nice vhost-user testing application vhost-user-bridge,
which implements most of vhost-user, and virtio.c which implements
virtqueues manipulation. Based on these two, I tried to make a simple
library, reusable for tests or development of new vhost-user scenarios.
Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com>
[Felipe: set used_idx copy on SET_VRING_ADDR and update shadow avail idx
on SET_VRING_BASE]
Signed-off-by: Felipe Franciosi <felipe@nutanix.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
2016-10-18 12:24:04 +03:00
|
|
|
/**
|
|
|
|
* vu_queue_rewind:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @num: number of elements to push back
|
|
|
|
*
|
|
|
|
* Pretend that elements weren't popped from the virtqueue. The next
|
|
|
|
* virtqueue_pop() will refetch the oldest element.
|
|
|
|
*
|
|
|
|
* Returns: true on success, false if @num is greater than the number of in use
|
|
|
|
* elements.
|
|
|
|
*/
|
|
|
|
bool vu_queue_rewind(VuDev *dev, VuVirtq *vq, unsigned int num);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_queue_fill:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @elem: a VuVirtqElement
|
|
|
|
* @len: length in bytes to write
|
|
|
|
* @idx: optional offset for the used ring index (0 in general)
|
|
|
|
*
|
|
|
|
* Fill the used ring with @elem element.
|
|
|
|
*/
|
|
|
|
void vu_queue_fill(VuDev *dev, VuVirtq *vq,
|
|
|
|
const VuVirtqElement *elem,
|
|
|
|
unsigned int len, unsigned int idx);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_queue_push:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @elem: a VuVirtqElement
|
|
|
|
* @len: length in bytes to write
|
|
|
|
*
|
|
|
|
* Helper that combines vu_queue_fill() with a vu_queue_flush().
|
|
|
|
*/
|
|
|
|
void vu_queue_push(VuDev *dev, VuVirtq *vq,
|
|
|
|
const VuVirtqElement *elem, unsigned int len);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_queue_flush:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @num: number of elements to flush
|
|
|
|
*
|
|
|
|
* Mark the last number of elements as done (used.idx is updated by
|
|
|
|
* num elements).
|
|
|
|
*/
|
|
|
|
void vu_queue_flush(VuDev *dev, VuVirtq *vq, unsigned int num);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_queue_get_avail_bytes:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @in_bytes: in bytes
|
|
|
|
* @out_bytes: out bytes
|
|
|
|
* @max_in_bytes: stop counting after max_in_bytes
|
|
|
|
* @max_out_bytes: stop counting after max_out_bytes
|
|
|
|
*
|
|
|
|
* Count the number of available bytes, up to max_in_bytes/max_out_bytes.
|
|
|
|
*/
|
|
|
|
void vu_queue_get_avail_bytes(VuDev *vdev, VuVirtq *vq, unsigned int *in_bytes,
|
|
|
|
unsigned int *out_bytes,
|
|
|
|
unsigned max_in_bytes, unsigned max_out_bytes);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* vu_queue_avail_bytes:
|
|
|
|
* @dev: a VuDev context
|
|
|
|
* @vq: a VuVirtq queue
|
|
|
|
* @in_bytes: expected in bytes
|
|
|
|
* @out_bytes: expected out bytes
|
|
|
|
*
|
|
|
|
* Returns: true if in_bytes <= in_total && out_bytes <= out_total
|
|
|
|
*/
|
|
|
|
bool vu_queue_avail_bytes(VuDev *dev, VuVirtq *vq, unsigned int in_bytes,
|
|
|
|
unsigned int out_bytes);
|
|
|
|
|
|
|
|
#endif /* LIBVHOST_USER_H */
|