xmlXPathContextPtr ctxt,
unsigned int flags)
{
- virStorageVolDefPtr def;
virStorageVolDefPtr ret = NULL;
virStorageVolOptionsPtr options;
char *type = NULL;
xmlNodePtr *nodes = NULL;
size_t i;
int n;
+ VIR_AUTOPTR(virStorageVolDef) def = NULL;
virCheckFlags(VIR_VOL_XML_PARSE_NO_CAPACITY |
VIR_VOL_XML_PARSE_OPT_CAPACITY, NULL);
VIR_STEAL_PTR(ret, def);
cleanup:
- virStorageVolDefFree(def);
VIR_FREE(nodes);
VIR_FREE(allocation);
VIR_FREE(capacity);
VIR_CONNECT_LIST_STORAGE_POOLS_FILTERS_POOL_TYPE)
VIR_DEFINE_AUTOPTR_FUNC(virStoragePoolSource, virStoragePoolSourceFree);
+VIR_DEFINE_AUTOPTR_FUNC(virStorageVolDef, virStorageVolDefFree);
#endif /* LIBVIRT_STORAGE_CONF_H */
virStorageVolPtr volume = NULL;
esxPrivate *priv = pool->conn->privateData;
virStoragePoolDef poolDef;
- virStorageVolDefPtr def = NULL;
char *tmp;
char *unescapedDatastorePath = NULL;
char *unescapedDirectoryName = NULL;
char *taskInfoErrorMessage = NULL;
char *uuid_string = NULL;
char *key = NULL;
+ VIR_AUTOPTR(virStorageVolDef) def = NULL;
virCheckFlags(0, NULL);
virtualDiskSpec->adapterType = NULL;
}
- virStorageVolDefFree(def);
VIR_FREE(unescapedDatastorePath);
VIR_FREE(unescapedDirectoryName);
VIR_FREE(unescapedDirectoryAndFileName);
esxPrivate *priv = pool->conn->privateData;
virStoragePoolDef poolDef;
char *sourceDatastorePath = NULL;
- virStorageVolDefPtr def = NULL;
char *tmp;
char *unescapedDatastorePath = NULL;
char *unescapedDirectoryName = NULL;
char *taskInfoErrorMessage = NULL;
char *uuid_string = NULL;
char *key = NULL;
+ VIR_AUTOPTR(virStorageVolDef) def = NULL;
virCheckFlags(0, NULL);
cleanup:
VIR_FREE(sourceDatastorePath);
- virStorageVolDefFree(def);
VIR_FREE(unescapedDatastorePath);
VIR_FREE(unescapedDirectoryName);
VIR_FREE(unescapedDirectoryAndFileName);
{
virCheckFlags(0, NULL);
- virStorageVolDefPtr voldef = NULL;
virStoragePoolDefPtr spdef = NULL;
virStorageVolPtr vol = NULL;
virStorageVolPtr dup_vol = NULL;
char *key = NULL;
+ VIR_AUTOPTR(virStorageVolDef) voldef = NULL;
if (VIR_ALLOC(spdef) < 0)
return NULL;
err:
VIR_FREE(key);
- virStorageVolDefFree(voldef);
virStoragePoolDefFree(spdef);
virObjectUnref(vol);
return NULL;
virStorageVolDefPtr *volptr)
{
int ret = -1;
- virStorageVolDefPtr vol = NULL;
glfs_fd_t *fd = NULL;
virStorageSourcePtr meta = NULL;
char *header = NULL;
ssize_t len;
int backingFormat;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
*volptr = NULL;
ret = 0;
cleanup:
virStorageSourceFree(meta);
- virStorageVolDefFree(vol);
if (fd)
glfs_close(fd);
VIR_FREE(header);
char *portal)
{
virStoragePoolDefPtr def = virStoragePoolObjGetDef(pool);
- virStorageVolDefPtr vol = NULL;
uint32_t block_size;
uint32_t nb_block;
- int ret = -1;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
virStoragePoolObjClearVols(pool);
if (virISCSIDirectTestUnitReady(iscsi, lun) < 0)
- goto cleanup;
+ return -1;
if (VIR_ALLOC(vol) < 0)
- goto cleanup;
+ return -1;
vol->type = VIR_STORAGE_VOL_NETWORK;
if (virISCSIDirectGetVolumeCapacity(iscsi, lun, &block_size, &nb_block) < 0)
- goto cleanup;
+ return -1;
vol->target.capacity = block_size * nb_block;
vol->target.allocation = block_size * nb_block;
def->allocation += vol->target.allocation;
if (virISCSIDirectSetVolumeAttributes(pool, vol, lun, portal) < 0)
- goto cleanup;
+ return -1;
if (virStoragePoolObjAddVol(pool, vol) < 0)
- goto cleanup;
-
+ return -1;
vol = NULL;
- ret = 0;
- cleanup:
- virStorageVolDefFree(vol);
- return ret;
+ return 0;
}
static int
const char *dev)
{
virStoragePoolDefPtr def = virStoragePoolObjGetDef(pool);
- virStorageVolDefPtr vol;
- int ret = -1;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
if (VIR_ALLOC(vol) < 0)
- goto cleanup;
+ return -1;
vol->type = VIR_STORAGE_VOL_BLOCK;
if (virAsprintf(&(vol->name), "dm-%u", devnum) < 0)
- goto cleanup;
+ return -1;
if (virAsprintf(&vol->target.path, "/dev/%s", dev) < 0)
- goto cleanup;
+ return -1;
if (virStorageBackendUpdateVolInfo(vol, true,
VIR_STORAGE_VOL_OPEN_DEFAULT, 0) < 0) {
- goto cleanup;
+ return -1;
}
/* XXX should use logical unit's UUID instead */
if (VIR_STRDUP(vol->key, vol->target.path) < 0)
- goto cleanup;
+ return -1;
if (virStoragePoolObjAddVol(pool, vol) < 0)
- goto cleanup;
+ return -1;
def->capacity += vol->target.capacity;
def->allocation += vol->target.allocation;
- ret = 0;
-
- cleanup:
+ vol = NULL;
- if (ret != 0)
- virStorageVolDefFree(vol);
-
- return ret;
+ return 0;
}
}
for (name = names; name < names + max_size;) {
- virStorageVolDefPtr vol;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
if (STREQ(name, ""))
break;
if (VIR_ALLOC(vol) < 0)
goto cleanup;
- if (VIR_STRDUP(vol->name, name) < 0) {
- VIR_FREE(vol);
+ if (VIR_STRDUP(vol->name, name) < 0)
goto cleanup;
- }
name += strlen(name) + 1;
if (r == -ENOENT || r == -ETIMEDOUT)
continue;
- virStorageVolDefFree(vol);
goto cleanup;
}
if (virStoragePoolObjAddVol(pool, vol) < 0) {
- virStorageVolDefFree(vol);
virStoragePoolObjClearVols(pool);
goto cleanup;
}
+ vol = NULL;
}
VIR_DEBUG("Found %zu images in RBD pool %s",
static int
virStorageBackendSheepdogAddVolume(virStoragePoolObjPtr pool, const char *diskInfo)
{
- virStorageVolDefPtr vol = NULL;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
if (diskInfo == NULL) {
virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
_("Missing disk info when adding volume"));
- goto error;
+ return -1;
}
if (VIR_ALLOC(vol) < 0 || VIR_STRDUP(vol->name, diskInfo) < 0)
- goto error;
+ return -1;
vol->type = VIR_STORAGE_VOL_NETWORK;
if (virStorageBackendSheepdogRefreshVol(pool, vol) < 0)
- goto error;
+ return -1;
if (virStoragePoolObjAddVol(pool, vol) < 0)
- goto error;
+ return -1;
+ vol = NULL;
return 0;
-
- error:
- virStorageVolDefFree(vol);
- return -1;
}
static int
virStoragePoolObjPtr obj;
virStoragePoolDefPtr def;
virStorageBackendPtr backend;
- virStorageVolDefPtr voldef = NULL;
virStorageVolPtr vol = NULL, newvol = NULL;
+ VIR_AUTOPTR(virStorageVolDef) voldef = NULL;
virCheckFlags(VIR_STORAGE_VOL_CREATE_PREALLOC_METADATA, NULL);
cleanup:
virObjectUnref(newvol);
- virStorageVolDefFree(voldef);
virStoragePoolObjEndAPI(&obj);
return vol;
}
virStoragePoolObjPtr objsrc = NULL;
virStorageBackendPtr backend;
virStorageVolDefPtr voldefsrc = NULL;
- virStorageVolDefPtr voldef = NULL;
virStorageVolDefPtr shadowvol = NULL;
virStorageVolPtr newvol = NULL;
virStorageVolPtr vol = NULL;
int buildret;
+ VIR_AUTOPTR(virStorageVolDef) voldef = NULL;
virCheckFlags(VIR_STORAGE_VOL_CREATE_PREALLOC_METADATA |
VIR_STORAGE_VOL_CREATE_REFLINK,
cleanup:
virObjectUnref(newvol);
- virStorageVolDefFree(voldef);
VIR_FREE(shadowvol);
virStoragePoolObjEndAPI(&obj);
virStoragePoolObjEndAPI(&objsrc);
struct dirent *ent;
struct statvfs sb;
struct stat statbuf;
- virStorageVolDefPtr vol = NULL;
virStorageSourcePtr target = NULL;
int direrr;
int fd = -1, ret = -1;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
if (virDirOpen(&dir, def->target.path) < 0)
goto cleanup;
cleanup:
VIR_DIR_CLOSE(dir);
VIR_FORCE_CLOSE(fd);
- virStorageVolDefFree(vol);
virStorageSourceFree(target);
if (ret < 0)
virStoragePoolObjClearVols(pool);
const char *dev)
{
virStoragePoolDefPtr def = virStoragePoolObjGetDef(pool);
- virStorageVolDefPtr vol = NULL;
char *devpath = NULL;
int retval = -1;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
/* Check if the pool is using a stable target path. The call to
* virStorageBackendStablePath will fail if the pool target path
retval = 0;
cleanup:
- virStorageVolDefFree(vol);
VIR_FREE(devpath);
return retval;
}
size_t i;
int num, ret = -1;
xmlNodePtr *nodes = NULL;
- virStorageVolDefPtr volDef = NULL;
+ VIR_AUTOPTR(virStorageVolDef) volDef = NULL;
/* Find storage volumes */
if (virAsprintf(&vol_xpath, "/node/pool[%d]/volume", objidx) < 0)
ret = 0;
error:
- virStorageVolDefFree(volDef);
VIR_FREE(nodes);
return ret;
}
testDriverPtr privconn = pool->conn->privateData;
virStoragePoolObjPtr obj;
virStoragePoolDefPtr def;
- virStorageVolDefPtr privvol = NULL;
virStorageVolPtr ret = NULL;
+ VIR_AUTOPTR(virStorageVolDef) privvol = NULL;
virCheckFlags(0, NULL);
privvol = NULL;
cleanup:
- virStorageVolDefFree(privvol);
virStoragePoolObjEndAPI(&obj);
return ret;
}
testDriverPtr privconn = pool->conn->privateData;
virStoragePoolObjPtr obj;
virStoragePoolDefPtr def;
- virStorageVolDefPtr privvol = NULL, origvol = NULL;
+ virStorageVolDefPtr origvol = NULL;
virStorageVolPtr ret = NULL;
+ VIR_AUTOPTR(virStorageVolDef) privvol = NULL;
virCheckFlags(0, NULL);
privvol = NULL;
cleanup:
- virStorageVolDefFree(privvol);
virStoragePoolObjEndAPI(&obj);
return ret;
}
const char *xml, unsigned int flags)
{
vboxDriverPtr data = pool->conn->privateData;
- virStorageVolDefPtr def = NULL;
PRUnichar *hddFormatUtf16 = NULL;
PRUnichar *hddNameUtf16 = NULL;
virStoragePoolDef poolDef;
PRUint32 variant = HardDiskVariant_Standard;
resultCodeUnion resultCode;
virStorageVolPtr ret = NULL;
+ VIR_AUTOPTR(virStorageVolDef) def = NULL;
if (!data->vboxObj)
return ret;
VBOX_RELEASE(progress);
VBOX_UTF16_FREE(hddFormatUtf16);
VBOX_UTF16_FREE(hddNameUtf16);
- virStorageVolDefFree(def);
return ret;
}
int ret = -1;
char *output = NULL;
virStoragePoolDefPtr pool = NULL;
- virStorageVolDefPtr vol = NULL;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
if (!(pool = virStoragePoolDefParseFile(data->poolxml)))
goto cleanup;
cleanup:
VIR_FREE(output);
virStoragePoolDefFree(pool);
- virStorageVolDefFree(vol);
return ret;
}
virCommandPtr cmd = NULL;
- virStorageVolDefPtr vol = NULL, inputvol = NULL;
virStoragePoolDefPtr def = NULL;
virStoragePoolDefPtr inputpool = NULL;
virStoragePoolObjPtr obj = NULL;
+ VIR_AUTOPTR(virStorageVolDef) vol = NULL;
+ VIR_AUTOPTR(virStorageVolDef) inputvol = NULL;
if (!(def = virStoragePoolDefParseFile(poolxml)))
goto cleanup;
cleanup:
virStoragePoolDefFree(inputpool);
- virStorageVolDefFree(vol);
- virStorageVolDefFree(inputvol);
virCommandFree(cmd);
VIR_FREE(actualCmdline);
virStoragePoolObjEndAPI(&obj);
char *actual = NULL;
int ret = -1;
virStoragePoolDefPtr pool = NULL;
- virStorageVolDefPtr dev = NULL;
+ VIR_AUTOPTR(virStorageVolDef) dev = NULL;
if (!(pool = virStoragePoolDefParseFile(poolxml)))
goto fail;
fail:
VIR_FREE(actual);
virStoragePoolDefFree(pool);
- virStorageVolDefFree(dev);
return ret;
}