1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-01-11 09:17:52 +03:00

storage: split off code for calling rbd_list

The rbd_list method has a quite unpleasant signature returning an
array of strings in a single buffer instead of an array. It is
being deprecated in favour of rbd_list2. To maintain clarity of
code when supporting both APIs in parallel, split the rbd_list
code out into a separate method.

In splitting this we now honour the rbd_list failures.

Reviewed-by: Ján Tomko <jtomko@redhat.com>
Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
Daniel P. Berrangé 2019-03-18 10:58:48 +00:00
parent 1e1cf8e66b
commit 28c8403ed0

View File

@ -565,19 +565,68 @@ volStorageBackendRBDRefreshVolInfo(virStorageVolDefPtr vol,
return ret; return ret;
} }
static char **
virStorageBackendRBDGetVolNames(virStorageBackendRBDStatePtr ptr)
{
char **names = NULL;
size_t nnames = 0;
int rc;
size_t max_size = 1024;
VIR_AUTOFREE(char *) namebuf = NULL;
const char *name;
while (true) {
if (VIR_ALLOC_N(namebuf, max_size) < 0)
goto error;
rc = rbd_list(ptr->ioctx, namebuf, &max_size);
if (rc >= 0)
break;
if (rc != -ERANGE) {
virReportSystemError(-rc, "%s", _("Unable to list RBD images"));
goto error;
}
VIR_FREE(namebuf);
}
for (name = namebuf; name < namebuf + max_size;) {
VIR_AUTOFREE(char *) namedup = NULL;
if (STREQ(name, ""))
break;
if (VIR_STRDUP(namedup, name) < 0)
goto error;
if (VIR_APPEND_ELEMENT(names, nnames, namedup) < 0)
goto error;
name += strlen(name) + 1;
}
if (VIR_EXPAND_N(names, nnames, 1) < 0)
goto error;
return names;
error:
virStringListFreeCount(names, nnames);
return NULL;
}
static int static int
virStorageBackendRBDRefreshPool(virStoragePoolObjPtr pool) virStorageBackendRBDRefreshPool(virStoragePoolObjPtr pool)
{ {
size_t max_size = 1024;
int ret = -1; int ret = -1;
int len = -1;
int r = 0; int r = 0;
char *name;
virStoragePoolDefPtr def = virStoragePoolObjGetDef(pool); virStoragePoolDefPtr def = virStoragePoolObjGetDef(pool);
virStorageBackendRBDStatePtr ptr = NULL; virStorageBackendRBDStatePtr ptr = NULL;
struct rados_cluster_stat_t clusterstat; struct rados_cluster_stat_t clusterstat;
struct rados_pool_stat_t poolstat; struct rados_pool_stat_t poolstat;
VIR_AUTOFREE(char *) names = NULL; char **names = NULL;
size_t i;
if (!(ptr = virStorageBackendRBDNewState(pool))) if (!(ptr = virStorageBackendRBDNewState(pool)))
goto cleanup; goto cleanup;
@ -602,33 +651,16 @@ virStorageBackendRBDRefreshPool(virStoragePoolObjPtr pool)
def->source.name, clusterstat.kb, clusterstat.kb_avail, def->source.name, clusterstat.kb, clusterstat.kb_avail,
poolstat.num_bytes); poolstat.num_bytes);
while (true) { if (!(names = virStorageBackendRBDGetVolNames(ptr)))
if (VIR_ALLOC_N(names, max_size) < 0) goto cleanup;
goto cleanup;
len = rbd_list(ptr->ioctx, names, &max_size); for (i = 0; names[i] != NULL; i++) {
if (len >= 0)
break;
if (len != -ERANGE) {
VIR_WARN("%s", "A problem occurred while listing RBD images");
goto cleanup;
}
VIR_FREE(names);
}
for (name = names; name < names + max_size;) {
VIR_AUTOPTR(virStorageVolDef) vol = NULL; VIR_AUTOPTR(virStorageVolDef) vol = NULL;
if (STREQ(name, ""))
break;
if (VIR_ALLOC(vol) < 0) if (VIR_ALLOC(vol) < 0)
goto cleanup; goto cleanup;
if (VIR_STRDUP(vol->name, name) < 0) VIR_STEAL_PTR(vol->name, names[i]);
goto cleanup;
name += strlen(name) + 1;
r = volStorageBackendRBDRefreshVolInfo(vol, pool, ptr); r = volStorageBackendRBDRefreshVolInfo(vol, pool, ptr);
@ -659,6 +691,7 @@ virStorageBackendRBDRefreshPool(virStoragePoolObjPtr pool)
ret = 0; ret = 0;
cleanup: cleanup:
virStringListFree(names);
virStorageBackendRBDFreeState(&ptr); virStorageBackendRBDFreeState(&ptr);
return ret; return ret;
} }