qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Qemu-devel] [RFC V8 12/13] quorum: Add quorum_snapshot_reopen.


From: Benoît Canet
Subject: [Qemu-devel] [RFC V8 12/13] quorum: Add quorum_snapshot_reopen.
Date: Mon, 28 Jan 2013 18:07:24 +0100

Signed-off-by: Benoit Canet <address@hidden>
---
 block/quorum.c |   20 ++++++++++++++++++++
 1 file changed, 20 insertions(+)

diff --git a/block/quorum.c b/block/quorum.c
index cc02c5f..4d86c32 100644
--- a/block/quorum.c
+++ b/block/quorum.c
@@ -795,6 +795,25 @@ free_new_s_exit:
     quorum_free(&new_s);
 }
 
+static int quorum_snapshot_reopen(BlockDriverState *bs, int bdrv_flags,
+                                  Error **errp)
+{
+    BDRVQuorumState *s = bs->file->opaque;
+    int i, ret = -1;
+    Error *local_err = NULL;
+    BlockReopenQueue *queue = NULL;
+
+    for (i = 0; i < s->total; i++) {
+        queue = bdrv_reopen_queue(queue, s->bs[i], bdrv_flags);
+    }
+
+    ret = bdrv_reopen_multiple(queue, &local_err);
+    if (local_err != NULL) {
+        error_propagate(errp, local_err);
+    }
+    return ret;
+}
+
 static BlockDriver bdrv_quorum = {
     .format_name        = "quorum",
     .protocol_name      = "quorum",
@@ -811,6 +830,7 @@ static BlockDriver bdrv_quorum = {
     .bdrv_co_is_allocated  = quorum_co_is_allocated,
 
     .bdrv_ext_snapshot_img_create = quorum_snapshot_img_create,
+    .bdrv_ext_snapshot_reopen = quorum_snapshot_reopen,
 };
 
 static void bdrv_quorum_init(void)
-- 
1.7.10.4




reply via email to

[Prev in Thread] Current Thread [Next in Thread]