Skip to content

Commit

Permalink
snapshot: create bdrv_all_goto_snapshot helper
Browse files Browse the repository at this point in the history
to switch to snapshot on all loaded block drivers.

The patch also ensures proper locking.

Signed-off-by: Denis V. Lunev <[email protected]>
Reviewed-by: Greg Kurz <[email protected]>
Reviewed-by: Stefan Hajnoczi <[email protected]>
Reviewed-by: Fam Zheng <[email protected]>
Reviewed-by: Juan Quintela <[email protected]>
CC: Kevin Wolf <[email protected]>
Tested-by: Greg Kurz <[email protected]>
Signed-off-by: Juan Quintela <[email protected]>
  • Loading branch information
Denis V. Lunev authored and Juan Quintela committed Nov 19, 2015
1 parent 9b00ea3 commit 4c1cdba
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 10 deletions.
20 changes: 20 additions & 0 deletions block/snapshot.c
Original file line number Diff line number Diff line change
Expand Up @@ -403,3 +403,23 @@ int bdrv_all_delete_snapshot(const char *name, BlockDriverState **first_bad_bs,
*first_bad_bs = bs;
return ret;
}


int bdrv_all_goto_snapshot(const char *name, BlockDriverState **first_bad_bs)
{
int err = 0;
BlockDriverState *bs = NULL;

while (err == 0 && (bs = bdrv_next(bs))) {
AioContext *ctx = bdrv_get_aio_context(bs);

aio_context_acquire(ctx);
if (bdrv_can_snapshot(bs)) {
err = bdrv_snapshot_goto(bs, name);
}
aio_context_release(ctx);
}

*first_bad_bs = bs;
return err;
}
1 change: 1 addition & 0 deletions include/block/snapshot.h
Original file line number Diff line number Diff line change
Expand Up @@ -84,5 +84,6 @@ int bdrv_snapshot_load_tmp_by_id_or_name(BlockDriverState *bs,
bool bdrv_all_can_snapshot(BlockDriverState **first_bad_bs);
int bdrv_all_delete_snapshot(const char *name, BlockDriverState **first_bsd_bs,
Error **err);
int bdrv_all_goto_snapshot(const char *name, BlockDriverState **first_bsd_bs);

#endif
15 changes: 5 additions & 10 deletions migration/savevm.c
Original file line number Diff line number Diff line change
Expand Up @@ -2093,16 +2093,11 @@ int load_vmstate(const char *name)
/* Flush all IO requests so they don't interfere with the new state. */
bdrv_drain_all();

bs = NULL;
while ((bs = bdrv_next(bs))) {
if (bdrv_can_snapshot(bs)) {
ret = bdrv_snapshot_goto(bs, name);
if (ret < 0) {
error_report("Error %d while activating snapshot '%s' on '%s'",
ret, name, bdrv_get_device_name(bs));
return ret;
}
}
ret = bdrv_all_goto_snapshot(name, &bs);
if (ret < 0) {
error_report("Error %d while activating snapshot '%s' on '%s'",
ret, name, bdrv_get_device_name(bs));
return ret;
}

/* restore the VM state */
Expand Down

0 comments on commit 4c1cdba

Please sign in to comment.