diff options
author | Fam Zheng <famz@redhat.com> | 2014-09-24 16:27:54 +0800 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2014-09-30 13:30:51 +0200 |
commit | 3df9caf88f5c0859ae380101fea47609ba1dbfbd (patch) | |
tree | 7987f8bae8fad5bec70727ee53ba3ffbfa3ee142 /include/hw/scsi/scsi.h | |
parent | 6c25fa6cf8b58db72956e880d76e4adc301bb472 (diff) |
scsi: Unify request unref in scsi_req_cancel
Before, scsi_req_cancel will take ownership of the canceled request and unref
it. We did this because we didn't know whether AIO CB will be called or not
during the cancelling, so we set the io_canceled flag before calling it, and
skip unref in the potentially called callbacks, which is not very nice.
Now, bdrv_aio_cancel has a stricter contract that the completion callbacks are
always called, so we can remove the checks of req->io_canceled and just unref
it in callbacks.
It will also make implementing asynchronous cancellation easier.
Signed-off-by: Fam Zheng <famz@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'include/hw/scsi/scsi.h')
0 files changed, 0 insertions, 0 deletions