secret: Clean up virSecretObjListExport logic

Shorten the time needed to keep the list lock and alter the cleanup
path to be more of an error path.

Utilize the the virObjectListFree function to handle the calls for
virObjectUnref on each list element and the VIR_FREE of the list
instead of open coding it.

Change the name of the virHashForEach callback to match the name
of the Export function with the Callback added onto it.

Signed-off-by: John Ferlan <jferlan@redhat.com>
This commit is contained in:
John Ferlan 2017-04-24 12:50:12 -04:00
parent 891d0a76b5
commit ab54d5f152

View File

@ -527,7 +527,7 @@ struct virSecretObjListData {
}; };
static int static int
virSecretObjListPopulate(void *payload, virSecretObjListExportCallback(void *payload,
const void *name ATTRIBUTE_UNUSED, const void *name ATTRIBUTE_UNUSED,
void *opaque) void *opaque)
{ {
@ -573,7 +573,6 @@ virSecretObjListExport(virConnectPtr conn,
virSecretObjListACLFilter filter, virSecretObjListACLFilter filter,
unsigned int flags) unsigned int flags)
{ {
int ret = -1;
struct virSecretObjListData data = { struct virSecretObjListData data = {
.conn = conn, .secrets = NULL, .conn = conn, .secrets = NULL,
.filter = filter, .flags = flags, .filter = filter, .flags = flags,
@ -581,30 +580,28 @@ virSecretObjListExport(virConnectPtr conn,
virObjectLock(secretobjs); virObjectLock(secretobjs);
if (secrets && if (secrets &&
VIR_ALLOC_N(data.secrets, virHashSize(secretobjs->objs) + 1) < 0) VIR_ALLOC_N(data.secrets, virHashSize(secretobjs->objs) + 1) < 0) {
goto cleanup; virObjectUnlock(secretobjs);
return -1;
}
virHashForEach(secretobjs->objs, virSecretObjListPopulate, &data); virHashForEach(secretobjs->objs, virSecretObjListExportCallback, &data);
virObjectUnlock(secretobjs);
if (data.error) if (data.error)
goto cleanup; goto error;
if (data.secrets) { if (data.secrets) {
/* trim the array to the final size */ /* trim the array to the final size */
ignore_value(VIR_REALLOC_N(data.secrets, data.nsecrets + 1)); ignore_value(VIR_REALLOC_N(data.secrets, data.nsecrets + 1));
*secrets = data.secrets; *secrets = data.secrets;
data.secrets = NULL;
} }
ret = data.nsecrets; return data.nsecrets;
cleanup: error:
virObjectUnlock(secretobjs); virObjectListFree(data.secrets);
while (data.secrets && data.nsecrets) return -1;
virObjectUnref(data.secrets[--data.nsecrets]);
VIR_FREE(data.secrets);
return ret;
} }