diff options
author | Jason Wang <jasowang@redhat.com> | 2012-05-01 23:42:54 -0400 |
---|---|---|
committer | Michael S. Tsirkin <mst@redhat.com> | 2012-05-02 11:22:25 -0400 |
commit | c70aa540c7a9f67add11ad3161096fb95233aa2e (patch) | |
tree | c02be13561a4a9347efd42cb6379950e5e277025 /drivers/vhost | |
parent | c8fb217af57c6c232af3517d3115d2af4ce9900e (diff) |
vhost: zerocopy: poll vq in zerocopy callback
We add used and signal guest in worker thread but did not poll the virtqueue
during the zero copy callback. This may lead the missing of adding and
signalling during zerocopy. Solve this by polling the virtqueue and let it
wakeup the worker during callback.
Signed-off-by: Jason Wang <jasowang@redhat.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Diffstat (limited to 'drivers/vhost')
-rw-r--r-- | drivers/vhost/vhost.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/vhost/vhost.c b/drivers/vhost/vhost.c index 51e4c1eeec4f..94dbd25caa30 100644 --- a/drivers/vhost/vhost.c +++ b/drivers/vhost/vhost.c | |||
@@ -1603,6 +1603,7 @@ void vhost_zerocopy_callback(struct ubuf_info *ubuf) | |||
1603 | struct vhost_ubuf_ref *ubufs = ubuf->ctx; | 1603 | struct vhost_ubuf_ref *ubufs = ubuf->ctx; |
1604 | struct vhost_virtqueue *vq = ubufs->vq; | 1604 | struct vhost_virtqueue *vq = ubufs->vq; |
1605 | 1605 | ||
1606 | vhost_poll_queue(&vq->poll); | ||
1606 | /* set len = 1 to mark this desc buffers done DMA */ | 1607 | /* set len = 1 to mark this desc buffers done DMA */ |
1607 | vq->heads[ubuf->desc].len = VHOST_DMA_DONE_LEN; | 1608 | vq->heads[ubuf->desc].len = VHOST_DMA_DONE_LEN; |
1608 | kref_put(&ubufs->kref, vhost_zerocopy_done_signal); | 1609 | kref_put(&ubufs->kref, vhost_zerocopy_done_signal); |