mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-09 02:24:58 -06:00
scsi: use scsi_req_cancel_async when purging requests
This avoids calls to aio_poll without having acquired the context first. Reviewed-by: Fam Zheng <famz@redhat.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com> Message-Id: <1450290827-30508-1-git-send-email-pbonzini@redhat.com>
This commit is contained in:
parent
4cae9c9796
commit
8aad35f678
1 changed files with 4 additions and 2 deletions
|
@ -1841,11 +1841,13 @@ void scsi_device_purge_requests(SCSIDevice *sdev, SCSISense sense)
|
||||||
{
|
{
|
||||||
SCSIRequest *req;
|
SCSIRequest *req;
|
||||||
|
|
||||||
|
aio_context_acquire(blk_get_aio_context(sdev->conf.blk));
|
||||||
while (!QTAILQ_EMPTY(&sdev->requests)) {
|
while (!QTAILQ_EMPTY(&sdev->requests)) {
|
||||||
req = QTAILQ_FIRST(&sdev->requests);
|
req = QTAILQ_FIRST(&sdev->requests);
|
||||||
scsi_req_cancel(req);
|
scsi_req_cancel_async(req, NULL);
|
||||||
}
|
}
|
||||||
|
blk_drain(sdev->conf.blk);
|
||||||
|
aio_context_release(blk_get_aio_context(sdev->conf.blk));
|
||||||
scsi_device_set_ua(sdev, sense);
|
scsi_device_set_ua(sdev, sense);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue