Skip to content

Commit

Permalink
vhost: Add count argument to vhost_svq_poll()
Browse files Browse the repository at this point in the history
Next patches in this series will no longer perform an
immediate poll and check of the device's used buffers
for each CVQ state load command. Instead, they will
send CVQ state load commands in parallel by polling
multiple pending buffers at once.

To achieve this, this patch refactoring vhost_svq_poll()
to accept a new argument `num`, which allows vhost_svq_poll()
to wait for the device to use multiple elements,
rather than polling for a single element.

Signed-off-by: Hawkins Jiawei <yin31149@gmail.com>
Acked-by: Eugenio Pérez <eperezma@redhat.com>
Message-Id: <950b3bfcfc5d446168b9d6a249d554a013a691d4.1693287885.git.yin31149@gmail.com>
Reviewed-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
  • Loading branch information
JiaweiHawk authored and mstsirkin committed Oct 4, 2023
1 parent f13f5f6 commit b0de17a
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 16 deletions.
36 changes: 22 additions & 14 deletions hw/virtio/vhost-shadow-virtqueue.c
Original file line number Diff line number Diff line change
Expand Up @@ -514,29 +514,37 @@ static void vhost_svq_flush(VhostShadowVirtqueue *svq,
}

/**
* Poll the SVQ for one device used buffer.
* Poll the SVQ to wait for the device to use the specified number
* of elements and return the total length written by the device.
*
* This function race with main event loop SVQ polling, so extra
* synchronization is needed.
*
* Return the length written by the device.
* @svq: The svq
* @num: The number of elements that need to be used
*/
size_t vhost_svq_poll(VhostShadowVirtqueue *svq)
size_t vhost_svq_poll(VhostShadowVirtqueue *svq, size_t num)
{
int64_t start_us = g_get_monotonic_time();
uint32_t len = 0;
size_t len = 0;
uint32_t r;

do {
if (vhost_svq_more_used(svq)) {
break;
}
while (num--) {
int64_t start_us = g_get_monotonic_time();

if (unlikely(g_get_monotonic_time() - start_us > 10e6)) {
return 0;
}
} while (true);
do {
if (vhost_svq_more_used(svq)) {
break;
}

if (unlikely(g_get_monotonic_time() - start_us > 10e6)) {
return len;
}
} while (true);

vhost_svq_get_buf(svq, &r);
len += r;
}

vhost_svq_get_buf(svq, &len);
return len;
}

Expand Down
2 changes: 1 addition & 1 deletion hw/virtio/vhost-shadow-virtqueue.h
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ void vhost_svq_push_elem(VhostShadowVirtqueue *svq,
int vhost_svq_add(VhostShadowVirtqueue *svq, const struct iovec *out_sg,
size_t out_num, const struct iovec *in_sg, size_t in_num,
VirtQueueElement *elem);
size_t vhost_svq_poll(VhostShadowVirtqueue *svq);
size_t vhost_svq_poll(VhostShadowVirtqueue *svq, size_t num);

void vhost_svq_set_svq_kick_fd(VhostShadowVirtqueue *svq, int svq_kick_fd);
void vhost_svq_set_svq_call_fd(VhostShadowVirtqueue *svq, int call_fd);
Expand Down
2 changes: 1 addition & 1 deletion net/vhost-vdpa.c
Original file line number Diff line number Diff line change
Expand Up @@ -645,7 +645,7 @@ static ssize_t vhost_vdpa_net_cvq_add(VhostVDPAState *s, size_t out_len,
* descriptor. Also, we need to take the answer before SVQ pulls by itself,
* when BQL is released
*/
return vhost_svq_poll(svq);
return vhost_svq_poll(svq, 1);
}

static ssize_t vhost_vdpa_net_load_cmd(VhostVDPAState *s, uint8_t class,
Expand Down

0 comments on commit b0de17a

Please sign in to comment.