mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-23 02:04:16 +03:00
virBitmapNewCopy: Honor sizes of either bitmap when doing memcpy()
'virBitmapNewCopy()' allocates a new bitmap with the same number of bits but uses the internal allocation length as argument for the memcpy() operation to copy the bits. Due to bugs in other code these may not be the same resulting into a buffer overflow if the source is over-allocated. Use the buffer length of the target bitmap instead. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
This commit is contained in:
parent
99acc29557
commit
cfe638ef80
@ -582,7 +582,7 @@ virBitmapNewCopy(virBitmap *src)
|
|||||||
{
|
{
|
||||||
virBitmap *dst = virBitmapNew(src->nbits);
|
virBitmap *dst = virBitmapNew(src->nbits);
|
||||||
|
|
||||||
memcpy(dst->map, src->map, src->map_len * sizeof(src->map[0]));
|
memcpy(dst->map, src->map, dst->map_len * sizeof(src->map[0]));
|
||||||
|
|
||||||
return dst;
|
return dst;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user