mirror of https://github.com/xemu-project/xemu.git
scsi: assert that callbacks run in the correct AioContext
Since the removal of AioContext locking, the correctness of the code relies on running requests from a single AioContext at any given time. Add assertions that verify that callbacks are invoked in the correct AioContext. Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Message-ID: <20231205182011.1976568-3-stefanha@redhat.com> Reviewed-by: Kevin Wolf <kwolf@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
parent
ed18b1ed4f
commit
10bcb0d996
|
@ -273,6 +273,10 @@ 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());
|
||||||
|
|
||||||
assert(r->req.aiocb != NULL);
|
assert(r->req.aiocb != NULL);
|
||||||
r->req.aiocb = NULL;
|
r->req.aiocb = NULL;
|
||||||
|
|
||||||
|
@ -370,8 +374,13 @@ 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());
|
||||||
|
|
||||||
assert(r->req.aiocb == NULL);
|
assert(r->req.aiocb == NULL);
|
||||||
if (scsi_disk_req_check_error(r, ret, false)) {
|
if (scsi_disk_req_check_error(r, ret, false)) {
|
||||||
goto done;
|
goto done;
|
||||||
|
@ -496,8 +505,13 @@ 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());
|
||||||
|
|
||||||
assert (r->req.aiocb == NULL);
|
assert (r->req.aiocb == NULL);
|
||||||
if (scsi_disk_req_check_error(r, ret, false)) {
|
if (scsi_disk_req_check_error(r, ret, false)) {
|
||||||
goto done;
|
goto done;
|
||||||
|
|
|
@ -119,6 +119,9 @@ static void dma_blk_cb(void *opaque, int ret)
|
||||||
|
|
||||||
trace_dma_blk_cb(dbs, ret);
|
trace_dma_blk_cb(dbs, ret);
|
||||||
|
|
||||||
|
/* DMAAIOCB is not thread-safe and must be accessed only from dbs->ctx */
|
||||||
|
assert(ctx == qemu_get_current_aio_context());
|
||||||
|
|
||||||
dbs->acb = NULL;
|
dbs->acb = NULL;
|
||||||
dbs->offset += dbs->iov.size;
|
dbs->offset += dbs->iov.size;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue