|
@@ -328,9 +328,8 @@ static void scsi_aio_complete(void *opaque, int ret)
|
|
SCSIDiskReq *r = (SCSIDiskReq *)opaque;
|
|
SCSIDiskReq *r = (SCSIDiskReq *)opaque;
|
|
SCSIDiskState *s = DO_UPCAST(SCSIDiskState, qdev, r->req.dev);
|
|
SCSIDiskState *s = DO_UPCAST(SCSIDiskState, qdev, r->req.dev);
|
|
|
|
|
|
- /* The request must only run in the BlockBackend's AioContext */
|
|
|
|
- assert(blk_get_aio_context(s->qdev.conf.blk) ==
|
|
|
|
- qemu_get_current_aio_context());
|
|
|
|
|
|
+ /* The request must run in its AioContext */
|
|
|
|
+ assert(r->req.ctx == qemu_get_current_aio_context());
|
|
|
|
|
|
assert(r->req.aiocb != NULL);
|
|
assert(r->req.aiocb != NULL);
|
|
r->req.aiocb = NULL;
|
|
r->req.aiocb = NULL;
|
|
@@ -430,12 +429,10 @@ static void scsi_dma_complete(void *opaque, int ret)
|
|
|
|
|
|
static void scsi_read_complete_noio(SCSIDiskReq *r, int ret)
|
|
static void scsi_read_complete_noio(SCSIDiskReq *r, int ret)
|
|
{
|
|
{
|
|
- SCSIDiskState *s = DO_UPCAST(SCSIDiskState, qdev, r->req.dev);
|
|
|
|
uint32_t n;
|
|
uint32_t n;
|
|
|
|
|
|
- /* The request must only run in the BlockBackend's AioContext */
|
|
|
|
- assert(blk_get_aio_context(s->qdev.conf.blk) ==
|
|
|
|
- qemu_get_current_aio_context());
|
|
|
|
|
|
+ /* The request must run in its AioContext */
|
|
|
|
+ assert(r->req.ctx == qemu_get_current_aio_context());
|
|
|
|
|
|
assert(r->req.aiocb == NULL);
|
|
assert(r->req.aiocb == NULL);
|
|
if (scsi_disk_req_check_error(r, ret, ret > 0)) {
|
|
if (scsi_disk_req_check_error(r, ret, ret > 0)) {
|
|
@@ -562,12 +559,10 @@ static void scsi_read_data(SCSIRequest *req)
|
|
|
|
|
|
static void scsi_write_complete_noio(SCSIDiskReq *r, int ret)
|
|
static void scsi_write_complete_noio(SCSIDiskReq *r, int ret)
|
|
{
|
|
{
|
|
- SCSIDiskState *s = DO_UPCAST(SCSIDiskState, qdev, r->req.dev);
|
|
|
|
uint32_t n;
|
|
uint32_t n;
|
|
|
|
|
|
- /* The request must only run in the BlockBackend's AioContext */
|
|
|
|
- assert(blk_get_aio_context(s->qdev.conf.blk) ==
|
|
|
|
- qemu_get_current_aio_context());
|
|
|
|
|
|
+ /* The request must run in its AioContext */
|
|
|
|
+ assert(r->req.ctx == qemu_get_current_aio_context());
|
|
|
|
|
|
assert (r->req.aiocb == NULL);
|
|
assert (r->req.aiocb == NULL);
|
|
if (scsi_disk_req_check_error(r, ret, ret > 0)) {
|
|
if (scsi_disk_req_check_error(r, ret, ret > 0)) {
|