提交 ae23dde9 编写于 作者: K Kevin Wolf

test-bdrv-drain: Test AIO_WAIT_WHILE() in completion callback

This is a regression test for a deadlock that occurred in block job
completion callbacks (via job_defer_to_main_loop) because the AioContext
lock was taken twice: once in job_finish_sync() and then again in
job_defer_to_main_loop_bh(). This would cause AIO_WAIT_WHILE() to hang.
Signed-off-by: NKevin Wolf <kwolf@redhat.com>
Reviewed-by: NFam Zheng <famz@redhat.com>
上级 de0fbe64
...@@ -774,6 +774,15 @@ typedef struct TestBlockJob { ...@@ -774,6 +774,15 @@ typedef struct TestBlockJob {
bool should_complete; bool should_complete;
} TestBlockJob; } TestBlockJob;
static int test_job_prepare(Job *job)
{
TestBlockJob *s = container_of(job, TestBlockJob, common.job);
/* Provoke an AIO_WAIT_WHILE() call to verify there is no deadlock */
blk_flush(s->common.blk);
return 0;
}
static int coroutine_fn test_job_run(Job *job, Error **errp) static int coroutine_fn test_job_run(Job *job, Error **errp)
{ {
TestBlockJob *s = container_of(job, TestBlockJob, common.job); TestBlockJob *s = container_of(job, TestBlockJob, common.job);
...@@ -804,6 +813,7 @@ BlockJobDriver test_job_driver = { ...@@ -804,6 +813,7 @@ BlockJobDriver test_job_driver = {
.drain = block_job_drain, .drain = block_job_drain,
.run = test_job_run, .run = test_job_run,
.complete = test_job_complete, .complete = test_job_complete,
.prepare = test_job_prepare,
}, },
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册