diff options
author | John Snow <jsnow@redhat.com> | 2019-03-11 21:51:46 +0300 |
---|---|---|
committer | John Snow <jsnow@redhat.com> | 2019-03-12 14:57:38 -0400 |
commit | d19c6b36ffe09cec7ce7ac6a3e979bfe923ebba9 (patch) | |
tree | 3dcdf00d405fb293b204ab01dac792d65a9beca6 /block/qcow2.h | |
parent | bf5f0cf5d819cce45dd578a19386d8b60022654f (diff) | |
download | qemu-d19c6b36ffe09cec7ce7ac6a3e979bfe923ebba9.zip qemu-d19c6b36ffe09cec7ce7ac6a3e979bfe923ebba9.tar.gz qemu-d19c6b36ffe09cec7ce7ac6a3e979bfe923ebba9.tar.bz2 |
block/qcow2-bitmap: Allow resizes with persistent bitmaps
Since we now load all bitmaps into memory anyway, we can just truncate
them in-memory and then flush them back to disk. Just in case, we will
still check and enforce that this shortcut is valid -- i.e. that any
bitmap described on-disk is indeed in-memory and can be modified.
If there are any inconsistent bitmaps, we refuse to allow the truncate
as we do not actually load these bitmaps into memory, and it isn't safe
or reasonable to attempt to truncate corrupted data.
Signed-off-by: John Snow <jsnow@redhat.com>
Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
Message-id: 20190311185147.52309-4-vsementsov@virtuozzo.com
[vsementsov: drop bitmap flushing, fix block comments style]
Signed-off-by: John Snow <jsnow@redhat.com>
Diffstat (limited to 'block/qcow2.h')
-rw-r--r-- | block/qcow2.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/block/qcow2.h b/block/qcow2.h index de2a3bd..fdee297 100644 --- a/block/qcow2.h +++ b/block/qcow2.h @@ -723,6 +723,7 @@ Qcow2BitmapInfoList *qcow2_get_bitmap_info_list(BlockDriverState *bs, int qcow2_reopen_bitmaps_rw_hint(BlockDriverState *bs, bool *header_updated, Error **errp); int qcow2_reopen_bitmaps_rw(BlockDriverState *bs, Error **errp); +int qcow2_truncate_bitmaps_check(BlockDriverState *bs, Error **errp); void qcow2_store_persistent_dirty_bitmaps(BlockDriverState *bs, Error **errp); int qcow2_reopen_bitmaps_ro(BlockDriverState *bs, Error **errp); bool qcow2_can_store_new_dirty_bitmap(BlockDriverState *bs, |