* [Qemu-devel] [PATCH 1/3] ide: Handle immediate bdrv_aio_flush failure
2010-10-27 11:20 [Qemu-devel] [PATCH 0/3] Consider werror/rerror on immediate bdrv_aio_* failure Kevin Wolf
@ 2010-10-27 11:20 ` Kevin Wolf
2010-10-27 11:20 ` [Qemu-devel] [PATCH 2/3] virtio-blk: Handle immediate flush failure properly Kevin Wolf
2010-10-27 11:20 ` [Qemu-devel] [PATCH 3/3] scsi-disk: Fix immediate failure of bdrv_aio_* Kevin Wolf
2 siblings, 0 replies; 4+ messages in thread
From: Kevin Wolf @ 2010-10-27 11:20 UTC (permalink / raw)
To: qemu-devel; +Cc: kwolf
If bdrv_aio_flush returns NULL, this should be treated as an error.
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
---
hw/ide/core.c | 12 +++++++++---
1 files changed, 9 insertions(+), 3 deletions(-)
diff --git a/hw/ide/core.c b/hw/ide/core.c
index bc3e916..484e0ca 100644
--- a/hw/ide/core.c
+++ b/hw/ide/core.c
@@ -811,10 +811,16 @@ static void ide_flush_cb(void *opaque, int ret)
static void ide_flush_cache(IDEState *s)
{
- if (s->bs) {
- bdrv_aio_flush(s->bs, ide_flush_cb, s);
- } else {
+ BlockDriverAIOCB *acb;
+
+ if (s->bs == NULL) {
ide_flush_cb(s, 0);
+ return;
+ }
+
+ acb = bdrv_aio_flush(s->bs, ide_flush_cb, s);
+ if (acb == NULL) {
+ ide_flush_cb(s, -EIO);
}
}
--
1.7.2.3
^ permalink raw reply related [flat|nested] 4+ messages in thread
* [Qemu-devel] [PATCH 3/3] scsi-disk: Fix immediate failure of bdrv_aio_*
2010-10-27 11:20 [Qemu-devel] [PATCH 0/3] Consider werror/rerror on immediate bdrv_aio_* failure Kevin Wolf
2010-10-27 11:20 ` [Qemu-devel] [PATCH 1/3] ide: Handle immediate bdrv_aio_flush failure Kevin Wolf
2010-10-27 11:20 ` [Qemu-devel] [PATCH 2/3] virtio-blk: Handle immediate flush failure properly Kevin Wolf
@ 2010-10-27 11:20 ` Kevin Wolf
2 siblings, 0 replies; 4+ messages in thread
From: Kevin Wolf @ 2010-10-27 11:20 UTC (permalink / raw)
To: qemu-devel; +Cc: kwolf
Fix scsi-disk to use the usual completion paths that involve rerror/werror
handling instead of directly completing the requests in cases where
bdrv_aio_readv/writev returns NULL.
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
---
hw/scsi-disk.c | 11 ++++++-----
1 files changed, 6 insertions(+), 5 deletions(-)
diff --git a/hw/scsi-disk.c b/hw/scsi-disk.c
index a1976ea..18b4d1a 100644
--- a/hw/scsi-disk.c
+++ b/hw/scsi-disk.c
@@ -178,8 +178,9 @@ static void scsi_read_request(SCSIDiskReq *r)
qemu_iovec_init_external(&r->qiov, &r->iov, 1);
r->req.aiocb = bdrv_aio_readv(s->bs, r->sector, &r->qiov, n,
scsi_read_complete, r);
- if (r->req.aiocb == NULL)
- scsi_command_complete(r, CHECK_CONDITION, HARDWARE_ERROR);
+ if (r->req.aiocb == NULL) {
+ scsi_read_complete(r, -EIO);
+ }
}
/* Read more data from scsi device into buffer. */
@@ -274,9 +275,9 @@ static void scsi_write_request(SCSIDiskReq *r)
qemu_iovec_init_external(&r->qiov, &r->iov, 1);
r->req.aiocb = bdrv_aio_writev(s->bs, r->sector, &r->qiov, n,
scsi_write_complete, r);
- if (r->req.aiocb == NULL)
- scsi_command_complete(r, CHECK_CONDITION,
- HARDWARE_ERROR);
+ if (r->req.aiocb == NULL) {
+ scsi_write_complete(r, -EIO);
+ }
} else {
/* Invoke completion routine to fetch data from host. */
scsi_write_complete(r, 0);
--
1.7.2.3
^ permalink raw reply related [flat|nested] 4+ messages in thread