summaryrefslogtreecommitdiffstats
path: root/block
diff options
context:
space:
mode:
authorVladimir Sementsov-Ogievskiy2019-01-16 00:26:50 +0100
committerJohn Snow2019-01-16 00:26:50 +0100
commita78a1a48cd1a2e86f23f113bb05e2d3dd8ae0bf6 (patch)
tree2e2007b9051da3cdab632a4f29af3c8f1e777f3e /block
parenttests: add tests for hbitmap_next_zero with specified end parameter (diff)
downloadqemu-a78a1a48cd1a2e86f23f113bb05e2d3dd8ae0bf6.tar.gz
qemu-a78a1a48cd1a2e86f23f113bb05e2d3dd8ae0bf6.tar.xz
qemu-a78a1a48cd1a2e86f23f113bb05e2d3dd8ae0bf6.zip
dirty-bitmap: add bdrv_dirty_bitmap_next_dirty_area
The function alters bdrv_dirty_iter_next_area(), which is wrong and less efficient (see further commit "block/mirror: fix and improve do_sync_target_write" for description). Signed-off-by: Vladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
Diffstat (limited to 'block')
-rw-r--r--block/dirty-bitmap.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/block/dirty-bitmap.c b/block/dirty-bitmap.c
index b162f4ac22..c1518373f9 100644
--- a/block/dirty-bitmap.c
+++ b/block/dirty-bitmap.c
@@ -787,6 +787,12 @@ int64_t bdrv_dirty_bitmap_next_zero(BdrvDirtyBitmap *bitmap, uint64_t offset,
return hbitmap_next_zero(bitmap->bitmap, offset, bytes);
}
+bool bdrv_dirty_bitmap_next_dirty_area(BdrvDirtyBitmap *bitmap,
+ uint64_t *offset, uint64_t *bytes)
+{
+ return hbitmap_next_dirty_area(bitmap->bitmap, offset, bytes);
+}
+
void bdrv_merge_dirty_bitmap(BdrvDirtyBitmap *dest, const BdrvDirtyBitmap *src,
HBitmap **backup, Error **errp)
{