storage_util: Rework storageBackendCreateRaw() slightly

Remove @ret and @created variables which are not needed really.

Signed-off-by: Yi Li <yili@winhong.com>
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
Yi Li 2021-01-05 22:43:32 +08:00 committed by Michal Privoznik
parent b3667052de
commit 777976e0a4
1 changed files with 15 additions and 16 deletions

View File

@ -384,11 +384,9 @@ storageBackendCreateRaw(virStoragePoolObjPtr pool,
unsigned int flags)
{
virStoragePoolDefPtr def = virStoragePoolObjGetDef(pool);
int ret = -1;
int operation_flags;
bool reflink_copy = false;
mode_t open_mode = VIR_STORAGE_DEFAULT_VOL_PERM_MODE;
bool created = false;
VIR_AUTOCLOSE fd = -1;
virCheckFlags(VIR_STORAGE_VOL_CREATE_PREALLOC_METADATA |
@ -399,13 +397,13 @@ storageBackendCreateRaw(virStoragePoolObjPtr pool,
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
_("metadata preallocation is not supported for raw "
"volumes"));
goto cleanup;
return -1;
}
if (virStorageSourceHasBacking(&vol->target)) {
virReportError(VIR_ERR_NO_SUPPORT, "%s",
_("backing storage not supported for raw volumes"));
goto cleanup;
return -1;
}
if (flags & VIR_STORAGE_VOL_CREATE_REFLINK)
@ -415,7 +413,7 @@ storageBackendCreateRaw(virStoragePoolObjPtr pool,
if (vol->target.encryption) {
virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
_("storage pool does not support encrypted volumes"));
goto cleanup;
return -1;
}
operation_flags = VIR_FILE_OPEN_FORCE_MODE | VIR_FILE_OPEN_FORCE_OWNER;
@ -434,26 +432,27 @@ storageBackendCreateRaw(virStoragePoolObjPtr pool,
virReportSystemError(-fd,
_("Failed to create file '%s'"),
vol->target.path);
goto cleanup;
return -1;
}
created = true;
/* NB, COW flag can only be toggled when the file is zero-size,
* so must go before the createRawFile call allocates payload */
if (vol->target.nocow &&
virFileSetCOW(vol->target.path, VIR_TRISTATE_BOOL_NO) < 0)
goto cleanup;
goto error;
if ((ret = createRawFile(fd, vol, inputvol, reflink_copy)) < 0)
if (createRawFile(fd, vol, inputvol, reflink_copy) < 0) {
/* createRawFile already reported the exact error. */
ret = -1;
goto error;
}
cleanup:
if (ret < 0 && created)
ignore_value(virFileRemove(vol->target.path,
vol->target.perms->uid,
vol->target.perms->gid));
return ret;
return 0;
error:
virFileRemove(vol->target.path,
vol->target.perms->uid,
vol->target.perms->gid);
return -1;
}