|
@@ -576,8 +576,6 @@ static void __devexit virtblk_remove(struct virtio_device *vdev)
|
|
|
{
|
|
|
struct virtio_blk *vblk = vdev->priv;
|
|
|
int index = vblk->index;
|
|
|
- struct virtblk_req *vbr;
|
|
|
- unsigned long flags;
|
|
|
|
|
|
/* Prevent config work handler from accessing the device. */
|
|
|
mutex_lock(&vblk->config_lock);
|
|
@@ -585,21 +583,13 @@ static void __devexit virtblk_remove(struct virtio_device *vdev)
|
|
|
mutex_unlock(&vblk->config_lock);
|
|
|
|
|
|
del_gendisk(vblk->disk);
|
|
|
+ blk_cleanup_queue(vblk->disk->queue);
|
|
|
|
|
|
/* Stop all the virtqueues. */
|
|
|
vdev->config->reset(vdev);
|
|
|
|
|
|
flush_work(&vblk->config_work);
|
|
|
|
|
|
- /* Abort requests dispatched to driver. */
|
|
|
- spin_lock_irqsave(&vblk->lock, flags);
|
|
|
- while ((vbr = virtqueue_detach_unused_buf(vblk->vq))) {
|
|
|
- __blk_end_request_all(vbr->req, -EIO);
|
|
|
- mempool_free(vbr, vblk->pool);
|
|
|
- }
|
|
|
- spin_unlock_irqrestore(&vblk->lock, flags);
|
|
|
-
|
|
|
- blk_cleanup_queue(vblk->disk->queue);
|
|
|
put_disk(vblk->disk);
|
|
|
mempool_destroy(vblk->pool);
|
|
|
vdev->config->del_vqs(vdev);
|