qemu-img: Empty image after commit
After the top image has been committed, it should be emptied unless specified otherwise. Signed-off-by: Max Reitz <mreitz@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Kevin Wolf <kwolf@redhat.com> Message-id: 1414159063-25977-10-git-send-email-mreitz@redhat.com Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
This commit is contained in:
parent
d4a3238af5
commit
9a86fe4895
@ -22,9 +22,9 @@ STEXI
|
|||||||
ETEXI
|
ETEXI
|
||||||
|
|
||||||
DEF("commit", img_commit,
|
DEF("commit", img_commit,
|
||||||
"commit [-q] [-f fmt] [-t cache] filename")
|
"commit [-q] [-f fmt] [-t cache] [-d] filename")
|
||||||
STEXI
|
STEXI
|
||||||
@item commit [-q] [-f @var{fmt}] [-t @var{cache}] @var{filename}
|
@item commit [-q] [-f @var{fmt}] [-t @var{cache}] [-d] @var{filename}
|
||||||
ETEXI
|
ETEXI
|
||||||
|
|
||||||
DEF("compare", img_compare,
|
DEF("compare", img_compare,
|
||||||
|
34
qemu-img.c
34
qemu-img.c
@ -757,14 +757,14 @@ static int img_commit(int argc, char **argv)
|
|||||||
const char *filename, *fmt, *cache;
|
const char *filename, *fmt, *cache;
|
||||||
BlockBackend *blk;
|
BlockBackend *blk;
|
||||||
BlockDriverState *bs, *base_bs;
|
BlockDriverState *bs, *base_bs;
|
||||||
bool quiet = false;
|
bool quiet = false, drop = false;
|
||||||
Error *local_err = NULL;
|
Error *local_err = NULL;
|
||||||
CommonBlockJobCBInfo cbi;
|
CommonBlockJobCBInfo cbi;
|
||||||
|
|
||||||
fmt = NULL;
|
fmt = NULL;
|
||||||
cache = BDRV_DEFAULT_CACHE;
|
cache = BDRV_DEFAULT_CACHE;
|
||||||
for(;;) {
|
for(;;) {
|
||||||
c = getopt(argc, argv, "f:ht:q");
|
c = getopt(argc, argv, "f:ht:dq");
|
||||||
if (c == -1) {
|
if (c == -1) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -779,6 +779,9 @@ static int img_commit(int argc, char **argv)
|
|||||||
case 't':
|
case 't':
|
||||||
cache = optarg;
|
cache = optarg;
|
||||||
break;
|
break;
|
||||||
|
case 'd':
|
||||||
|
drop = true;
|
||||||
|
break;
|
||||||
case 'q':
|
case 'q':
|
||||||
quiet = true;
|
quiet = true;
|
||||||
break;
|
break;
|
||||||
@ -789,7 +792,7 @@ static int img_commit(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
filename = argv[optind++];
|
filename = argv[optind++];
|
||||||
|
|
||||||
flags = BDRV_O_RDWR;
|
flags = BDRV_O_RDWR | BDRV_O_UNMAP;
|
||||||
ret = bdrv_parse_cache_flags(cache, &flags);
|
ret = bdrv_parse_cache_flags(cache, &flags);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
error_report("Invalid cache option: %s", cache);
|
error_report("Invalid cache option: %s", cache);
|
||||||
@ -822,7 +825,32 @@ static int img_commit(int argc, char **argv)
|
|||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* The block job will swap base_bs and bs (which is not what we really want
|
||||||
|
* here, but okay) and unref base_bs (after the swap, i.e., the old top
|
||||||
|
* image). In order to still be able to empty that top image afterwards,
|
||||||
|
* increment the reference counter here preemptively. */
|
||||||
|
if (!drop) {
|
||||||
|
bdrv_ref(base_bs);
|
||||||
|
}
|
||||||
|
|
||||||
run_block_job(bs->job, &local_err);
|
run_block_job(bs->job, &local_err);
|
||||||
|
if (local_err) {
|
||||||
|
goto unref_backing;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!drop && base_bs->drv->bdrv_make_empty) {
|
||||||
|
ret = base_bs->drv->bdrv_make_empty(base_bs);
|
||||||
|
if (ret) {
|
||||||
|
error_setg_errno(&local_err, -ret, "Could not empty %s",
|
||||||
|
filename);
|
||||||
|
goto unref_backing;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
unref_backing:
|
||||||
|
if (!drop) {
|
||||||
|
bdrv_unref(base_bs);
|
||||||
|
}
|
||||||
|
|
||||||
done:
|
done:
|
||||||
blk_unref(blk);
|
blk_unref(blk);
|
||||||
|
@ -167,7 +167,7 @@ this case. @var{backing_file} will never be modified unless you use the
|
|||||||
The size can also be specified using the @var{size} option with @code{-o},
|
The size can also be specified using the @var{size} option with @code{-o},
|
||||||
it doesn't need to be specified separately in this case.
|
it doesn't need to be specified separately in this case.
|
||||||
|
|
||||||
@item commit [-f @var{fmt}] [-t @var{cache}] @var{filename}
|
@item commit [-f @var{fmt}] [-t @var{cache}] [-d] @var{filename}
|
||||||
|
|
||||||
Commit the changes recorded in @var{filename} in its base image or backing file.
|
Commit the changes recorded in @var{filename} in its base image or backing file.
|
||||||
If the backing file is smaller than the snapshot, then the backing file will be
|
If the backing file is smaller than the snapshot, then the backing file will be
|
||||||
@ -176,6 +176,10 @@ the backing file, the backing file will not be truncated. If you want the
|
|||||||
backing file to match the size of the smaller snapshot, you can safely truncate
|
backing file to match the size of the smaller snapshot, you can safely truncate
|
||||||
it yourself once the commit operation successfully completes.
|
it yourself once the commit operation successfully completes.
|
||||||
|
|
||||||
|
The image @var{filename} is emptied after the operation has succeeded. If you do
|
||||||
|
not need @var{filename} afterwards and intend to drop it, you may skip emptying
|
||||||
|
@var{filename} by specifying the @code{-d} flag.
|
||||||
|
|
||||||
@item compare [-f @var{fmt}] [-F @var{fmt}] [-T @var{src_cache}] [-p] [-s] [-q] @var{filename1} @var{filename2}
|
@item compare [-f @var{fmt}] [-F @var{fmt}] [-T @var{src_cache}] [-p] [-s] [-q] @var{filename1} @var{filename2}
|
||||||
|
|
||||||
Check if two images have the same content. You can compare images with
|
Check if two images have the same content. You can compare images with
|
||||||
|
Loading…
Reference in New Issue
Block a user