| Submitter | Kevin Wolf |
|---|---|
| Date | Oct. 22, 2010, 1:43 p.m. |
| Message ID | <1287755036-27688-12-git-send-email-kwolf@redhat.com> |
| Download | mbox | patch |
| Permalink | /patch/68856/ |
| State | New |
| Headers | show |
Comments
Patch
diff --git a/hw/virtio-blk.c b/hw/virtio-blk.c index a1df26d..dbe2070 100644 --- a/hw/virtio-blk.c +++ b/hw/virtio-blk.c @@ -106,7 +106,13 @@ static void virtio_blk_flush_complete(void *opaque, int ret) { VirtIOBlockReq *req = opaque; - virtio_blk_req_complete(req, ret ? VIRTIO_BLK_S_IOERR : VIRTIO_BLK_S_OK); + if (ret) { + if (virtio_blk_handle_rw_error(req, -ret, 0)) { + return; + } + } + + virtio_blk_req_complete(req, VIRTIO_BLK_S_OK); } static VirtIOBlockReq *virtio_blk_alloc_request(VirtIOBlock *s)
The werror option now affects not only write requests, but also flush requests. Previously, it was not possible to stop a VM on a failed flush. Signed-off-by: Kevin Wolf <kwolf@redhat.com> --- hw/virtio-blk.c | 8 +++++++- 1 files changed, 7 insertions(+), 1 deletions(-)