mirror of
https://git.proxmox.com/git/qemu
synced 2025-07-17 14:05:11 +00:00
scsi-disk: Fix immediate failure of bdrv_aio_*
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>
This commit is contained in:
parent
18a8d4214b
commit
d33ea50a95
@ -178,8 +178,9 @@ static void scsi_read_request(SCSIDiskReq *r)
|
|||||||
qemu_iovec_init_external(&r->qiov, &r->iov, 1);
|
qemu_iovec_init_external(&r->qiov, &r->iov, 1);
|
||||||
r->req.aiocb = bdrv_aio_readv(s->bs, r->sector, &r->qiov, n,
|
r->req.aiocb = bdrv_aio_readv(s->bs, r->sector, &r->qiov, n,
|
||||||
scsi_read_complete, r);
|
scsi_read_complete, r);
|
||||||
if (r->req.aiocb == NULL)
|
if (r->req.aiocb == NULL) {
|
||||||
scsi_command_complete(r, CHECK_CONDITION, HARDWARE_ERROR);
|
scsi_read_complete(r, -EIO);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Read more data from scsi device into buffer. */
|
/* Read more data from scsi device into buffer. */
|
||||||
@ -273,9 +274,9 @@ static void scsi_write_request(SCSIDiskReq *r)
|
|||||||
qemu_iovec_init_external(&r->qiov, &r->iov, 1);
|
qemu_iovec_init_external(&r->qiov, &r->iov, 1);
|
||||||
r->req.aiocb = bdrv_aio_writev(s->bs, r->sector, &r->qiov, n,
|
r->req.aiocb = bdrv_aio_writev(s->bs, r->sector, &r->qiov, n,
|
||||||
scsi_write_complete, r);
|
scsi_write_complete, r);
|
||||||
if (r->req.aiocb == NULL)
|
if (r->req.aiocb == NULL) {
|
||||||
scsi_command_complete(r, CHECK_CONDITION,
|
scsi_write_complete(r, -EIO);
|
||||||
HARDWARE_ERROR);
|
}
|
||||||
} else {
|
} else {
|
||||||
/* Invoke completion routine to fetch data from host. */
|
/* Invoke completion routine to fetch data from host. */
|
||||||
scsi_write_complete(r, 0);
|
scsi_write_complete(r, 0);
|
||||||
|
Loading…
Reference in New Issue
Block a user