[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 07/11] block: do not acquire AioContext in check_to_
From: |
Paolo Bonzini |
Subject: |
[Qemu-devel] [PATCH 07/11] block: do not acquire AioContext in check_to_replace_node |
Date: |
Thu, 6 Jul 2017 18:38:24 +0200 |
The only caller does it already.
Signed-off-by: Paolo Bonzini <address@hidden>
---
block.c | 13 +++----------
1 file changed, 3 insertions(+), 10 deletions(-)
diff --git a/block.c b/block.c
index 694396281b..af0a9a1c22 100644
--- a/block.c
+++ b/block.c
@@ -4701,23 +4701,19 @@ bool bdrv_is_first_non_filter(BlockDriverState
*candidate)
return false;
}
+/* Called with AioContext lock held. */
BlockDriverState *check_to_replace_node(BlockDriverState *parent_bs,
const char *node_name, Error **errp)
{
BlockDriverState *to_replace_bs = bdrv_find_node(node_name);
- AioContext *aio_context;
if (!to_replace_bs) {
error_setg(errp, "Node name '%s' not found", node_name);
return NULL;
}
- aio_context = bdrv_get_aio_context(to_replace_bs);
- aio_context_acquire(aio_context);
-
if (bdrv_op_is_blocked(to_replace_bs, BLOCK_OP_TYPE_REPLACE, errp)) {
- to_replace_bs = NULL;
- goto out;
+ return NULL;
}
/* We don't want arbitrary node of the BDS chain to be replaced only the
top
@@ -4727,12 +4723,9 @@ BlockDriverState *check_to_replace_node(BlockDriverState
*parent_bs,
*/
if (!bdrv_recurse_is_first_non_filter(parent_bs, to_replace_bs)) {
error_setg(errp, "Only top most non filter can be replaced");
- to_replace_bs = NULL;
- goto out;
+ return NULL;
}
-out:
- aio_context_release(aio_context);
return to_replace_bs;
}
--
2.13.0
- Re: [Qemu-devel] [PATCH 03/11] util: use RCU accessors for notifiers, (continued)
[Qemu-devel] [PATCH 05/11] block-backup: add reqs_lock, Paolo Bonzini, 2017/07/06
[Qemu-devel] [PATCH 08/11] block: drain I/O around key management, Paolo Bonzini, 2017/07/06
[Qemu-devel] [PATCH 06/11] block: add a few more notes on locking, Paolo Bonzini, 2017/07/06
[Qemu-devel] [PATCH 09/11] block/replication: do not acquire AioContext, Paolo Bonzini, 2017/07/06
[Qemu-devel] [PATCH 07/11] block: do not acquire AioContext in check_to_replace_node,
Paolo Bonzini <=
[Qemu-devel] [PATCH 10/11] block: do not take AioContext around reopen, Paolo Bonzini, 2017/07/06
[Qemu-devel] [PATCH 11/11] block/snapshot: do not take AioContext lock, Paolo Bonzini, 2017/07/06
Re: [Qemu-devel] [RFC PATCH 00/11] Block layer thread-safety, next part, no-reply, 2017/07/06