mirror of
				https://github.com/qemu/qemu.git
				synced 2025-10-26 12:03:40 +00:00 
			
		
		
		
	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: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Fam Zheng <famz@redhat.com>
This commit is contained in:
		
							parent
							
								
									de0fbe6480
								
							
						
					
					
						commit
						ae23dde9dd
					
				| @ -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 = { | |||||||
|         .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, | ||||||
|     }, |     }, | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Kevin Wolf
						Kevin Wolf