On Thu, 03/20 11:22, Paolo Bonzini wrote:
> Il 12/03/2014 07:31, Fam Zheng ha scritto:
> >+HBitmap *hbitmap_copy(const HBitmap *bitmap)
> >+{
> >+ int i;
> >+ HBitmap *hb = g_memdup(bitmap, sizeof(struct HBitmap));
> >+
> >+ for (i = HBITMAP_LEVELS; i-- > 0; ) {
> >+ hb->levels[i] = g_memdup(bitmap->levels[i],
> >+ bitmap->size * sizeof(unsigned long));
> >+ }
> >+
> >+ return hb;
>
> Not quite... the bitmap->size is in bits, so you need to scale it down by
>
> size = MAX((size + BITS_PER_LONG - 1) >> BITS_PER_LEVEL, 1);
>
> before each memdup.
>
This is fixed in V3 which is posted on the list.
Thanks,
Fam