summaryrefslogtreecommitdiffstats
path: root/block/qcow2.c
diff options
context:
space:
mode:
authorKevin Wolf2013-09-06 12:20:08 +0200
committerKevin Wolf2013-09-12 10:12:46 +0200
commit1ebf561c11302f4fbe4afdd82758fe053cf1d5fc (patch)
tree97ddd797d3feefe5751a858b3b2df42efbd3dea1 /block/qcow2.c
parentqcow2: Pass discard type to qcow2_discard_clusters() (diff)
downloadqemu-1ebf561c11302f4fbe4afdd82758fe053cf1d5fc.tar.gz
qemu-1ebf561c11302f4fbe4afdd82758fe053cf1d5fc.tar.xz
qemu-1ebf561c11302f4fbe4afdd82758fe053cf1d5fc.zip
qcow2: Discard VM state in active L1 after creating snapshot
During savevm, the VM state is written to the active L1 of the image and then a snapshot is taken. After that, the VM state isn't needed any more in the active L1 and should be discarded. This is implemented by this patch. The impact of not discarding the VM state is that a snapshot can never become smaller than any previous snapshot (because it would be padded with old VM state), and more importantly that future savevm operations cause unnecessary COWs (with associated flushes), which makes subsequent snapshots much slower. Signed-off-by: Kevin Wolf <kwolf@redhat.com> Reviewed-by: Max Reitz <mreitz@redhat.com>
Diffstat (limited to 'block/qcow2.c')
-rw-r--r--block/qcow2.c5
1 files changed, 0 insertions, 5 deletions
diff --git a/block/qcow2.c b/block/qcow2.c
index 147822e8fd..c9e266e22e 100644
--- a/block/qcow2.c
+++ b/block/qcow2.c
@@ -1757,11 +1757,6 @@ static coroutine_fn int qcow2_co_flush_to_os(BlockDriverState *bs)
return 0;
}
-static int64_t qcow2_vm_state_offset(BDRVQcowState *s)
-{
- return (int64_t)s->l1_vm_state_index << (s->cluster_bits + s->l2_bits);
-}
-
static int qcow2_get_info(BlockDriverState *bs, BlockDriverInfo *bdi)
{
BDRVQcowState *s = bs->opaque;