mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-10 05:17:59 +03:00
storage: add support for new rbd_list2 method
The rbd_list method has been deprecated in Ceph >= 14.0.0 in favour of the new rbd_list2 method which populates an array of structs. Reviewed-by: Ján Tomko <jtomko@redhat.com> Signed-off-by: Daniel P. Berrangé <berrange@redhat.com>
This commit is contained in:
parent
28c8403ed0
commit
3aa190f2a4
@ -33,6 +33,7 @@ AC_DEFUN([LIBVIRT_STORAGE_CHECK_RBD], [
|
|||||||
old_LIBS="$LIBS"
|
old_LIBS="$LIBS"
|
||||||
LIBS="$LIBS $LIBRBD_LIBS"
|
LIBS="$LIBS $LIBRBD_LIBS"
|
||||||
AC_CHECK_FUNCS([rbd_get_features],[],[LIBRBD_FOUND=no])
|
AC_CHECK_FUNCS([rbd_get_features],[],[LIBRBD_FOUND=no])
|
||||||
|
AC_CHECK_FUNCS([rbd_list2])
|
||||||
LIBS="$old_LIBS"
|
LIBS="$old_LIBS"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -566,6 +566,48 @@ volStorageBackendRBDRefreshVolInfo(virStorageVolDefPtr vol,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_RBD_LIST2
|
||||||
|
static char **
|
||||||
|
virStorageBackendRBDGetVolNames(virStorageBackendRBDStatePtr ptr)
|
||||||
|
{
|
||||||
|
char **names = NULL;
|
||||||
|
size_t nnames = 0;
|
||||||
|
int rc;
|
||||||
|
rbd_image_spec_t *images = NULL;
|
||||||
|
size_t nimages = 16;
|
||||||
|
size_t i;
|
||||||
|
|
||||||
|
while (true) {
|
||||||
|
if (VIR_ALLOC_N(images, nimages) < 0)
|
||||||
|
goto error;
|
||||||
|
|
||||||
|
rc = rbd_list2(ptr->ioctx, images, &nimages);
|
||||||
|
if (rc >= 0)
|
||||||
|
break;
|
||||||
|
if (rc != -ERANGE) {
|
||||||
|
virReportSystemError(-rc, "%s", _("Unable to list RBD images"));
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (VIR_ALLOC_N(names, nimages + 1) < 0)
|
||||||
|
goto error;
|
||||||
|
nnames = nimages;
|
||||||
|
|
||||||
|
for (i = 0; i < nimages; i++)
|
||||||
|
VIR_STEAL_PTR(names[i], images->name);
|
||||||
|
|
||||||
|
return names;
|
||||||
|
|
||||||
|
error:
|
||||||
|
virStringListFreeCount(names, nnames);
|
||||||
|
rbd_image_spec_list_cleanup(images, nimages);
|
||||||
|
VIR_FREE(images);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else /* ! HAVE_RBD_LIST2 */
|
||||||
|
|
||||||
static char **
|
static char **
|
||||||
virStorageBackendRBDGetVolNames(virStorageBackendRBDStatePtr ptr)
|
virStorageBackendRBDGetVolNames(virStorageBackendRBDStatePtr ptr)
|
||||||
{
|
{
|
||||||
@ -614,6 +656,7 @@ virStorageBackendRBDGetVolNames(virStorageBackendRBDStatePtr ptr)
|
|||||||
virStringListFreeCount(names, nnames);
|
virStringListFreeCount(names, nnames);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
#endif /* ! HAVE_RBD_LIST2 */
|
||||||
|
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
Loading…
Reference in New Issue
Block a user