mirror of https://github.com/xemu-project/xemu.git
virtio-blk: Fix restart after read error
Current code assumes that only write requests are ever going to be restarted. This is wrong since rerror=stop exists. Instead of directly starting writes, use the same request processing as used for new requests. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
parent
bc6694d43a
commit
f1b5286803
|
@ -384,6 +384,10 @@ static void virtio_blk_dma_restart_bh(void *opaque)
|
|||
{
|
||||
VirtIOBlock *s = opaque;
|
||||
VirtIOBlockReq *req = s->rq;
|
||||
MultiReqBuffer mrb = {
|
||||
.num_writes = 0,
|
||||
.old_bs = NULL,
|
||||
};
|
||||
|
||||
qemu_bh_delete(s->bh);
|
||||
s->bh = NULL;
|
||||
|
@ -391,10 +395,13 @@ static void virtio_blk_dma_restart_bh(void *opaque)
|
|||
s->rq = NULL;
|
||||
|
||||
while (req) {
|
||||
bdrv_aio_writev(req->dev->bs, req->out->sector, &req->qiov,
|
||||
req->qiov.size / 512, virtio_blk_rw_complete, req);
|
||||
virtio_blk_handle_request(req, &mrb);
|
||||
req = req->next;
|
||||
}
|
||||
|
||||
if (mrb.num_writes > 0) {
|
||||
do_multiwrite(mrb.old_bs, mrb.blkreq, mrb.num_writes);
|
||||
}
|
||||
}
|
||||
|
||||
static void virtio_blk_dma_restart_cb(void *opaque, int running, int reason)
|
||||
|
|
Loading…
Reference in New Issue