mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-24 06:03:52 +03:00
cmdDomBlkError: Fix crash when initial call to virDomainGetDiskErrors fails
virDomainGetDiskErrors uses the weird semantics where we make the caller query for the number of elements and then pass pre-allocated structure. The cleanup section errorneously used the 'count' variable to free the allocated elements for the API but 'count' can be '-1' in cases when the API returns failure, thus attempting to free beyond the end of the array. Resolves: https://gitlab.com/libvirt/libvirt/-/issues/155 Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Pavel Hrdina <phrdina@redhat.com>
This commit is contained in:
parent
ac87f612ba
commit
c2558e78d4
@ -1220,7 +1220,7 @@ cmdDomBlkError(vshControl *ctl, const vshCmd *cmd)
|
|||||||
{
|
{
|
||||||
virDomainPtr dom;
|
virDomainPtr dom;
|
||||||
virDomainDiskErrorPtr disks = NULL;
|
virDomainDiskErrorPtr disks = NULL;
|
||||||
unsigned int ndisks;
|
unsigned int ndisks = 0;
|
||||||
size_t i;
|
size_t i;
|
||||||
int count;
|
int count;
|
||||||
bool ret = false;
|
bool ret = false;
|
||||||
@ -1230,10 +1230,10 @@ cmdDomBlkError(vshControl *ctl, const vshCmd *cmd)
|
|||||||
|
|
||||||
if ((count = virDomainGetDiskErrors(dom, NULL, 0, 0)) < 0)
|
if ((count = virDomainGetDiskErrors(dom, NULL, 0, 0)) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
ndisks = count;
|
|
||||||
|
|
||||||
if (ndisks) {
|
if (count > 0) {
|
||||||
disks = g_new0(virDomainDiskError, ndisks);
|
disks = g_new0(virDomainDiskError, count);
|
||||||
|
ndisks = count;
|
||||||
|
|
||||||
if ((count = virDomainGetDiskErrors(dom, disks, ndisks, 0)) == -1)
|
if ((count = virDomainGetDiskErrors(dom, disks, ndisks, 0)) == -1)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
@ -1252,7 +1252,7 @@ cmdDomBlkError(vshControl *ctl, const vshCmd *cmd)
|
|||||||
ret = true;
|
ret = true;
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
for (i = 0; i < count; i++)
|
for (i = 0; i < ndisks; i++)
|
||||||
VIR_FREE(disks[i].disk);
|
VIR_FREE(disks[i].disk);
|
||||||
VIR_FREE(disks);
|
VIR_FREE(disks);
|
||||||
virshDomainFree(dom);
|
virshDomainFree(dom);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user