esx: Fix memory leaks in error paths related to transferred ownership

Appending an item to a list transfers ownership of that item to the
list owner. But an error can occur in between item allocation and
appending it to the list. In this case the item has to be freed
explicitly. This was not done in some special cases resulting in
possible memory leaks.

Reported by Coverity.
(cherry picked from commit 3b9a12958d)
This commit is contained in:
Matthias Bolte 2012-05-06 19:33:59 +02:00 committed by Cole Robinson
parent ecd9a50b76
commit 856a23c2bc
2 changed files with 66 additions and 13 deletions

View File

@ -3489,6 +3489,7 @@ esxDomainSetAutostart(virDomainPtr domain, int autostart)
esxVI_AutoStartPowerInfo *powerInfoList = NULL; esxVI_AutoStartPowerInfo *powerInfoList = NULL;
esxVI_AutoStartPowerInfo *powerInfo = NULL; esxVI_AutoStartPowerInfo *powerInfo = NULL;
esxVI_AutoStartPowerInfo *newPowerInfo = NULL; esxVI_AutoStartPowerInfo *newPowerInfo = NULL;
bool newPowerInfo_isAppended = false;
if (esxVI_EnsureSession(priv->primary) < 0) { if (esxVI_EnsureSession(priv->primary) < 0) {
return -1; return -1;
@ -3546,9 +3547,7 @@ esxDomainSetAutostart(virDomainPtr domain, int autostart)
if (esxVI_AutoStartPowerInfo_Alloc(&newPowerInfo) < 0 || if (esxVI_AutoStartPowerInfo_Alloc(&newPowerInfo) < 0 ||
esxVI_Int_Alloc(&newPowerInfo->startOrder) < 0 || esxVI_Int_Alloc(&newPowerInfo->startOrder) < 0 ||
esxVI_Int_Alloc(&newPowerInfo->startDelay) < 0 || esxVI_Int_Alloc(&newPowerInfo->startDelay) < 0 ||
esxVI_Int_Alloc(&newPowerInfo->stopDelay) < 0 || esxVI_Int_Alloc(&newPowerInfo->stopDelay) < 0) {
esxVI_AutoStartPowerInfo_AppendToList(&spec->powerInfo,
newPowerInfo) < 0) {
goto cleanup; goto cleanup;
} }
@ -3560,6 +3559,13 @@ esxDomainSetAutostart(virDomainPtr domain, int autostart)
newPowerInfo->stopDelay->value = -1; /* use system default */ newPowerInfo->stopDelay->value = -1; /* use system default */
newPowerInfo->stopAction = (char *)"none"; newPowerInfo->stopAction = (char *)"none";
if (esxVI_AutoStartPowerInfo_AppendToList(&spec->powerInfo,
newPowerInfo) < 0) {
goto cleanup;
}
newPowerInfo_isAppended = true;
if (esxVI_ReconfigureAutostart if (esxVI_ReconfigureAutostart
(priv->primary, (priv->primary,
priv->primary->hostSystem->configManager->autoStartManager, priv->primary->hostSystem->configManager->autoStartManager,
@ -3581,6 +3587,10 @@ esxDomainSetAutostart(virDomainPtr domain, int autostart)
esxVI_AutoStartDefaults_Free(&defaults); esxVI_AutoStartDefaults_Free(&defaults);
esxVI_AutoStartPowerInfo_Free(&powerInfoList); esxVI_AutoStartPowerInfo_Free(&powerInfoList);
if (!newPowerInfo_isAppended) {
esxVI_AutoStartPowerInfo_Free(&newPowerInfo);
}
return result; return result;
} }

View File

@ -1882,7 +1882,9 @@ esxVI_LookupObjectContentByType(esxVI_Context *ctx,
{ {
int result = -1; int result = -1;
esxVI_ObjectSpec *objectSpec = NULL; esxVI_ObjectSpec *objectSpec = NULL;
bool objectSpec_isAppended = false;
esxVI_PropertySpec *propertySpec = NULL; esxVI_PropertySpec *propertySpec = NULL;
bool propertySpec_isAppended = false;
esxVI_PropertyFilterSpec *propertyFilterSpec = NULL; esxVI_PropertyFilterSpec *propertyFilterSpec = NULL;
if (objectContentList == NULL || *objectContentList != NULL) { if (objectContentList == NULL || *objectContentList != NULL) {
@ -1951,10 +1953,20 @@ esxVI_LookupObjectContentByType(esxVI_Context *ctx,
if (esxVI_PropertyFilterSpec_Alloc(&propertyFilterSpec) < 0 || if (esxVI_PropertyFilterSpec_Alloc(&propertyFilterSpec) < 0 ||
esxVI_PropertySpec_AppendToList(&propertyFilterSpec->propSet, esxVI_PropertySpec_AppendToList(&propertyFilterSpec->propSet,
propertySpec) < 0 || propertySpec) < 0) {
esxVI_ObjectSpec_AppendToList(&propertyFilterSpec->objectSet, goto cleanup;
objectSpec) < 0 || }
esxVI_RetrieveProperties(ctx, propertyFilterSpec,
propertySpec_isAppended = true;
if (esxVI_ObjectSpec_AppendToList(&propertyFilterSpec->objectSet,
objectSpec) < 0) {
goto cleanup;
}
objectSpec_isAppended = true;
if (esxVI_RetrieveProperties(ctx, propertyFilterSpec,
objectContentList) < 0) { objectContentList) < 0) {
goto cleanup; goto cleanup;
} }
@ -1994,13 +2006,24 @@ esxVI_LookupObjectContentByType(esxVI_Context *ctx,
* Remove values given by the caller from the data structures to prevent * Remove values given by the caller from the data structures to prevent
* them from being freed by the call to esxVI_PropertyFilterSpec_Free(). * them from being freed by the call to esxVI_PropertyFilterSpec_Free().
*/ */
objectSpec->obj = NULL; if (objectSpec != NULL) {
objectSpec->selectSet = NULL; objectSpec->obj = NULL;
objectSpec->selectSet = NULL;
}
if (propertySpec != NULL) { if (propertySpec != NULL) {
propertySpec->type = NULL; propertySpec->type = NULL;
propertySpec->pathSet = NULL; propertySpec->pathSet = NULL;
} }
if (!objectSpec_isAppended) {
esxVI_ObjectSpec_Free(&objectSpec);
}
if (!propertySpec_isAppended) {
esxVI_PropertySpec_Free(&propertySpec);
}
esxVI_PropertyFilterSpec_Free(&propertyFilterSpec); esxVI_PropertyFilterSpec_Free(&propertyFilterSpec);
return result; return result;
@ -3885,7 +3908,9 @@ esxVI_WaitForTaskCompletion(esxVI_Context *ctx,
{ {
int result = -1; int result = -1;
esxVI_ObjectSpec *objectSpec = NULL; esxVI_ObjectSpec *objectSpec = NULL;
bool objectSpec_isAppended = false;
esxVI_PropertySpec *propertySpec = NULL; esxVI_PropertySpec *propertySpec = NULL;
bool propertySpec_isAppended = false;
esxVI_PropertyFilterSpec *propertyFilterSpec = NULL; esxVI_PropertyFilterSpec *propertyFilterSpec = NULL;
esxVI_ManagedObjectReference *propertyFilter = NULL; esxVI_ManagedObjectReference *propertyFilter = NULL;
char *version = NULL; char *version = NULL;
@ -3927,10 +3952,20 @@ esxVI_WaitForTaskCompletion(esxVI_Context *ctx,
"info.state") < 0 || "info.state") < 0 ||
esxVI_PropertyFilterSpec_Alloc(&propertyFilterSpec) < 0 || esxVI_PropertyFilterSpec_Alloc(&propertyFilterSpec) < 0 ||
esxVI_PropertySpec_AppendToList(&propertyFilterSpec->propSet, esxVI_PropertySpec_AppendToList(&propertyFilterSpec->propSet,
propertySpec) < 0 || propertySpec) < 0) {
esxVI_ObjectSpec_AppendToList(&propertyFilterSpec->objectSet, goto cleanup;
objectSpec) < 0 || }
esxVI_CreateFilter(ctx, propertyFilterSpec, esxVI_Boolean_True,
propertySpec_isAppended = true;
if (esxVI_ObjectSpec_AppendToList(&propertyFilterSpec->objectSet,
objectSpec) < 0) {
goto cleanup;
}
objectSpec_isAppended = true;
if (esxVI_CreateFilter(ctx, propertyFilterSpec, esxVI_Boolean_True,
&propertyFilter) < 0) { &propertyFilter) < 0) {
goto cleanup; goto cleanup;
} }
@ -4066,6 +4101,14 @@ esxVI_WaitForTaskCompletion(esxVI_Context *ctx,
propertySpec->type = NULL; propertySpec->type = NULL;
} }
if (!objectSpec_isAppended) {
esxVI_ObjectSpec_Free(&objectSpec);
}
if (!propertySpec_isAppended) {
esxVI_PropertySpec_Free(&propertySpec);
}
esxVI_PropertyFilterSpec_Free(&propertyFilterSpec); esxVI_PropertyFilterSpec_Free(&propertyFilterSpec);
esxVI_ManagedObjectReference_Free(&propertyFilter); esxVI_ManagedObjectReference_Free(&propertyFilter);
VIR_FREE(version); VIR_FREE(version);