diff options
author | Kevin Wolf <kwolf@redhat.com> | 2023-05-10 22:35:57 +0200 |
---|---|---|
committer | Kevin Wolf <kwolf@redhat.com> | 2023-05-19 19:12:12 +0200 |
commit | 3db0c8b25c452b53aabc8efa36e655c7c02abb8f (patch) | |
tree | 5c38d0cd7a2b6bcd88d20b7a0b5d000e8054a4d9 | |
parent | e3e31dc87208007784b93a19f8efcdda90ea64f6 (diff) | |
download | qemu-3db0c8b25c452b53aabc8efa36e655c7c02abb8f.zip qemu-3db0c8b25c452b53aabc8efa36e655c7c02abb8f.tar.gz qemu-3db0c8b25c452b53aabc8efa36e655c7c02abb8f.tar.bz2 |
qemu-img: Take graph lock more selectively
If we take a reader lock, we can't call any functions that take a writer
lock internally without causing deadlocks once the reader lock is
actually enforced in the main thread, too. Take the reader lock only
where it is actually needed.
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Message-Id: <20230510203601.418015-5-kwolf@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
-rw-r--r-- | qemu-img.c | 5 |
1 files changed, 3 insertions, 2 deletions
@@ -2938,8 +2938,6 @@ static BlockGraphInfoList *collect_image_info_list(bool image_opts, } bs = blk_bs(blk); - GRAPH_RDLOCK_GUARD_MAINLOOP(); - /* * Note that the returned BlockGraphInfo object will not have * information about this image's backing node, because we have opened @@ -2947,7 +2945,10 @@ static BlockGraphInfoList *collect_image_info_list(bool image_opts, * duplicate the backing chain information that we obtain by walking * the chain manually here. */ + bdrv_graph_rdlock_main_loop(); bdrv_query_block_graph_info(bs, &info, &err); + bdrv_graph_rdunlock_main_loop(); + if (err) { error_report_err(err); blk_unref(blk); |