summaryrefslogtreecommitdiffstats
path: root/drivers/virtio/virtio_input.c
diff options
context:
space:
mode:
authorJason Wang <jasowang@redhat.com>2015-08-06 07:54:21 +0200
committerMichael S. Tsirkin <mst@redhat.com>2015-08-06 09:40:35 +0200
commitdf4198b1e0c4a7d1adde1e5c2ceb67ac10b391bb (patch)
tree7a2f88d1e80de2f14e6cf43a12ecf2073dc1f2ca /drivers/virtio/virtio_input.c
parentLinux 4.2-rc5 (diff)
downloadlinux-df4198b1e0c4a7d1adde1e5c2ceb67ac10b391bb.tar.xz
linux-df4198b1e0c4a7d1adde1e5c2ceb67ac10b391bb.zip
virtio-input: reset device and detach unused during remove
Spec requires a device reset during cleanup, so do it and avoid warn in virtio core. And detach unused buffers to avoid memory leak. Signed-off-by: Jason Wang <jasowang@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
Diffstat (limited to 'drivers/virtio/virtio_input.c')
-rw-r--r--drivers/virtio/virtio_input.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/drivers/virtio/virtio_input.c b/drivers/virtio/virtio_input.c
index 60e2a1677563..c96944b59856 100644
--- a/drivers/virtio/virtio_input.c
+++ b/drivers/virtio/virtio_input.c
@@ -313,6 +313,7 @@ err_init_vq:
static void virtinput_remove(struct virtio_device *vdev)
{
struct virtio_input *vi = vdev->priv;
+ void *buf;
unsigned long flags;
spin_lock_irqsave(&vi->lock, flags);
@@ -320,6 +321,9 @@ static void virtinput_remove(struct virtio_device *vdev)
spin_unlock_irqrestore(&vi->lock, flags);
input_unregister_device(vi->idev);
+ vdev->config->reset(vdev);
+ while ((buf = virtqueue_detach_unused_buf(vi->sts)) != NULL)
+ kfree(buf);
vdev->config->del_vqs(vdev);
kfree(vi);
}