mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-11 07:17:44 +00:00
conf: Utilize more of VIR_(APPEND|INSERT|DELETE)_ELEMENT
This fixes a possible double free. In virNetworkAssignDef() if virBitmapNew() fails, then virNetworkObjFree(network) is called. However, with network->def pointing to actual @def. So if caller frees @def again, ... Moreover, this fixes one possible memory leak too. In virInterfaceAssignDef() if appending to the list of interfaces fails, we ought to call virInterfaceObjFree() instead of bare VIR_FREE(). Although, in order to do that some array size variables needs to be turned into size_t rather than int. Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
925de19ed7
commit
2133441a07
@ -10216,17 +10216,9 @@ void virDomainDiskInsertPreAlloced(virDomainDefPtr def,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* No disks with this bus yet, so put at end of list */
|
/* VIR_INSERT_ELEMENT_INPLACE will never return an error here. */
|
||||||
if (insertAt == -1)
|
ignore_value(VIR_INSERT_ELEMENT_INPLACE(def->disks, insertAt,
|
||||||
insertAt = def->ndisks;
|
def->ndisks, disk));
|
||||||
|
|
||||||
if (insertAt < def->ndisks)
|
|
||||||
memmove(def->disks + insertAt + 1,
|
|
||||||
def->disks + insertAt,
|
|
||||||
(sizeof(def->disks[0]) * (def->ndisks-insertAt)));
|
|
||||||
|
|
||||||
def->disks[insertAt] = disk;
|
|
||||||
def->ndisks++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -10235,19 +10227,7 @@ virDomainDiskRemove(virDomainDefPtr def, size_t i)
|
|||||||
{
|
{
|
||||||
virDomainDiskDefPtr disk = def->disks[i];
|
virDomainDiskDefPtr disk = def->disks[i];
|
||||||
|
|
||||||
if (def->ndisks > 1) {
|
VIR_DELETE_ELEMENT(def->disks, i, def->ndisks);
|
||||||
memmove(def->disks + i,
|
|
||||||
def->disks + i + 1,
|
|
||||||
sizeof(*def->disks) *
|
|
||||||
(def->ndisks - (i + 1)));
|
|
||||||
def->ndisks--;
|
|
||||||
if (VIR_REALLOC_N(def->disks, def->ndisks) < 0) {
|
|
||||||
/* ignore, harmless */
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
VIR_FREE(def->disks);
|
|
||||||
def->ndisks = 0;
|
|
||||||
}
|
|
||||||
return disk;
|
return disk;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -10274,13 +10254,17 @@ virDomainHasDiskMirror(virDomainObjPtr vm)
|
|||||||
|
|
||||||
int virDomainNetInsert(virDomainDefPtr def, virDomainNetDefPtr net)
|
int virDomainNetInsert(virDomainDefPtr def, virDomainNetDefPtr net)
|
||||||
{
|
{
|
||||||
if (VIR_REALLOC_N(def->nets, def->nnets + 1) < 0)
|
/* hostdev net devices must also exist in the hostdevs array */
|
||||||
|
if (net->type == VIR_DOMAIN_NET_TYPE_HOSTDEV &&
|
||||||
|
virDomainHostdevInsert(def, &net->data.hostdev.def) < 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
if (VIR_APPEND_ELEMENT(def->nets, def->nnets, net) < 0) {
|
||||||
|
/* virDomainHostdevInsert just appends new hostdevs, so we are sure
|
||||||
|
* that the hostdev we've added a few lines above is at the end of
|
||||||
|
* array. Although, devices are indexed from zero ... */
|
||||||
|
virDomainHostdevRemove(def, def->nhostdevs - 1);
|
||||||
return -1;
|
return -1;
|
||||||
def->nets[def->nnets] = net;
|
|
||||||
def->nnets++;
|
|
||||||
if (net->type == VIR_DOMAIN_NET_TYPE_HOSTDEV) {
|
|
||||||
/* hostdev net devices must also exist in the hostdevs array */
|
|
||||||
return virDomainHostdevInsert(def, &net->data.hostdev.def);
|
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -10360,19 +10344,7 @@ virDomainNetRemove(virDomainDefPtr def, size_t i)
|
|||||||
virDomainNetDefPtr net = def->nets[i];
|
virDomainNetDefPtr net = def->nets[i];
|
||||||
|
|
||||||
virDomainNetRemoveHostdev(def, net);
|
virDomainNetRemoveHostdev(def, net);
|
||||||
|
VIR_DELETE_ELEMENT(def->nets, i, def->nnets);
|
||||||
if (def->nnets > 1) {
|
|
||||||
memmove(def->nets + i,
|
|
||||||
def->nets + i + 1,
|
|
||||||
sizeof(*def->nets) * (def->nnets - (i + 1)));
|
|
||||||
def->nnets--;
|
|
||||||
if (VIR_REALLOC_N(def->nets, def->nnets) < 0) {
|
|
||||||
/* ignore harmless */
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
VIR_FREE(def->nets);
|
|
||||||
def->nnets = 0;
|
|
||||||
}
|
|
||||||
return net;
|
return net;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -10415,17 +10387,9 @@ void virDomainControllerInsertPreAlloced(virDomainDefPtr def,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* No controllers with this bus yet, so put at end of list */
|
/* VIR_INSERT_ELEMENT_INPLACE will never return an error here. */
|
||||||
if (insertAt == -1)
|
ignore_value(VIR_INSERT_ELEMENT_INPLACE(def->controllers, insertAt,
|
||||||
insertAt = def->ncontrollers;
|
def->ncontrollers, controller));
|
||||||
|
|
||||||
if (insertAt < def->ncontrollers)
|
|
||||||
memmove(def->controllers + insertAt + 1,
|
|
||||||
def->controllers + insertAt,
|
|
||||||
(sizeof(def->controllers[0]) * (def->ncontrollers-insertAt)));
|
|
||||||
|
|
||||||
def->controllers[insertAt] = controller;
|
|
||||||
def->ncontrollers++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
@ -10449,20 +10413,7 @@ virDomainControllerRemove(virDomainDefPtr def, size_t i)
|
|||||||
{
|
{
|
||||||
virDomainControllerDefPtr controller = def->controllers[i];
|
virDomainControllerDefPtr controller = def->controllers[i];
|
||||||
|
|
||||||
if (def->ncontrollers > 1) {
|
VIR_DELETE_ELEMENT(def->controllers, i, def->ncontrollers);
|
||||||
memmove(def->controllers + i,
|
|
||||||
def->controllers + i + 1,
|
|
||||||
sizeof(*def->controllers) *
|
|
||||||
(def->ncontrollers - (i + 1)));
|
|
||||||
def->ncontrollers--;
|
|
||||||
if (VIR_REALLOC_N(def->controllers, def->ncontrollers) < 0) {
|
|
||||||
/* ignore, harmless */
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
VIR_FREE(def->controllers);
|
|
||||||
def->ncontrollers = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return controller;
|
return controller;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -10520,16 +10471,7 @@ virDomainLeaseRemoveAt(virDomainDefPtr def, size_t i)
|
|||||||
|
|
||||||
virDomainLeaseDefPtr lease = def->leases[i];
|
virDomainLeaseDefPtr lease = def->leases[i];
|
||||||
|
|
||||||
if (def->nleases > 1) {
|
VIR_DELETE_ELEMENT(def->leases, i, def->nleases);
|
||||||
memmove(def->leases + i,
|
|
||||||
def->leases + i + 1,
|
|
||||||
sizeof(*def->leases) *
|
|
||||||
(def->nleases - (i + 1)));
|
|
||||||
VIR_SHRINK_N(def->leases, def->nleases, 1);
|
|
||||||
} else {
|
|
||||||
VIR_FREE(def->leases);
|
|
||||||
def->nleases = 0;
|
|
||||||
}
|
|
||||||
return lease;
|
return lease;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -14451,7 +14393,7 @@ virDomainVcpuPinFindByVcpu(virDomainVcpuPinDefPtr *def,
|
|||||||
|
|
||||||
int
|
int
|
||||||
virDomainVcpuPinAdd(virDomainVcpuPinDefPtr **vcpupin_list,
|
virDomainVcpuPinAdd(virDomainVcpuPinDefPtr **vcpupin_list,
|
||||||
int *nvcpupin,
|
size_t *nvcpupin,
|
||||||
unsigned char *cpumap,
|
unsigned char *cpumap,
|
||||||
int maplen,
|
int maplen,
|
||||||
int vcpu)
|
int vcpu)
|
||||||
@ -14484,11 +14426,9 @@ virDomainVcpuPinAdd(virDomainVcpuPinDefPtr **vcpupin_list,
|
|||||||
if (!vcpupin->cpumask)
|
if (!vcpupin->cpumask)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
if (VIR_REALLOC_N(*vcpupin_list, *nvcpupin + 1) < 0)
|
if (VIR_APPEND_ELEMENT(*vcpupin_list, *nvcpupin, vcpupin) < 0)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
(*vcpupin_list)[(*nvcpupin)++] = vcpupin;
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
@ -14500,7 +14440,6 @@ int
|
|||||||
virDomainVcpuPinDel(virDomainDefPtr def, int vcpu)
|
virDomainVcpuPinDel(virDomainDefPtr def, int vcpu)
|
||||||
{
|
{
|
||||||
int n;
|
int n;
|
||||||
bool deleted = false;
|
|
||||||
virDomainVcpuPinDefPtr *vcpupin_list = def->cputune.vcpupin;
|
virDomainVcpuPinDefPtr *vcpupin_list = def->cputune.vcpupin;
|
||||||
|
|
||||||
/* No vcpupin exists yet */
|
/* No vcpupin exists yet */
|
||||||
@ -14512,24 +14451,11 @@ virDomainVcpuPinDel(virDomainDefPtr def, int vcpu)
|
|||||||
if (vcpupin_list[n]->vcpuid == vcpu) {
|
if (vcpupin_list[n]->vcpuid == vcpu) {
|
||||||
virBitmapFree(vcpupin_list[n]->cpumask);
|
virBitmapFree(vcpupin_list[n]->cpumask);
|
||||||
VIR_FREE(vcpupin_list[n]);
|
VIR_FREE(vcpupin_list[n]);
|
||||||
memmove(&vcpupin_list[n],
|
VIR_DELETE_ELEMENT(vcpupin_list, n, def->cputune.nvcpupin);
|
||||||
&vcpupin_list[n+1],
|
|
||||||
(def->cputune.nvcpupin - n - 1) * sizeof(virDomainVcpuPinDef *));
|
|
||||||
deleted = true;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!deleted)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
if (--def->cputune.nvcpupin == 0) {
|
|
||||||
VIR_FREE(def->cputune.vcpupin);
|
|
||||||
} else {
|
|
||||||
if (VIR_REALLOC_N(def->cputune.vcpupin, def->cputune.nvcpupin) < 0)
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2003,7 +2003,7 @@ struct _virDomainDef {
|
|||||||
long long quota;
|
long long quota;
|
||||||
unsigned long long emulator_period;
|
unsigned long long emulator_period;
|
||||||
long long emulator_quota;
|
long long emulator_quota;
|
||||||
int nvcpupin;
|
size_t nvcpupin;
|
||||||
virDomainVcpuPinDefPtr *vcpupin;
|
virDomainVcpuPinDefPtr *vcpupin;
|
||||||
virDomainVcpuPinDefPtr emulatorpin;
|
virDomainVcpuPinDefPtr emulatorpin;
|
||||||
} cputune;
|
} cputune;
|
||||||
@ -2410,7 +2410,7 @@ int virDomainDefCompatibleDevice(virDomainDefPtr def,
|
|||||||
virDomainDeviceDefPtr dev);
|
virDomainDeviceDefPtr dev);
|
||||||
|
|
||||||
int virDomainVcpuPinAdd(virDomainVcpuPinDefPtr **vcpupin_list,
|
int virDomainVcpuPinAdd(virDomainVcpuPinDefPtr **vcpupin_list,
|
||||||
int *nvcpupin,
|
size_t *nvcpupin,
|
||||||
unsigned char *cpumap,
|
unsigned char *cpumap,
|
||||||
int maplen,
|
int maplen,
|
||||||
int vcpu);
|
int vcpu);
|
||||||
|
@ -1266,16 +1266,14 @@ virInterfaceObjPtr virInterfaceAssignDef(virInterfaceObjListPtr interfaces,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
virInterfaceObjLock(iface);
|
virInterfaceObjLock(iface);
|
||||||
iface->def = def;
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(interfaces->objs, interfaces->count + 1) < 0) {
|
if (VIR_APPEND_ELEMENT_COPY(interfaces->objs,
|
||||||
VIR_FREE(iface);
|
interfaces->count, iface) < 0) {
|
||||||
|
virInterfaceObjFree(iface);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
interfaces->objs[interfaces->count] = iface;
|
iface->def = def;
|
||||||
interfaces->count++;
|
|
||||||
|
|
||||||
return iface;
|
return iface;
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -1292,15 +1290,7 @@ void virInterfaceRemove(virInterfaceObjListPtr interfaces,
|
|||||||
virInterfaceObjUnlock(interfaces->objs[i]);
|
virInterfaceObjUnlock(interfaces->objs[i]);
|
||||||
virInterfaceObjFree(interfaces->objs[i]);
|
virInterfaceObjFree(interfaces->objs[i]);
|
||||||
|
|
||||||
if (i < (interfaces->count - 1))
|
VIR_DELETE_ELEMENT(interfaces->objs, i, interfaces->count);
|
||||||
memmove(interfaces->objs + i, interfaces->objs + i + 1,
|
|
||||||
sizeof(*(interfaces->objs)) * (interfaces->count - (i + 1)));
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(interfaces->objs, interfaces->count - 1) < 0) {
|
|
||||||
; /* Failure to reduce memory allocation isn't fatal */
|
|
||||||
}
|
|
||||||
interfaces->count--;
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
virInterfaceObjUnlock(interfaces->objs[i]);
|
virInterfaceObjUnlock(interfaces->objs[i]);
|
||||||
|
@ -171,7 +171,7 @@ struct _virInterfaceObj {
|
|||||||
typedef struct _virInterfaceObjList virInterfaceObjList;
|
typedef struct _virInterfaceObjList virInterfaceObjList;
|
||||||
typedef virInterfaceObjList *virInterfaceObjListPtr;
|
typedef virInterfaceObjList *virInterfaceObjListPtr;
|
||||||
struct _virInterfaceObjList {
|
struct _virInterfaceObjList {
|
||||||
unsigned int count;
|
size_t count;
|
||||||
virInterfaceObjPtr *objs;
|
virInterfaceObjPtr *objs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -372,9 +372,6 @@ virNetworkAssignDef(virNetworkObjListPtr nets,
|
|||||||
return network;
|
return network;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (VIR_REALLOC_N(nets->objs, nets->count + 1) < 0)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
if (VIR_ALLOC(network) < 0)
|
if (VIR_ALLOC(network) < 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
if (virMutexInit(&network->lock) < 0) {
|
if (virMutexInit(&network->lock) < 0) {
|
||||||
@ -384,9 +381,9 @@ virNetworkAssignDef(virNetworkObjListPtr nets,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
virNetworkObjLock(network);
|
virNetworkObjLock(network);
|
||||||
network->def = def;
|
|
||||||
|
|
||||||
if (!(network->class_id = virBitmapNew(CLASS_ID_BITMAP_SIZE)))
|
if (VIR_APPEND_ELEMENT_COPY(nets->objs, nets->count, network) < 0 ||
|
||||||
|
!(network->class_id = virBitmapNew(CLASS_ID_BITMAP_SIZE)))
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
/* The first three class IDs are already taken */
|
/* The first three class IDs are already taken */
|
||||||
@ -395,8 +392,6 @@ virNetworkAssignDef(virNetworkObjListPtr nets,
|
|||||||
ignore_value(virBitmapSetBit(network->class_id, 2));
|
ignore_value(virBitmapSetBit(network->class_id, 2));
|
||||||
|
|
||||||
network->def = def;
|
network->def = def;
|
||||||
nets->objs[nets->count] = network;
|
|
||||||
nets->count++;
|
|
||||||
|
|
||||||
return network;
|
return network;
|
||||||
error:
|
error:
|
||||||
@ -576,15 +571,7 @@ void virNetworkRemoveInactive(virNetworkObjListPtr nets,
|
|||||||
virNetworkObjUnlock(nets->objs[i]);
|
virNetworkObjUnlock(nets->objs[i]);
|
||||||
virNetworkObjFree(nets->objs[i]);
|
virNetworkObjFree(nets->objs[i]);
|
||||||
|
|
||||||
if (i < (nets->count - 1))
|
VIR_DELETE_ELEMENT(nets->objs, i, nets->count);
|
||||||
memmove(nets->objs + i, nets->objs + i + 1,
|
|
||||||
sizeof(*(nets->objs)) * (nets->count - (i + 1)));
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(nets->objs, nets->count - 1) < 0) {
|
|
||||||
; /* Failure to reduce memory allocation isn't fatal */
|
|
||||||
}
|
|
||||||
nets->count--;
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
virNetworkObjUnlock(nets->objs[i]);
|
virNetworkObjUnlock(nets->objs[i]);
|
||||||
@ -900,13 +887,17 @@ virNetworkDNSHostDefParseXML(const char *networkName,
|
|||||||
if (cur->type == XML_ELEMENT_NODE &&
|
if (cur->type == XML_ELEMENT_NODE &&
|
||||||
xmlStrEqual(cur->name, BAD_CAST "hostname")) {
|
xmlStrEqual(cur->name, BAD_CAST "hostname")) {
|
||||||
if (cur->children != NULL) {
|
if (cur->children != NULL) {
|
||||||
if (VIR_REALLOC_N(def->names, def->nnames + 1) < 0)
|
char *name = (char *) xmlNodeGetContent(cur);
|
||||||
goto error;
|
|
||||||
def->names[def->nnames++] = (char *)xmlNodeGetContent(cur);
|
if (!name) {
|
||||||
if (!def->names[def->nnames - 1]) {
|
|
||||||
virReportError(VIR_ERR_XML_DETAIL,
|
virReportError(VIR_ERR_XML_DETAIL,
|
||||||
_("Missing hostname in network '%s' DNS HOST record"),
|
_("Missing hostname in network '%s' DNS HOST record"),
|
||||||
networkName);
|
networkName);
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
if (VIR_APPEND_ELEMENT(def->names, def->nnames, name) < 0) {
|
||||||
|
VIR_FREE(name);
|
||||||
|
goto error;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -108,7 +108,7 @@ typedef struct _virNetworkDNSHostDef virNetworkDNSHostDef;
|
|||||||
typedef virNetworkDNSHostDef *virNetworkDNSHostDefPtr;
|
typedef virNetworkDNSHostDef *virNetworkDNSHostDefPtr;
|
||||||
struct _virNetworkDNSHostDef {
|
struct _virNetworkDNSHostDef {
|
||||||
virSocketAddr ip;
|
virSocketAddr ip;
|
||||||
int nnames;
|
size_t nnames;
|
||||||
char **names;
|
char **names;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -294,7 +294,7 @@ struct _virNetworkObj {
|
|||||||
typedef struct _virNetworkObjList virNetworkObjList;
|
typedef struct _virNetworkObjList virNetworkObjList;
|
||||||
typedef virNetworkObjList *virNetworkObjListPtr;
|
typedef virNetworkObjList *virNetworkObjListPtr;
|
||||||
struct _virNetworkObjList {
|
struct _virNetworkObjList {
|
||||||
unsigned int count;
|
size_t count;
|
||||||
virNetworkObjPtr *objs;
|
virNetworkObjPtr *objs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -186,15 +186,13 @@ virNodeDeviceObjPtr virNodeDeviceAssignDef(virNodeDeviceObjListPtr devs,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
virNodeDeviceObjLock(device);
|
virNodeDeviceObjLock(device);
|
||||||
device->def = def;
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(devs->objs, devs->count+1) < 0) {
|
if (VIR_APPEND_ELEMENT_COPY(devs->objs, devs->count, device) < 0){
|
||||||
device->def = NULL;
|
|
||||||
virNodeDeviceObjUnlock(device);
|
virNodeDeviceObjUnlock(device);
|
||||||
virNodeDeviceObjFree(device);
|
virNodeDeviceObjFree(device);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
devs->objs[devs->count++] = device;
|
device->def = def;
|
||||||
|
|
||||||
return device;
|
return device;
|
||||||
|
|
||||||
@ -213,15 +211,7 @@ void virNodeDeviceObjRemove(virNodeDeviceObjListPtr devs,
|
|||||||
virNodeDeviceObjUnlock(dev);
|
virNodeDeviceObjUnlock(dev);
|
||||||
virNodeDeviceObjFree(devs->objs[i]);
|
virNodeDeviceObjFree(devs->objs[i]);
|
||||||
|
|
||||||
if (i < (devs->count - 1))
|
VIR_DELETE_ELEMENT(devs->objs, i, devs->count);
|
||||||
memmove(devs->objs + i, devs->objs + i + 1,
|
|
||||||
sizeof(*(devs->objs)) * (devs->count - (i + 1)));
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(devs->objs, devs->count - 1) < 0) {
|
|
||||||
; /* Failure to reduce memory allocation isn't fatal */
|
|
||||||
}
|
|
||||||
devs->count--;
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
virNodeDeviceObjUnlock(dev);
|
virNodeDeviceObjUnlock(dev);
|
||||||
|
@ -204,7 +204,7 @@ struct _virNodeDeviceObj {
|
|||||||
typedef struct _virNodeDeviceObjList virNodeDeviceObjList;
|
typedef struct _virNodeDeviceObjList virNodeDeviceObjList;
|
||||||
typedef virNodeDeviceObjList *virNodeDeviceObjListPtr;
|
typedef virNodeDeviceObjList *virNodeDeviceObjListPtr;
|
||||||
struct _virNodeDeviceObjList {
|
struct _virNodeDeviceObjList {
|
||||||
unsigned int count;
|
size_t count;
|
||||||
virNodeDeviceObjPtr *objs;
|
virNodeDeviceObjPtr *objs;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -399,15 +399,13 @@ virNWFilterRuleDefAddString(virNWFilterRuleDefPtr nwf,
|
|||||||
const char *string,
|
const char *string,
|
||||||
size_t maxstrlen)
|
size_t maxstrlen)
|
||||||
{
|
{
|
||||||
if (VIR_REALLOC_N(nwf->strings, nwf->nstrings+1) < 0)
|
char *tmp;
|
||||||
return NULL;
|
|
||||||
|
|
||||||
if (VIR_STRNDUP(nwf->strings[nwf->nstrings], string, maxstrlen) < 0)
|
if (VIR_STRNDUP(tmp, string, maxstrlen) < 0 ||
|
||||||
return NULL;
|
VIR_APPEND_ELEMENT_COPY(nwf->strings, nwf->nstrings, tmp) < 0)
|
||||||
|
VIR_FREE(tmp);
|
||||||
|
|
||||||
nwf->nstrings++;
|
return tmp;
|
||||||
|
|
||||||
return nwf->strings[nwf->nstrings-1];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -425,15 +423,7 @@ virNWFilterObjRemove(virNWFilterObjListPtr nwfilters,
|
|||||||
virNWFilterObjUnlock(nwfilters->objs[i]);
|
virNWFilterObjUnlock(nwfilters->objs[i]);
|
||||||
virNWFilterObjFree(nwfilters->objs[i]);
|
virNWFilterObjFree(nwfilters->objs[i]);
|
||||||
|
|
||||||
if (i < (nwfilters->count - 1))
|
VIR_DELETE_ELEMENT(nwfilters->objs, i, nwfilters->count);
|
||||||
memmove(nwfilters->objs + i, nwfilters->objs + i + 1,
|
|
||||||
sizeof(*(nwfilters->objs)) * (nwfilters->count - (i + 1)));
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(nwfilters->objs, nwfilters->count - 1) < 0) {
|
|
||||||
; /* Failure to reduce memory allocation isn't fatal */
|
|
||||||
}
|
|
||||||
nwfilters->count--;
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
virNWFilterObjUnlock(nwfilters->objs[i]);
|
virNWFilterObjUnlock(nwfilters->objs[i]);
|
||||||
@ -2593,11 +2583,11 @@ virNWFilterDefParseXML(xmlXPathContextPtr ctxt) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (entry->rule || entry->include) {
|
if (entry->rule || entry->include) {
|
||||||
if (VIR_REALLOC_N(ret->filterEntries, ret->nentries+1) < 0) {
|
if (VIR_APPEND_ELEMENT_COPY(ret->filterEntries,
|
||||||
|
ret->nentries, entry) < 0) {
|
||||||
virNWFilterEntryFree(entry);
|
virNWFilterEntryFree(entry);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
ret->filterEntries[ret->nentries++] = entry;
|
|
||||||
} else
|
} else
|
||||||
virNWFilterEntryFree(entry);
|
virNWFilterEntryFree(entry);
|
||||||
}
|
}
|
||||||
@ -3029,15 +3019,14 @@ virNWFilterObjAssignDef(virNWFilterObjListPtr nwfilters,
|
|||||||
}
|
}
|
||||||
virNWFilterObjLock(nwfilter);
|
virNWFilterObjLock(nwfilter);
|
||||||
nwfilter->active = 0;
|
nwfilter->active = 0;
|
||||||
nwfilter->def = def;
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(nwfilters->objs, nwfilters->count + 1) < 0) {
|
if (VIR_APPEND_ELEMENT_COPY(nwfilters->objs,
|
||||||
nwfilter->def = NULL;
|
nwfilters->count, nwfilter) < 0) {
|
||||||
virNWFilterObjUnlock(nwfilter);
|
virNWFilterObjUnlock(nwfilter);
|
||||||
virNWFilterObjFree(nwfilter);
|
virNWFilterObjFree(nwfilter);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
nwfilters->objs[nwfilters->count++] = nwfilter;
|
nwfilter->def = def;
|
||||||
|
|
||||||
return nwfilter;
|
return nwfilter;
|
||||||
}
|
}
|
||||||
|
@ -476,7 +476,7 @@ struct _virNWFilterRuleDef {
|
|||||||
size_t nVarAccess;
|
size_t nVarAccess;
|
||||||
virNWFilterVarAccessPtr *varAccess;
|
virNWFilterVarAccessPtr *varAccess;
|
||||||
|
|
||||||
int nstrings;
|
size_t nstrings;
|
||||||
char **strings;
|
char **strings;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -524,7 +524,7 @@ struct _virNWFilterDef {
|
|||||||
char *chainsuffix;
|
char *chainsuffix;
|
||||||
virNWFilterChainPriority chainPriority;
|
virNWFilterChainPriority chainPriority;
|
||||||
|
|
||||||
int nentries;
|
size_t nentries;
|
||||||
virNWFilterEntryPtr *filterEntries;
|
virNWFilterEntryPtr *filterEntries;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -547,7 +547,7 @@ struct _virNWFilterObj {
|
|||||||
typedef struct _virNWFilterObjList virNWFilterObjList;
|
typedef struct _virNWFilterObjList virNWFilterObjList;
|
||||||
typedef virNWFilterObjList *virNWFilterObjListPtr;
|
typedef virNWFilterObjList *virNWFilterObjListPtr;
|
||||||
struct _virNWFilterObjList {
|
struct _virNWFilterObjList {
|
||||||
unsigned int count;
|
size_t count;
|
||||||
virNWFilterObjPtr *objs;
|
virNWFilterObjPtr *objs;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -572,7 +572,7 @@ typedef virNWFilterTechDriver *virNWFilterTechDriverPtr;
|
|||||||
typedef struct _virNWFilterRuleInst virNWFilterRuleInst;
|
typedef struct _virNWFilterRuleInst virNWFilterRuleInst;
|
||||||
typedef virNWFilterRuleInst *virNWFilterRuleInstPtr;
|
typedef virNWFilterRuleInst *virNWFilterRuleInstPtr;
|
||||||
struct _virNWFilterRuleInst {
|
struct _virNWFilterRuleInst {
|
||||||
int ndata;
|
size_t ndata;
|
||||||
void **data;
|
void **data;
|
||||||
virNWFilterTechDriverPtr techdriver;
|
virNWFilterTechDriverPtr techdriver;
|
||||||
};
|
};
|
||||||
|
@ -256,13 +256,7 @@ virNWFilterVarValueDelNthValue(virNWFilterVarValuePtr val, unsigned int pos)
|
|||||||
case NWFILTER_VALUE_TYPE_ARRAY:
|
case NWFILTER_VALUE_TYPE_ARRAY:
|
||||||
if (pos < val->u.array.nValues) {
|
if (pos < val->u.array.nValues) {
|
||||||
VIR_FREE(val->u.array.values[pos]);
|
VIR_FREE(val->u.array.values[pos]);
|
||||||
val->u.array.nValues--;
|
VIR_DELETE_ELEMENT(val->u.array.values, pos, val->u.array.nValues);
|
||||||
|
|
||||||
if (pos < val->u.array.nValues)
|
|
||||||
memmove(&val->u.array.values[pos],
|
|
||||||
&val->u.array.values[pos + 1],
|
|
||||||
sizeof(val->u.array.values[0]) *
|
|
||||||
(val->u.array.nValues - pos));
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -642,11 +636,11 @@ virNWFilterHashTablePut(virNWFilterHashTablePtr table,
|
|||||||
if (VIR_STRDUP(newName, name) < 0)
|
if (VIR_STRDUP(newName, name) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (VIR_REALLOC_N(table->names, table->nNames + 1) < 0) {
|
if (VIR_APPEND_ELEMENT_COPY(table->names,
|
||||||
|
table->nNames, newName) < 0) {
|
||||||
VIR_FREE(newName);
|
VIR_FREE(newName);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
table->names[table->nNames++] = newName;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (virHashAddEntry(table->hashTable, name, val) < 0) {
|
if (virHashAddEntry(table->hashTable, name, val) < 0) {
|
||||||
|
@ -67,7 +67,7 @@ typedef virNWFilterHashTable *virNWFilterHashTablePtr;
|
|||||||
struct _virNWFilterHashTable {
|
struct _virNWFilterHashTable {
|
||||||
virHashTablePtr hashTable;
|
virHashTablePtr hashTable;
|
||||||
|
|
||||||
int nNames;
|
size_t nNames;
|
||||||
char **names;
|
char **names;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -266,8 +266,7 @@ virObjectEventCallbackListMarkDeleteID(virConnectPtr conn,
|
|||||||
static int
|
static int
|
||||||
virObjectEventCallbackListPurgeMarked(virObjectEventCallbackListPtr cbList)
|
virObjectEventCallbackListPurgeMarked(virObjectEventCallbackListPtr cbList)
|
||||||
{
|
{
|
||||||
int old_count = cbList->count;
|
size_t n;
|
||||||
int n;
|
|
||||||
for (n = 0; n < cbList->count; n++) {
|
for (n = 0; n < cbList->count; n++) {
|
||||||
if (cbList->callbacks[n]->deleted) {
|
if (cbList->callbacks[n]->deleted) {
|
||||||
virFreeCallback freecb = cbList->callbacks[n]->freecb;
|
virFreeCallback freecb = cbList->callbacks[n]->freecb;
|
||||||
@ -276,19 +275,10 @@ virObjectEventCallbackListPurgeMarked(virObjectEventCallbackListPtr cbList)
|
|||||||
virObjectUnref(cbList->callbacks[n]->conn);
|
virObjectUnref(cbList->callbacks[n]->conn);
|
||||||
VIR_FREE(cbList->callbacks[n]);
|
VIR_FREE(cbList->callbacks[n]);
|
||||||
|
|
||||||
if (n < (cbList->count - 1))
|
VIR_DELETE_ELEMENT(cbList->callbacks, n, cbList->count);
|
||||||
memmove(cbList->callbacks + n,
|
|
||||||
cbList->callbacks + n + 1,
|
|
||||||
sizeof(*(cbList->callbacks)) *
|
|
||||||
(cbList->count - (n + 1)));
|
|
||||||
cbList->count--;
|
|
||||||
n--;
|
n--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (cbList->count < old_count &&
|
|
||||||
VIR_REALLOC_N(cbList->callbacks, cbList->count) < 0) {
|
|
||||||
; /* Failure to reduce memory allocation isn't fatal */
|
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -458,15 +458,7 @@ virStoragePoolObjRemove(virStoragePoolObjListPtr pools,
|
|||||||
virStoragePoolObjUnlock(pools->objs[i]);
|
virStoragePoolObjUnlock(pools->objs[i]);
|
||||||
virStoragePoolObjFree(pools->objs[i]);
|
virStoragePoolObjFree(pools->objs[i]);
|
||||||
|
|
||||||
if (i < (pools->count - 1))
|
VIR_DELETE_ELEMENT(pools->objs, i, pools->count);
|
||||||
memmove(pools->objs + i, pools->objs + i + 1,
|
|
||||||
sizeof(*(pools->objs)) * (pools->count - (i + 1)));
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(pools->objs, pools->count - 1) < 0) {
|
|
||||||
; /* Failure to reduce memory allocation isn't fatal */
|
|
||||||
}
|
|
||||||
pools->count--;
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
virStoragePoolObjUnlock(pools->objs[i]);
|
virStoragePoolObjUnlock(pools->objs[i]);
|
||||||
@ -1782,15 +1774,13 @@ virStoragePoolObjAssignDef(virStoragePoolObjListPtr pools,
|
|||||||
}
|
}
|
||||||
virStoragePoolObjLock(pool);
|
virStoragePoolObjLock(pool);
|
||||||
pool->active = 0;
|
pool->active = 0;
|
||||||
pool->def = def;
|
|
||||||
|
|
||||||
if (VIR_REALLOC_N(pools->objs, pools->count+1) < 0) {
|
if (VIR_APPEND_ELEMENT_COPY(pools->objs, pools->count, pool) < 0) {
|
||||||
pool->def = NULL;
|
|
||||||
virStoragePoolObjUnlock(pool);
|
virStoragePoolObjUnlock(pool);
|
||||||
virStoragePoolObjFree(pool);
|
virStoragePoolObjFree(pool);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
pools->objs[pools->count++] = pool;
|
pool->def = def;
|
||||||
|
|
||||||
return pool;
|
return pool;
|
||||||
}
|
}
|
||||||
|
@ -4301,7 +4301,7 @@ qemuDomainPinVcpuFlags(virDomainPtr dom,
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
qemuDomainObjPrivatePtr priv;
|
qemuDomainObjPrivatePtr priv;
|
||||||
bool doReset = false;
|
bool doReset = false;
|
||||||
int newVcpuPinNum = 0;
|
size_t newVcpuPinNum = 0;
|
||||||
virDomainVcpuPinDefPtr *newVcpuPin = NULL;
|
virDomainVcpuPinDefPtr *newVcpuPin = NULL;
|
||||||
virBitmapPtr pcpumap = NULL;
|
virBitmapPtr pcpumap = NULL;
|
||||||
virQEMUDriverConfigPtr cfg = NULL;
|
virQEMUDriverConfigPtr cfg = NULL;
|
||||||
@ -4575,7 +4575,7 @@ qemuDomainPinEmulator(virDomainPtr dom,
|
|||||||
int ret = -1;
|
int ret = -1;
|
||||||
qemuDomainObjPrivatePtr priv;
|
qemuDomainObjPrivatePtr priv;
|
||||||
bool doReset = false;
|
bool doReset = false;
|
||||||
int newVcpuPinNum = 0;
|
size_t newVcpuPinNum = 0;
|
||||||
virDomainVcpuPinDefPtr *newVcpuPin = NULL;
|
virDomainVcpuPinDefPtr *newVcpuPin = NULL;
|
||||||
virBitmapPtr pcpumap = NULL;
|
virBitmapPtr pcpumap = NULL;
|
||||||
virQEMUDriverConfigPtr cfg = NULL;
|
virQEMUDriverConfigPtr cfg = NULL;
|
||||||
|
Loading…
Reference in New Issue
Block a user