scsi-generic: do not use a stale aiocb
If a request is canceled after it has been completed, scsi_cancel_io would pass a stale aiocb to bdrv_aio_cancel. Avoid this. Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Cc: Christoph Hellwig <hch@lst.de>
This commit is contained in:
parent
cfdc1bb06e
commit
d33e0ce213
@ -91,6 +91,7 @@ static void scsi_command_complete(void *opaque, int ret)
|
|||||||
SCSIGenericReq *r = (SCSIGenericReq *)opaque;
|
SCSIGenericReq *r = (SCSIGenericReq *)opaque;
|
||||||
SCSIGenericState *s = DO_UPCAST(SCSIGenericState, qdev, r->req.dev);
|
SCSIGenericState *s = DO_UPCAST(SCSIGenericState, qdev, r->req.dev);
|
||||||
|
|
||||||
|
r->req.aiocb = NULL;
|
||||||
s->driver_status = r->io_header.driver_status;
|
s->driver_status = r->io_header.driver_status;
|
||||||
if (s->driver_status & SG_ERR_DRIVER_SENSE)
|
if (s->driver_status & SG_ERR_DRIVER_SENSE)
|
||||||
s->senselen = r->io_header.sb_len_wr;
|
s->senselen = r->io_header.sb_len_wr;
|
||||||
@ -163,6 +164,7 @@ static void scsi_read_complete(void * opaque, int ret)
|
|||||||
SCSIGenericReq *r = (SCSIGenericReq *)opaque;
|
SCSIGenericReq *r = (SCSIGenericReq *)opaque;
|
||||||
int len;
|
int len;
|
||||||
|
|
||||||
|
r->req.aiocb = NULL;
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DPRINTF("IO error ret %d\n", ret);
|
DPRINTF("IO error ret %d\n", ret);
|
||||||
scsi_command_complete(r, ret);
|
scsi_command_complete(r, ret);
|
||||||
@ -229,6 +231,7 @@ static void scsi_write_complete(void * opaque, int ret)
|
|||||||
SCSIGenericState *s = DO_UPCAST(SCSIGenericState, qdev, r->req.dev);
|
SCSIGenericState *s = DO_UPCAST(SCSIGenericState, qdev, r->req.dev);
|
||||||
|
|
||||||
DPRINTF("scsi_write_complete() ret = %d\n", ret);
|
DPRINTF("scsi_write_complete() ret = %d\n", ret);
|
||||||
|
r->req.aiocb = NULL;
|
||||||
if (ret) {
|
if (ret) {
|
||||||
DPRINTF("IO error\n");
|
DPRINTF("IO error\n");
|
||||||
scsi_command_complete(r, ret);
|
scsi_command_complete(r, ret);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user