[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-block] [PATCH v2 12/13] block: Add BlockDriverState.inherits_from
From: |
Kevin Wolf |
Subject: |
[Qemu-block] [PATCH v2 12/13] block: Add BlockDriverState.inherits_from |
Date: |
Wed, 10 Jun 2015 15:47:06 +0200 |
Currently, the block layer assumes that any block node can have only one
parent, and if it has a parent, that it inherits some options/flags from
this parent.
This is not true any more: With references used in block device
creation, a single node can be used by multiple parents, or it can be
created separately and not inherit flags from any parent.
To handle reopens correctly, a node must know from which parent it
inherited options. This patch adds the information to BlockDriverState.
Signed-off-by: Kevin Wolf <address@hidden>
Reviewed-by: Eric Blake <address@hidden>
Reviewed-by: Max Reitz <address@hidden>
---
block.c | 17 +++++++++++++++++
include/block/block_int.h | 4 ++++
2 files changed, 21 insertions(+)
diff --git a/block.c b/block.c
index e2236c3..fa89410 100644
--- a/block.c
+++ b/block.c
@@ -1398,6 +1398,7 @@ static int bdrv_open_inherit(BlockDriverState **pbs,
const char *filename,
}
if (child_role) {
+ bs->inherits_from = parent;
flags = child_role->inherit_flags(parent->open_flags);
}
@@ -1825,6 +1826,9 @@ void bdrv_close(BlockDriverState *bs)
BdrvChild *child, *next;
QLIST_FOREACH_SAFE(child, &bs->children, next, next) {
+ if (child->bs->inherits_from == bs) {
+ child->bs->inherits_from = NULL;
+ }
QLIST_REMOVE(child, next);
g_free(child);
}
@@ -1973,6 +1977,7 @@ static void bdrv_move_feature_fields(BlockDriverState
*bs_dest,
void bdrv_swap(BlockDriverState *bs_new, BlockDriverState *bs_old)
{
BlockDriverState tmp;
+ BdrvChild *child;
bdrv_drain(bs_new);
bdrv_drain(bs_old);
@@ -2032,6 +2037,18 @@ void bdrv_swap(BlockDriverState *bs_new,
BlockDriverState *bs_old)
QLIST_FIX_HEAD_PTR(&bs_new->children, next);
QLIST_FIX_HEAD_PTR(&bs_old->children, next);
+ /* Update references in bs->opaque and children */
+ QLIST_FOREACH(child, &bs_old->children, next) {
+ if (child->bs->inherits_from == bs_new) {
+ child->bs->inherits_from = bs_old;
+ }
+ }
+ QLIST_FOREACH(child, &bs_new->children, next) {
+ if (child->bs->inherits_from == bs_old) {
+ child->bs->inherits_from = bs_new;
+ }
+ }
+
bdrv_rebind(bs_new);
bdrv_rebind(bs_old);
}
diff --git a/include/block/block_int.h b/include/block/block_int.h
index 4ae5860..2732ccd 100644
--- a/include/block/block_int.h
+++ b/include/block/block_int.h
@@ -437,6 +437,10 @@ struct BlockDriverState {
/* long-running background operation */
BlockJob *job;
+ /* The node that this node inherited default options from (and a reopen on
+ * which can affect this node by changing these defaults). This is always a
+ * parent node of this node. */
+ BlockDriverState *inherits_from;
QLIST_HEAD(, BdrvChild) children;
QDict *options;
--
1.8.3.1
- [Qemu-block] [PATCH v2 05/13] vmdk: Use bdrv_open_image(), (continued)
- [Qemu-block] [PATCH v2 05/13] vmdk: Use bdrv_open_image(), Kevin Wolf, 2015/06/10
- [Qemu-block] [PATCH v2 07/13] block: Use QemuOpts in bdrv_open_common(), Kevin Wolf, 2015/06/10
- [Qemu-block] [PATCH v2 09/13] block: Drain requests before swapping nodes in bdrv_swap(), Kevin Wolf, 2015/06/10
- [Qemu-block] [PATCH v2 10/13] queue.h: Add QLIST_FIX_HEAD_PTR(), Kevin Wolf, 2015/06/10
- [Qemu-block] [PATCH v2 12/13] block: Add BlockDriverState.inherits_from,
Kevin Wolf <=
- [Qemu-block] [PATCH v2 08/13] block: Move flag inheritance to bdrv_open_inherit(), Kevin Wolf, 2015/06/10
- [Qemu-block] [PATCH v2 11/13] block: Add list of children to BlockDriverState, Kevin Wolf, 2015/06/10
- [Qemu-block] [PATCH v2 13/13] block: Fix reopen flag inheritance, Kevin Wolf, 2015/06/10