aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKevin Wolf <kwolf@redhat.com>2017-12-11 15:33:17 +0100
committerKevin Wolf <kwolf@redhat.com>2017-12-22 15:03:41 +0100
commitc200c4a470fc89d9a2b2d1884b140b03fd31981f (patch)
treed2dc8d18ba8d14d4cf74a6f53ca7bf6095f726be
parent60369b86c427c6646c53b607b5a3e6b507ffe8d6 (diff)
downloadqemu-c200c4a470fc89d9a2b2d1884b140b03fd31981f.zip
qemu-c200c4a470fc89d9a2b2d1884b140b03fd31981f.tar.gz
qemu-c200c4a470fc89d9a2b2d1884b140b03fd31981f.tar.bz2
block: Don't acquire AioContext in hmp_qemu_io()
Commit 15afd94a047 added code to acquire and release the AioContext in qemuio_command(). This means that the lock is taken twice now in the call path from hmp_qemu_io(). This causes BDRV_POLL_WHILE() to hang for any requests issued to nodes in a non-mainloop AioContext. Dropping the first locking from hmp_qemu_io() fixes the problem. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Stefan Hajnoczi <stefanha@redhat.com>
-rw-r--r--hmp.c6
1 files changed, 0 insertions, 6 deletions
diff --git a/hmp.c b/hmp.c
index 35a7041..2d72f94 100644
--- a/hmp.c
+++ b/hmp.c
@@ -2318,7 +2318,6 @@ void hmp_qemu_io(Monitor *mon, const QDict *qdict)
{
BlockBackend *blk;
BlockBackend *local_blk = NULL;
- AioContext *aio_context;
const char* device = qdict_get_str(qdict, "device");
const char* command = qdict_get_str(qdict, "command");
Error *err = NULL;
@@ -2338,9 +2337,6 @@ void hmp_qemu_io(Monitor *mon, const QDict *qdict)
}
}
- aio_context = blk_get_aio_context(blk);
- aio_context_acquire(aio_context);
-
/*
* Notably absent: Proper permission management. This is sad, but it seems
* almost impossible to achieve without changing the semantics and thereby
@@ -2368,8 +2364,6 @@ void hmp_qemu_io(Monitor *mon, const QDict *qdict)
*/
qemuio_command(blk, command);
- aio_context_release(aio_context);
-
fail:
blk_unref(local_blk);
hmp_handle_error(mon, &err);