summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHeinz Graalfs <graalfs@linux.vnet.ibm.com>2013-10-29 00:10:30 +0100
committerRusty Russell <rusty@rustcorp.com.au>2013-10-29 01:58:17 +0100
commit7f03b17d5c3f3b63dcacf0e481cf94c9d07267ab (patch)
tree338af05a9b2456350b84858b314d101c9c71fc5a
parentvirtio_ring: add new function virtqueue_is_broken() (diff)
downloadlinux-7f03b17d5c3f3b63dcacf0e481cf94c9d07267ab.tar.xz
linux-7f03b17d5c3f3b63dcacf0e481cf94c9d07267ab.zip
virtio_blk: verify if queue is broken after virtqueue_get_buf()
In case virtqueue_get_buf() returned with a NULL pointer verify if the virtqueue is broken in order to leave while loop. Signed-off-by: Heinz Graalfs <graalfs@linux.vnet.ibm.com> Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
-rw-r--r--drivers/block/virtio_blk.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/block/virtio_blk.c b/drivers/block/virtio_blk.c
index 6b66252fc4e6..f3be496ac8fa 100644
--- a/drivers/block/virtio_blk.c
+++ b/drivers/block/virtio_blk.c
@@ -292,6 +292,8 @@ static void virtblk_done(struct virtqueue *vq)
req_done = true;
}
}
+ if (unlikely(virtqueue_is_broken(vq)))
+ break;
} while (!virtqueue_enable_cb(vq));
/* In case queue is stopped waiting for more buffers. */
if (req_done)