提交 8515efbe 编写于 作者: J John Snow 提交者: Kevin Wolf

hbitmap: cache array lengths

As a convenience: between incremental backups, bitmap migrations
and bitmap persistence we seem to need to recalculate these a lot.

Because the lengths are a little bit-twiddly, let's just solidly
cache them and be done with it.
Reviewed-by: NMax Reitz <mreitz@redhat.com>
Reviewed-by: NEric Blake <eblake@redhat.com>
Signed-off-by: NJohn Snow <jsnow@redhat.com>
Reviewed-by: NStefan Hajnoczi <stefanha@redhat.com>
Message-id: 1429314609-29776-7-git-send-email-jsnow@redhat.com
Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
Signed-off-by: NKevin Wolf <kwolf@redhat.com>
上级 592fdd02
...@@ -90,6 +90,9 @@ struct HBitmap { ...@@ -90,6 +90,9 @@ struct HBitmap {
* bitmap will still allocate HBITMAP_LEVELS arrays. * bitmap will still allocate HBITMAP_LEVELS arrays.
*/ */
unsigned long *levels[HBITMAP_LEVELS]; unsigned long *levels[HBITMAP_LEVELS];
/* The length of each levels[] array. */
uint64_t sizes[HBITMAP_LEVELS];
}; };
/* Advance hbi to the next nonzero word and return it. hbi->pos /* Advance hbi to the next nonzero word and return it. hbi->pos
...@@ -384,6 +387,7 @@ HBitmap *hbitmap_alloc(uint64_t size, int granularity) ...@@ -384,6 +387,7 @@ HBitmap *hbitmap_alloc(uint64_t size, int granularity)
hb->granularity = granularity; hb->granularity = granularity;
for (i = HBITMAP_LEVELS; i-- > 0; ) { for (i = HBITMAP_LEVELS; i-- > 0; ) {
size = MAX((size + BITS_PER_LONG - 1) >> BITS_PER_LEVEL, 1); size = MAX((size + BITS_PER_LONG - 1) >> BITS_PER_LEVEL, 1);
hb->sizes[i] = size;
hb->levels[i] = g_new0(unsigned long, size); hb->levels[i] = g_new0(unsigned long, size);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册