[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]
Subject: [RESEND Patch v1 20/37] vhost-pci-slave/msg: VHOST_USER_SET_VRING_KICK
Update the kickfd to the head node in the list. This version of vhost-pci expects the driver to use polling to receive packets. So, other than storing the kickfd, we don't do anything more. Signed-off-by: Wei Wang <wei.w.wang@intel.com> --- hw/virtio/vhost-pci-slave.c | 19 +++++++++++++++++++ include/hw/virtio/vhost-pci-slave.h | 1 + 2 files changed, 20 insertions(+) diff --git a/hw/virtio/vhost-pci-slave.c b/hw/virtio/vhost-pci-slave.c index 5ddcb8f..1286ab6 100644 --- a/hw/virtio/vhost-pci-slave.c +++ b/hw/virtio/vhost-pci-slave.c @@ -11,6 +11,7 @@ */ #include <qemu/osdep.h> +#include <qemu/sockets.h> #include "qapi/error.h" #include "qemu/error-report.h" @@ -230,6 +231,13 @@ static void vp_slave_set_vring_addr(VhostUserMsg *msg) sizeof(struct vhost_vring_addr)); } +static void vp_slave_set_vring_kick(int fd) +{ + PeerVqNode *pvq_node = QLIST_FIRST(&vp_slave->pvq_list); + if (!pvq_node) + pvq_node->kickfd = fd; +} + static int vp_slave_can_read(void *opaque) { return VHOST_USER_HDR_SIZE; @@ -306,6 +314,17 @@ static void vp_slave_read(void *opaque, const uint8_t *buf, int size) case VHOST_USER_SET_VRING_ADDR: vp_slave_set_vring_addr(&msg); break; + case VHOST_USER_SET_VRING_KICK: + /* consume the fd */ + qemu_chr_fe_get_msgfds(chr_be, fds, 1); + vp_slave_set_vring_kick(fds[0]); + /* + * This is a non-blocking eventfd. + * The receive function forces it to be blocking, + * so revert it back to non-blocking. + */ + qemu_set_nonblock(fds[0]); + break; default: error_report("vhost-pci-slave does not support msg request = %d", msg.request); diff --git a/include/hw/virtio/vhost-pci-slave.h b/include/hw/virtio/vhost-pci-slave.h index 439198d..4b6b213 100644 --- a/include/hw/virtio/vhost-pci-slave.h +++ b/include/hw/virtio/vhost-pci-slave.h @@ -10,6 +10,7 @@ typedef struct PeerVqNode { uint16_t last_avail_idx; uint32_t vring_num; + int kickfd; struct vhost_vring_addr addr; QLIST_ENTRY(PeerVqNode) node; } PeerVqNode; -- 2.7.4
[Date Prev] | [Thread Prev] | [Thread Next] | [Date Next] -- [Date Index] | [Thread Index] | [List Home]