---
src/esx/esx_driver.c | 62 ++++++++---------------------
src/esx/esx_network_driver.c | 16 ++------
src/esx/esx_storage_backend_iscsi.c | 4 +-
src/esx/esx_storage_backend_vmfs.c | 78 +++++++++----------------------------
src/esx/esx_util.c | 4 +-
src/esx/esx_vi.c | 50 +++++++-----------------
src/esx/esx_vi.h | 3 +-
src/esx/esx_vi_types.c | 3 +-
8 files changed, 60 insertions(+), 160 deletions(-)
diff --git a/src/esx/esx_driver.c b/src/esx/esx_driver.c
index a5df810..26a3f1d 100644
--- a/src/esx/esx_driver.c
+++ b/src/esx/esx_driver.c
@@ -146,10 +146,8 @@ esxParseVMXFileName(const char *fileName, void *opaque)
if (strchr(fileName, '/') == NULL && strchr(fileName, '\\')
== NULL) {
/* Plain file name, use same directory as for the .vmx file */
if (virAsprintf(&result, "%s/%s",
- data->datastorePathWithoutFileName, fileName) < 0) {
- virReportOOMError();
+ data->datastorePathWithoutFileName, fileName) < 0)
goto cleanup;
- }
} else {
if (esxVI_String_AppendValueToList(&propertyNameList,
"summary.name") < 0 ||
@@ -199,10 +197,8 @@ esxParseVMXFileName(const char *fileName, void *opaque)
}
if (virAsprintf(&result, "[%s] %s", datastoreName,
- strippedFileName) < 0) {
- virReportOOMError();
+ strippedFileName) < 0)
goto cleanup;
- }
break;
}
@@ -239,10 +235,8 @@ esxParseVMXFileName(const char *fileName, void *opaque)
}
if (virAsprintf(&result, "[%s] %s", datastoreName,
- directoryAndFileName) < 0) {
- virReportOOMError();
+ directoryAndFileName) < 0)
goto cleanup;
- }
}
/* If it's an absolute path outside of a datastore just use it as is */
@@ -587,10 +581,8 @@ esxCapsInit(esxPrivate *priv)
caps = virCapabilitiesNew(VIR_ARCH_I686, 1, 1);
}
- if (caps == NULL) {
- virReportOOMError();
+ if (caps == NULL)
return NULL;
- }
virCapabilitiesAddHostMigrateTransport(caps, "vpxmigr");
@@ -695,10 +687,8 @@ esxConnectToHost(esxPrivate *priv,
}
if (virAsprintf(&url, "%s://%s:%d/sdk",
priv->parsedUri->transport,
- conn->uri->server, conn->uri->port) < 0) {
- virReportOOMError();
+ conn->uri->server, conn->uri->port) < 0)
goto cleanup;
- }
if (esxVI_Context_Alloc(&priv->host) < 0 ||
esxVI_Context_Connect(priv->host, url, ipAddress, username, password,
@@ -818,10 +808,8 @@ esxConnectToVCenter(esxPrivate *priv,
}
if (virAsprintf(&url, "%s://%s:%d/sdk",
priv->parsedUri->transport,
- hostname, conn->uri->port) < 0) {
- virReportOOMError();
+ hostname, conn->uri->port) < 0)
goto cleanup;
- }
if (esxVI_Context_Alloc(&priv->vCenter) < 0 ||
esxVI_Context_Connect(priv->vCenter, url, ipAddress, username,
@@ -973,10 +961,8 @@ esxConnectOpen(virConnectPtr conn, virConnectAuthPtr auth,
}
/* Allocate per-connection private data */
- if (VIR_ALLOC(priv) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC(priv) < 0)
goto cleanup;
- }
if (esxUtil_ParseUri(&priv->parsedUri, conn->uri) < 0) {
goto cleanup;
@@ -1269,10 +1255,8 @@ esxConnectGetHostname(virConnectPtr conn)
if (VIR_STRDUP(complete, hostName) < 0)
goto cleanup;
} else {
- if (virAsprintf(&complete, "%s.%s", hostName, domainName) < 0)
{
- virReportOOMError();
+ if (virAsprintf(&complete, "%s.%s", hostName, domainName) < 0)
goto cleanup;
- }
}
cleanup:
@@ -2739,16 +2723,12 @@ esxDomainGetXMLDesc(virDomainPtr domain, unsigned int flags)
if (directoryName == NULL) {
if (virAsprintf(&data.datastorePathWithoutFileName, "[%s]",
- datastoreName) < 0) {
- virReportOOMError();
+ datastoreName) < 0)
goto cleanup;
- }
} else {
if (virAsprintf(&data.datastorePathWithoutFileName, "[%s] %s",
- datastoreName, directoryName) < 0) {
- virReportOOMError();
+ datastoreName, directoryName) < 0)
goto cleanup;
- }
}
ctx.opaque = &data;
@@ -3213,16 +3193,12 @@ esxDomainDefineXML(virConnectPtr conn, const char *xml)
/* Register the domain */
if (directoryName != NULL) {
if (virAsprintf(&datastoreRelatedPath, "[%s] %s/%s.vmx",
datastoreName,
- directoryName, escapedName) < 0) {
- virReportOOMError();
+ directoryName, escapedName) < 0)
goto cleanup;
- }
} else {
if (virAsprintf(&datastoreRelatedPath, "[%s] %s.vmx",
datastoreName,
- escapedName) < 0) {
- virReportOOMError();
+ escapedName) < 0)
goto cleanup;
- }
}
if (esxVI_RegisterVM_Task(priv->primary,
priv->primary->datacenter->vmFolder,
@@ -3860,10 +3836,8 @@ esxDomainMigratePrepare(virConnectPtr dconn,
if (virAsprintf(uri_out, "vpxmigr://%s/%s/%s",
priv->vCenter->ipAddress,
priv->vCenter->computeResource->resourcePool->value,
- priv->vCenter->hostSystem->_reference->value) < 0)
{
- virReportOOMError();
+ priv->vCenter->hostSystem->_reference->value) <
0)
return -1;
- }
}
return 0;
@@ -5020,7 +4994,7 @@ esxConnectListAllDomains(virConnectPtr conn,
!MATCH(VIR_CONNECT_LIST_DOMAINS_NO_MANAGEDSAVE))) {
if (domains &&
VIR_ALLOC_N(*domains, 1) < 0)
- goto no_memory;
+ goto cleanup;
ret = 0;
goto cleanup;
@@ -5074,7 +5048,7 @@ esxConnectListAllDomains(virConnectPtr conn,
if (domains) {
if (VIR_ALLOC_N(doms, 1) < 0)
- goto no_memory;
+ goto cleanup;
ndoms = 1;
}
@@ -5167,7 +5141,7 @@ esxConnectListAllDomains(virConnectPtr conn,
}
if (VIR_RESIZE_N(doms, ndoms, count, 2) < 0)
- goto no_memory;
+ goto cleanup;
if (!(dom = virGetDomain(conn, name, uuid)))
goto cleanup;
@@ -5203,10 +5177,6 @@ cleanup:
esxVI_VirtualMachineSnapshotTree_Free(&rootSnapshotTreeList);
return ret;
-
-no_memory:
- virReportOOMError();
- goto cleanup;
}
#undef MATCH
diff --git a/src/esx/esx_network_driver.c b/src/esx/esx_network_driver.c
index 9aacffc..d51aad1 100644
--- a/src/esx/esx_network_driver.c
+++ b/src/esx/esx_network_driver.c
@@ -642,10 +642,8 @@ esxShapingPolicyToBandwidth(esxVI_HostNetworkTrafficShapingPolicy
*shapingPolicy
if (VIR_ALLOC(*bandwidth) < 0 ||
VIR_ALLOC((*bandwidth)->in) < 0 ||
- VIR_ALLOC((*bandwidth)->out) < 0) {
- virReportOOMError();
+ VIR_ALLOC((*bandwidth)->out) < 0)
return -1;
- }
if (shapingPolicy->averageBandwidth != NULL) {
/* Scale bits per second to kilobytes per second */
@@ -694,10 +692,8 @@ esxNetworkGetXMLDesc(virNetworkPtr network_, unsigned int flags)
return NULL;
}
- if (VIR_ALLOC(def) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC(def) < 0)
goto cleanup;
- }
/* Lookup HostVirtualSwitch */
if (esxVI_LookupHostVirtualSwitchByName(priv->primary, network_->name,
@@ -724,10 +720,8 @@ esxNetworkGetXMLDesc(virNetworkPtr network_, unsigned int flags)
if (count > 0) {
def->forward.type = VIR_NETWORK_FORWARD_BRIDGE;
- if (VIR_ALLOC_N(def->forward.ifs, count) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC_N(def->forward.ifs, count) < 0)
goto cleanup;
- }
/* Find PhysicalNic by key */
if (esxVI_LookupPhysicalNicList(priv->primary, &physicalNicList) < 0)
{
@@ -772,10 +766,8 @@ esxNetworkGetXMLDesc(virNetworkPtr network_, unsigned int flags)
}
if (count > 0) {
- if (VIR_ALLOC_N(def->portGroups, count) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC_N(def->portGroups, count) < 0)
goto cleanup;
- }
/* Lookup Network list and create name list */
if (esxVI_String_AppendValueToList(&propertyNameList, "name") <
0 ||
diff --git a/src/esx/esx_storage_backend_iscsi.c b/src/esx/esx_storage_backend_iscsi.c
index 6e1095e..346596f 100644
--- a/src/esx/esx_storage_backend_iscsi.c
+++ b/src/esx/esx_storage_backend_iscsi.c
@@ -334,10 +334,8 @@ esxStoragePoolGetXMLDesc(virStoragePoolPtr pool, unsigned int flags)
def.source.nhost = 1;
- if (VIR_ALLOC_N(def.source.hosts, def.source.nhost) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC_N(def.source.hosts, def.source.nhost) < 0)
goto cleanup;
- }
def.source.hosts[0].name = target->address;
diff --git a/src/esx/esx_storage_backend_vmfs.c b/src/esx/esx_storage_backend_vmfs.c
index 2966109..dc2b308 100644
--- a/src/esx/esx_storage_backend_vmfs.c
+++ b/src/esx/esx_storage_backend_vmfs.c
@@ -484,10 +484,8 @@ esxStoragePoolGetXMLDesc(virStoragePoolPtr pool, unsigned int flags)
if (esxVI_LocalDatastoreInfo_DynamicCast(info) != NULL) {
def.type = VIR_STORAGE_POOL_DIR;
} else if ((nasInfo = esxVI_NasDatastoreInfo_DynamicCast(info)) != NULL) {
- if (VIR_ALLOC_N(def.source.hosts, 1) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC_N(def.source.hosts, 1) < 0)
goto cleanup;
- }
def.type = VIR_STORAGE_POOL_NETFS;
def.source.hosts[0].name = nasInfo->nas->remoteHost;
def.source.dir = nasInfo->nas->remotePath;
@@ -614,10 +612,8 @@ esxStoragePoolListVolumes(virStoragePoolPtr pool, char **const
names,
if (VIR_STRDUP(names[count], fileInfo->path) < 0)
goto cleanup;
} else if (virAsprintf(&names[count], "%s/%s",
directoryAndFileName,
- fileInfo->path) < 0) {
- virReportOOMError();
+ fileInfo->path) < 0)
goto cleanup;
- }
++count;
}
@@ -651,10 +647,8 @@ esxStorageVolLookupByName(virStoragePoolPtr pool,
char *datastorePath = NULL;
char *key = NULL;
- if (virAsprintf(&datastorePath, "[%s] %s", pool->name, name) < 0)
{
- virReportOOMError();
+ if (virAsprintf(&datastorePath, "[%s] %s", pool->name, name) <
0)
goto cleanup;
- }
if (esxVI_LookupStorageVolumeKeyByDatastorePath(priv->primary,
datastorePath, &key) < 0) {
@@ -788,16 +782,12 @@ esxStorageVolLookupByKey(virConnectPtr conn, const char *key)
goto cleanup;
} else if (virAsprintf(&volumeName, "%s/%s",
directoryAndFileName,
- fileInfo->path) < 0) {
- virReportOOMError();
+ fileInfo->path) < 0)
goto cleanup;
- }
if (virAsprintf(&datastorePath, "[%s] %s", datastoreName,
- volumeName) < 0) {
- virReportOOMError();
+ volumeName) < 0)
goto cleanup;
- }
if (esxVI_VmDiskFileInfo_DynamicCast(fileInfo) == NULL) {
/* Only a VirtualDisk has a UUID */
@@ -907,10 +897,8 @@ esxStorageVolCreateXML(virStoragePoolPtr pool,
}
if (virAsprintf(&unescapedDatastorePath, "[%s] %s", pool->name,
- def->name) < 0) {
- virReportOOMError();
+ def->name) < 0)
goto cleanup;
- }
if (def->target.format == VIR_STORAGE_FILE_VMDK) {
/* Parse and escape datastore path */
@@ -934,16 +922,12 @@ esxStorageVolCreateXML(virStoragePoolPtr pool,
}
if (virAsprintf(&datastorePathWithoutFileName, "[%s] %s",
pool->name,
- directoryName) < 0) {
- virReportOOMError();
+ directoryName) < 0)
goto cleanup;
- }
if (virAsprintf(&datastorePath, "[%s] %s/%s", pool->name,
directoryName,
- fileName) < 0) {
- virReportOOMError();
+ fileName) < 0)
goto cleanup;
- }
/* Create directory, if it doesn't exist yet */
if (esxVI_LookupFileInfoByDatastorePath
@@ -1015,10 +999,8 @@ esxStorageVolCreateXML(virStoragePoolPtr pool,
}
if (priv->primary->hasQueryVirtualDiskUuid) {
- if (VIR_ALLOC_N(key, VIR_UUID_STRING_BUFLEN) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC_N(key, VIR_UUID_STRING_BUFLEN) < 0)
goto cleanup;
- }
if (esxVI_QueryVirtualDiskUuid(priv->primary, datastorePath,
priv->primary->datacenter->_reference,
@@ -1107,10 +1089,8 @@ esxStorageVolCreateXMLFrom(virStoragePoolPtr pool,
}
if (virAsprintf(&sourceDatastorePath, "[%s] %s",
sourceVolume->pool,
- sourceVolume->name) < 0) {
- virReportOOMError();
+ sourceVolume->name) < 0)
goto cleanup;
- }
/* Parse config */
def = virStorageVolDefParseString(&poolDef, xmldesc);
@@ -1143,10 +1123,8 @@ esxStorageVolCreateXMLFrom(virStoragePoolPtr pool,
}
if (virAsprintf(&unescapedDatastorePath, "[%s] %s", pool->name,
- def->name) < 0) {
- virReportOOMError();
+ def->name) < 0)
goto cleanup;
- }
if (def->target.format == VIR_STORAGE_FILE_VMDK) {
/* Parse and escape datastore path */
@@ -1170,16 +1148,12 @@ esxStorageVolCreateXMLFrom(virStoragePoolPtr pool,
}
if (virAsprintf(&datastorePathWithoutFileName, "[%s] %s",
pool->name,
- directoryName) < 0) {
- virReportOOMError();
+ directoryName) < 0)
goto cleanup;
- }
if (virAsprintf(&datastorePath, "[%s] %s/%s", pool->name,
directoryName,
- fileName) < 0) {
- virReportOOMError();
+ fileName) < 0)
goto cleanup;
- }
/* Create directory, if it doesn't exist yet */
if (esxVI_LookupFileInfoByDatastorePath
@@ -1217,10 +1191,8 @@ esxStorageVolCreateXMLFrom(virStoragePoolPtr pool,
}
if (priv->primary->hasQueryVirtualDiskUuid) {
- if (VIR_ALLOC_N(key, VIR_UUID_STRING_BUFLEN) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC_N(key, VIR_UUID_STRING_BUFLEN) < 0)
goto cleanup;
- }
if (esxVI_QueryVirtualDiskUuid(priv->primary, datastorePath,
priv->primary->datacenter->_reference,
@@ -1280,10 +1252,8 @@ esxStorageVolDelete(virStorageVolPtr volume, unsigned int flags)
virCheckFlags(0, -1);
- if (virAsprintf(&datastorePath, "[%s] %s", volume->pool,
volume->name) < 0) {
- virReportOOMError();
+ if (virAsprintf(&datastorePath, "[%s] %s", volume->pool,
volume->name) < 0)
goto cleanup;
- }
if (esxVI_DeleteVirtualDisk_Task(priv->primary, datastorePath,
priv->primary->datacenter->_reference,
@@ -1325,10 +1295,8 @@ esxStorageVolWipe(virStorageVolPtr volume, unsigned int flags)
virCheckFlags(0, -1);
- if (virAsprintf(&datastorePath, "[%s] %s", volume->pool,
volume->name) < 0) {
- virReportOOMError();
+ if (virAsprintf(&datastorePath, "[%s] %s", volume->pool,
volume->name) < 0)
goto cleanup;
- }
if (esxVI_ZeroFillVirtualDisk_Task(priv->primary, datastorePath,
priv->primary->datacenter->_reference,
@@ -1370,10 +1338,8 @@ esxStorageVolGetInfo(virStorageVolPtr volume,
memset(info, 0, sizeof(*info));
- if (virAsprintf(&datastorePath, "[%s] %s", volume->pool,
volume->name) < 0) {
- virReportOOMError();
+ if (virAsprintf(&datastorePath, "[%s] %s", volume->pool,
volume->name) < 0)
goto cleanup;
- }
if (esxVI_LookupFileInfoByDatastorePath(priv->primary, datastorePath,
false, &fileInfo,
@@ -1430,10 +1396,8 @@ esxStorageVolGetXMLDesc(virStorageVolPtr volume,
}
/* Lookup file info */
- if (virAsprintf(&datastorePath, "[%s] %s", volume->pool,
volume->name) < 0) {
- virReportOOMError();
+ if (virAsprintf(&datastorePath, "[%s] %s", volume->pool,
volume->name) < 0)
goto cleanup;
- }
if (esxVI_LookupFileInfoByDatastorePath(priv->primary, datastorePath,
false, &fileInfo,
@@ -1494,11 +1458,7 @@ esxStorageVolGetPath(virStorageVolPtr volume)
{
char *path;
- if (virAsprintf(&path, "[%s] %s", volume->pool, volume->name)
< 0) {
- virReportOOMError();
- return NULL;
- }
-
+ ignore_value(virAsprintf(&path, "[%s] %s", volume->pool,
volume->name));
return path;
}
diff --git a/src/esx/esx_util.c b/src/esx/esx_util.c
index a4b931d..536864d 100644
--- a/src/esx/esx_util.c
+++ b/src/esx/esx_util.c
@@ -54,10 +54,8 @@ esxUtil_ParseUri(esxUtil_ParsedUri **parsedUri, virURIPtr uri)
return -1;
}
- if (VIR_ALLOC(*parsedUri) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC(*parsedUri) < 0)
return -1;
- }
for (i = 0; i < uri->paramsCount; i++) {
virURIParamPtr queryParam = &uri->params[i];
diff --git a/src/esx/esx_vi.c b/src/esx/esx_vi.c
index 39420b6..e4a58c4 100644
--- a/src/esx/esx_vi.c
+++ b/src/esx/esx_vi.c
@@ -51,7 +51,8 @@
int \
esxVI_##_type##_Alloc(esxVI_##_type **ptrptr) \
{ \
- return esxVI_Alloc((void **)ptrptr, sizeof(esxVI_##_type)); \
+ return esxVI_Alloc((void **)ptrptr, sizeof(esxVI_##_type), \
+ __FILE__, __FUNCTION__, __LINE__); \
}
@@ -392,15 +393,11 @@ esxVI_CURL_Download(esxVI_CURL *curl, const char *url, char
**content,
return -1;
}
- if (virAsprintf(&range, "%llu-%llu", offset, offset + *length - 1)
< 0) {
- virReportOOMError();
+ if (virAsprintf(&range, "%llu-%llu", offset, offset + *length - 1)
< 0)
goto cleanup;
- }
} else if (offset > 0) {
- if (virAsprintf(&range, "%llu-", offset) < 0) {
- virReportOOMError();
+ if (virAsprintf(&range, "%llu-", offset) < 0)
goto cleanup;
- }
}
virMutexLock(&curl->lock);
@@ -808,10 +805,8 @@ esxVI_Context_Connect(esxVI_Context *ctx, const char *url,
return -1;
}
- if (VIR_ALLOC(ctx->sessionLock) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC(ctx->sessionLock) < 0)
return -1;
- }
if (virMutexInit(ctx->sessionLock) < 0) {
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
@@ -1315,10 +1310,8 @@ esxVI_Context_Execute(esxVI_Context *ctx, const char *methodName,
} else {
if (virAsprintf(&xpathExpression,
"/soapenv:Envelope/soapenv:Body/vim:%sResponse",
- methodName) < 0) {
- virReportOOMError();
+ methodName) < 0)
goto cleanup;
- }
responseNode = virXPathNode(xpathExpression, xpathContext);
@@ -1743,19 +1736,16 @@ esxVI_List_Deserialize(xmlNodePtr node, esxVI_List **list,
*/
int
-esxVI_Alloc(void **ptrptr, size_t size)
+esxVI_Alloc(void **ptrptr, size_t size, const char *file,
+ const char *function, size_t linenr)
{
if (ptrptr == NULL || *ptrptr != NULL) {
virReportError(VIR_ERR_INTERNAL_ERROR, "%s", _("Invalid
argument"));
return -1;
}
- if (virAllocN(ptrptr, size, 1, false, 0, NULL, NULL, 0) < 0) {
- virReportOOMError();
- return -1;
- }
-
- return 0;
+ return virAllocN(ptrptr, size, 1, true, VIR_FROM_THIS,
+ file, function, linenr);
}
@@ -3480,20 +3470,16 @@ esxVI_LookupFileInfoByDatastorePath(esxVI_Context *ctx,
* that the <path> part is actually the file name.
*/
if (virAsprintf(&datastorePathWithoutFileName, "[%s]",
- datastoreName) < 0) {
- virReportOOMError();
+ datastoreName) < 0)
goto cleanup;
- }
if (VIR_STRDUP(fileName, directoryAndFileName) < 0) {
goto cleanup;
}
} else {
if (virAsprintf(&datastorePathWithoutFileName, "[%s] %s",
- datastoreName, directoryName) < 0) {
- virReportOOMError();
+ datastoreName, directoryName) < 0)
goto cleanup;
- }
length = strlen(directoryName);
@@ -3715,10 +3701,8 @@ esxVI_LookupDatastoreContentByDatastoreName
}
/* Search datastore for files */
- if (virAsprintf(&datastorePath, "[%s]", datastoreName) < 0) {
- virReportOOMError();
+ if (virAsprintf(&datastorePath, "[%s]", datastoreName) < 0)
goto cleanup;
- }
if (esxVI_SearchDatastoreSubFolders_Task(ctx, hostDatastoreBrowser,
datastorePath, searchSpec,
@@ -3788,10 +3772,8 @@ esxVI_LookupStorageVolumeKeyByDatastorePath(esxVI_Context *ctx,
goto cleanup;
}
- if (VIR_ALLOC_N(*key, VIR_UUID_STRING_BUFLEN) < 0) {
- virReportOOMError();
+ if (VIR_ALLOC_N(*key, VIR_UUID_STRING_BUFLEN) < 0)
goto cleanup;
- }
if (esxUtil_ReformatUuid(uuid_string, *key) < 0) {
goto cleanup;
@@ -4493,10 +4475,8 @@ esxVI_WaitForTaskCompletion(esxVI_Context *ctx,
} else {
if (virAsprintf(errorMessage, "%s - %s",
taskInfo->error->fault->_actualType,
- taskInfo->error->localizedMessage) < 0) {
- virReportOOMError();
+ taskInfo->error->localizedMessage) < 0)
goto cleanup;
- }
}
}
diff --git a/src/esx/esx_vi.h b/src/esx/esx_vi.h
index 3eaeb38..c1612e2 100644
--- a/src/esx/esx_vi.h
+++ b/src/esx/esx_vi.h
@@ -330,7 +330,8 @@ int esxVI_List_Deserialize(xmlNodePtr node, esxVI_List **list,
* - 'get' functions get information from a local object
*/
-int esxVI_Alloc(void **ptrptr, size_t size);
+int esxVI_Alloc(void **ptrptr, size_t size, const char *file,
+ const char *function, size_t linenr);
int esxVI_BuildSelectSet
(esxVI_SelectionSpec **selectSet, const char *name,
diff --git a/src/esx/esx_vi_types.c b/src/esx/esx_vi_types.c
index 7908b1c..14caeeb 100644
--- a/src/esx/esx_vi_types.c
+++ b/src/esx/esx_vi_types.c
@@ -43,7 +43,8 @@
int \
esxVI_##__type##_Alloc(esxVI_##__type **ptrptr) \
{ \
- if (esxVI_Alloc((void **)ptrptr, sizeof(esxVI_##__type)) < 0) { \
+ if (esxVI_Alloc((void **)ptrptr, sizeof(esxVI_##__type), \
+ __FILE__, __FUNCTION__, __LINE__) < 0) { \
return -1; \
} \
\
--
1.8.1.5