/* * Sharing QEMU devices via vhost-user protocol * * Copyright (c) Coiby Xu . * Copyright (c) 2020 Red Hat, Inc. * * 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 VHOST_USER_SERVER_H #define VHOST_USER_SERVER_H #include "subprojects/libvhost-user/libvhost-user.h" /* only for the type definitions */ #include "io/channel-socket.h" #include "io/channel-file.h" #include "io/net-listener.h" #include "qapi/error.h" #include "standard-headers/linux/virtio_blk.h" /* A kick fd that we monitor on behalf of libvhost-user */ typedef struct VuFdWatch { VuDev *vu_dev; int fd; /*kick fd*/ void *pvt; vu_watch_cb cb; QTAILQ_ENTRY(VuFdWatch) next; } VuFdWatch; /** * VuServer: * A vhost-user server instance with user-defined VuDevIface callbacks. * Vhost-user device backends can be implemented using VuServer. VuDevIface * callbacks and virtqueue kicks run in the given AioContext. */ typedef struct { QIONetListener *listener; QEMUBH *restart_listener_bh; AioContext *ctx; int max_queues; const VuDevIface *vu_iface; unsigned int in_flight; /* atomic */ /* Protected by ctx lock */ bool in_qio_channel_yield; bool wait_idle; bool quiescing; VuDev vu_dev; QIOChannel *ioc; /* The I/O channel with the client */ QIOChannelSocket *sioc; /* The underlying data channel with the client */ QTAILQ_HEAD(, VuFdWatch) vu_fd_watches; Coroutine *co_trip; /* coroutine for processing VhostUserMsg */ } VuServer; bool vhost_user_server_start(VuServer *server, SocketAddress *unix_socket, AioContext *ctx, uint16_t max_queues, const VuDevIface *vu_iface, Error **errp); void vhost_user_server_stop(VuServer *server); void vhost_user_server_inc_in_flight(VuServer *server); void vhost_user_server_dec_in_flight(VuServer *server); bool vhost_user_server_has_in_flight(VuServer *server); void vhost_user_server_attach_aio_context(VuServer *server, AioContext *ctx); void vhost_user_server_detach_aio_context(VuServer *server); #endif /* VHOST_USER_SERVER_H */