diff options
author | Denis V. Lunev <den@openvz.org> | 2015-11-04 20:19:42 +0300 |
---|---|---|
committer | Stefan Hajnoczi <stefanha@redhat.com> | 2015-11-09 10:07:10 +0000 |
commit | 6bf1faa84877514971a20bb180b0ae5270bee571 (patch) | |
tree | a9912f5be1b9d42cd63d53c844b4cccf7ae9a3cc /monitor.c | |
parent | fbe3fc5cb3cd9f9064e98c549684e821c353fe41 (diff) | |
download | qemu-6bf1faa84877514971a20bb180b0ae5270bee571.tar.gz qemu-6bf1faa84877514971a20bb180b0ae5270bee571.tar.bz2 qemu-6bf1faa84877514971a20bb180b0ae5270bee571.zip |
monitor: add missed aio_context_acquire into vm_completion call
Signed-off-by: Denis V. Lunev <den@openvz.org>
CC: Stefan Hajnoczi <stefanha@redhat.com>
CC: Kevin Wolf <kwolf@redhat.com>
CC: Luiz Capitulino <lcapitulino@redhat.com>
CC: Markus Armbruster <armbru@redhat.com>
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Diffstat (limited to 'monitor.c')
-rw-r--r-- | monitor.c | 11 |
1 files changed, 8 insertions, 3 deletions
@@ -3408,13 +3408,18 @@ static void vm_completion(ReadLineState *rs, const char *str) readline_set_completion_index(rs, len); while ((bs = bdrv_next(bs))) { SnapshotInfoList *snapshots, *snapshot; + AioContext *ctx = bdrv_get_aio_context(bs); + bool ok = false; - if (!bdrv_can_snapshot(bs)) { - continue; + aio_context_acquire(ctx); + if (bdrv_can_snapshot(bs)) { + ok = bdrv_query_snapshot_info_list(bs, &snapshots, NULL) == 0; } - if (bdrv_query_snapshot_info_list(bs, &snapshots, NULL)) { + aio_context_release(ctx); + if (!ok) { continue; } + snapshot = snapshots; while (snapshot) { char *completion = snapshot->value->name; |