[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v14 04/19] block: Introduce bdrv_dirty_bitmap_granul
From: |
John Snow |
Subject: |
[Qemu-devel] [PATCH v14 04/19] block: Introduce bdrv_dirty_bitmap_granularity() |
Date: |
Fri, 20 Feb 2015 18:07:10 -0500 |
This returns the granularity (in bytes) of dirty bitmap,
which matches the QMP interface and the existing query
interface.
Signed-off-by: John Snow <address@hidden>
Reviewed-by: Max Reitz <address@hidden>
---
block.c | 8 ++++++--
include/block/block.h | 1 +
2 files changed, 7 insertions(+), 2 deletions(-)
diff --git a/block.c b/block.c
index 60dbdbd..8b40e38 100644
--- a/block.c
+++ b/block.c
@@ -5440,8 +5440,7 @@ BlockDirtyInfoList
*bdrv_query_dirty_bitmaps(BlockDriverState *bs)
BlockDirtyInfo *info = g_new0(BlockDirtyInfo, 1);
BlockDirtyInfoList *entry = g_new0(BlockDirtyInfoList, 1);
info->count = bdrv_get_dirty_count(bs, bm);
- info->granularity =
- ((uint32_t) BDRV_SECTOR_SIZE << hbitmap_granularity(bm->bitmap));
+ info->granularity = bdrv_dirty_bitmap_granularity(bm);
info->has_name = !!bm->name;
info->name = g_strdup(bm->name);
entry->value = info;
@@ -5481,6 +5480,11 @@ uint32_t
bdrv_get_default_bitmap_granularity(BlockDriverState *bs)
return granularity;
}
+uint32_t bdrv_dirty_bitmap_granularity(BdrvDirtyBitmap *bitmap)
+{
+ return BDRV_SECTOR_SIZE << hbitmap_granularity(bitmap->bitmap);
+}
+
void bdrv_dirty_iter_init(BlockDriverState *bs,
BdrvDirtyBitmap *bitmap, HBitmapIter *hbi)
{
diff --git a/include/block/block.h b/include/block/block.h
index 3589132..41b8418 100644
--- a/include/block/block.h
+++ b/include/block/block.h
@@ -448,6 +448,7 @@ void bdrv_dirty_bitmap_make_anon(BlockDriverState *bs,
BdrvDirtyBitmap *bitmap);
void bdrv_release_dirty_bitmap(BlockDriverState *bs, BdrvDirtyBitmap *bitmap);
BlockDirtyInfoList *bdrv_query_dirty_bitmaps(BlockDriverState *bs);
uint32_t bdrv_get_default_bitmap_granularity(BlockDriverState *bs);
+uint32_t bdrv_dirty_bitmap_granularity(BdrvDirtyBitmap *bitmap);
int bdrv_get_dirty(BlockDriverState *bs, BdrvDirtyBitmap *bitmap, int64_t
sector);
void bdrv_set_dirty_bitmap(BlockDriverState *bs, BdrvDirtyBitmap *bitmap,
int64_t cur_sector, int nr_sectors);
--
1.9.3
- [Qemu-devel] [PATCH v14 00/19] block: incremental backup series, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 02/19] qmp: Ensure consistent granularity type, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 04/19] block: Introduce bdrv_dirty_bitmap_granularity(),
John Snow <=
- [Qemu-devel] [PATCH v14 05/19] hbitmap: add hbitmap_merge, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 01/19] qapi: Add optional field "name" to block dirty bitmap, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 06/19] qmp: Add block-dirty-bitmap-enable and block-dirty-bitmap-disable, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 03/19] qmp: Add block-dirty-bitmap-add and block-dirty-bitmap-remove, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 07/19] block: Add bitmap successors, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 13/19] block: Ensure consistent bitmap function prototypes, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 09/19] qmp: add block-dirty-bitmap-clear, John Snow, 2015/02/20
- [Qemu-devel] [PATCH v14 14/19] iotests: add invalid input incremental backup tests, John Snow, 2015/02/20