mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-24 21:45:21 +00:00
daemon: Rework remoteClientFreeFunc cleanup loops into C macro
Rather than 'n' repetitive code segments, let's create a single macro which will make the code easier to read. Signed-off-by: John Ferlan <jferlan@redhat.com>
This commit is contained in:
parent
0023cc039d
commit
2033e8cc11
126
daemon/remote.c
126
daemon/remote.c
@ -1666,6 +1666,24 @@ void remoteRelayConnectionClosedEvent(virConnectPtr conn ATTRIBUTE_UNUSED, int r
|
|||||||
&msg);
|
&msg);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define DEREG_CB(conn, eventCallbacks, neventCallbacks, deregFcn, name) \
|
||||||
|
do { \
|
||||||
|
size_t i; \
|
||||||
|
for (i = 0; i < neventCallbacks; i++) { \
|
||||||
|
int callbackID = eventCallbacks[i]->callbackID; \
|
||||||
|
if (callbackID < 0) { \
|
||||||
|
VIR_WARN("unexpected incomplete %s callback %zu", name, i); \
|
||||||
|
continue; \
|
||||||
|
} \
|
||||||
|
VIR_DEBUG("Deregistering remote %s event relay %d", \
|
||||||
|
name, callbackID); \
|
||||||
|
eventCallbacks[i]->callbackID = -1; \
|
||||||
|
if (deregFcn(conn, callbackID) < 0) \
|
||||||
|
VIR_WARN("unexpected %s event deregister failure", name); \
|
||||||
|
} \
|
||||||
|
VIR_FREE(eventCallbacks); \
|
||||||
|
} while (0);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* You must hold lock for at least the client
|
* You must hold lock for at least the client
|
||||||
* We don't free stuff here, merely disconnect the client's
|
* We don't free stuff here, merely disconnect the client's
|
||||||
@ -1680,98 +1698,27 @@ void remoteClientFreeFunc(void *data)
|
|||||||
/* Deregister event delivery callback */
|
/* Deregister event delivery callback */
|
||||||
if (priv->conn) {
|
if (priv->conn) {
|
||||||
virIdentityPtr sysident = virIdentityGetSystem();
|
virIdentityPtr sysident = virIdentityGetSystem();
|
||||||
size_t i;
|
|
||||||
|
|
||||||
virIdentitySetCurrent(sysident);
|
virIdentitySetCurrent(sysident);
|
||||||
|
|
||||||
for (i = 0; i < priv->ndomainEventCallbacks; i++) {
|
DEREG_CB(priv->conn, priv->domainEventCallbacks,
|
||||||
int callbackID = priv->domainEventCallbacks[i]->callbackID;
|
priv->ndomainEventCallbacks,
|
||||||
if (callbackID < 0) {
|
virConnectDomainEventDeregisterAny, "domain");
|
||||||
VIR_WARN("unexpected incomplete domain callback %zu", i);
|
DEREG_CB(priv->conn, priv->networkEventCallbacks,
|
||||||
continue;
|
priv->nnetworkEventCallbacks,
|
||||||
}
|
virConnectNetworkEventDeregisterAny, "network");
|
||||||
VIR_DEBUG("Deregistering remote domain event relay %d",
|
DEREG_CB(priv->conn, priv->storageEventCallbacks,
|
||||||
callbackID);
|
priv->nstorageEventCallbacks,
|
||||||
priv->domainEventCallbacks[i]->callbackID = -1;
|
virConnectStoragePoolEventDeregisterAny, "storage");
|
||||||
if (virConnectDomainEventDeregisterAny(priv->conn, callbackID) < 0)
|
DEREG_CB(priv->conn, priv->nodeDeviceEventCallbacks,
|
||||||
VIR_WARN("unexpected domain event deregister failure");
|
priv->nnodeDeviceEventCallbacks,
|
||||||
}
|
virConnectNodeDeviceEventDeregisterAny, "node device");
|
||||||
VIR_FREE(priv->domainEventCallbacks);
|
DEREG_CB(priv->conn, priv->secretEventCallbacks,
|
||||||
|
priv->nsecretEventCallbacks,
|
||||||
for (i = 0; i < priv->nnetworkEventCallbacks; i++) {
|
virConnectSecretEventDeregisterAny, "secret");
|
||||||
int callbackID = priv->networkEventCallbacks[i]->callbackID;
|
DEREG_CB(priv->conn, priv->qemuEventCallbacks,
|
||||||
if (callbackID < 0) {
|
priv->nqemuEventCallbacks,
|
||||||
VIR_WARN("unexpected incomplete network callback %zu", i);
|
virConnectDomainQemuMonitorEventDeregister, "qemu monitor");
|
||||||
continue;
|
|
||||||
}
|
|
||||||
VIR_DEBUG("Deregistering remote network event relay %d",
|
|
||||||
callbackID);
|
|
||||||
priv->networkEventCallbacks[i]->callbackID = -1;
|
|
||||||
if (virConnectNetworkEventDeregisterAny(priv->conn,
|
|
||||||
callbackID) < 0)
|
|
||||||
VIR_WARN("unexpected network event deregister failure");
|
|
||||||
}
|
|
||||||
VIR_FREE(priv->networkEventCallbacks);
|
|
||||||
|
|
||||||
for (i = 0; i < priv->nstorageEventCallbacks; i++) {
|
|
||||||
int callbackID = priv->storageEventCallbacks[i]->callbackID;
|
|
||||||
if (callbackID < 0) {
|
|
||||||
VIR_WARN("unexpected incomplete storage pool callback %zu", i);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
VIR_DEBUG("Deregistering remote storage pool event relay %d",
|
|
||||||
callbackID);
|
|
||||||
priv->storageEventCallbacks[i]->callbackID = -1;
|
|
||||||
if (virConnectStoragePoolEventDeregisterAny(priv->conn,
|
|
||||||
callbackID) < 0)
|
|
||||||
VIR_WARN("unexpected storage pool event deregister failure");
|
|
||||||
}
|
|
||||||
VIR_FREE(priv->storageEventCallbacks);
|
|
||||||
|
|
||||||
for (i = 0; i < priv->nnodeDeviceEventCallbacks; i++) {
|
|
||||||
int callbackID = priv->nodeDeviceEventCallbacks[i]->callbackID;
|
|
||||||
if (callbackID < 0) {
|
|
||||||
VIR_WARN("unexpected incomplete node device callback %zu", i);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
VIR_DEBUG("Deregistering remote node device event relay %d",
|
|
||||||
callbackID);
|
|
||||||
priv->nodeDeviceEventCallbacks[i]->callbackID = -1;
|
|
||||||
if (virConnectNodeDeviceEventDeregisterAny(priv->conn,
|
|
||||||
callbackID) < 0)
|
|
||||||
VIR_WARN("unexpected node device event deregister failure");
|
|
||||||
}
|
|
||||||
VIR_FREE(priv->nodeDeviceEventCallbacks);
|
|
||||||
|
|
||||||
for (i = 0; i < priv->nsecretEventCallbacks; i++) {
|
|
||||||
int callbackID = priv->secretEventCallbacks[i]->callbackID;
|
|
||||||
if (callbackID < 0) {
|
|
||||||
VIR_WARN("unexpected incomplete secret callback %zu", i);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
VIR_DEBUG("Deregistering remote secret event relay %d",
|
|
||||||
callbackID);
|
|
||||||
priv->secretEventCallbacks[i]->callbackID = -1;
|
|
||||||
if (virConnectSecretEventDeregisterAny(priv->conn,
|
|
||||||
callbackID) < 0)
|
|
||||||
VIR_WARN("unexpected secret event deregister failure");
|
|
||||||
}
|
|
||||||
VIR_FREE(priv->secretEventCallbacks);
|
|
||||||
|
|
||||||
for (i = 0; i < priv->nqemuEventCallbacks; i++) {
|
|
||||||
int callbackID = priv->qemuEventCallbacks[i]->callbackID;
|
|
||||||
if (callbackID < 0) {
|
|
||||||
VIR_WARN("unexpected incomplete qemu monitor callback %zu", i);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
VIR_DEBUG("Deregistering remote qemu monitor event relay %d",
|
|
||||||
callbackID);
|
|
||||||
priv->qemuEventCallbacks[i]->callbackID = -1;
|
|
||||||
if (virConnectDomainQemuMonitorEventDeregister(priv->conn,
|
|
||||||
callbackID) < 0)
|
|
||||||
VIR_WARN("unexpected qemu monitor event deregister failure");
|
|
||||||
}
|
|
||||||
VIR_FREE(priv->qemuEventCallbacks);
|
|
||||||
|
|
||||||
if (priv->closeRegistered) {
|
if (priv->closeRegistered) {
|
||||||
if (virConnectUnregisterCloseCallback(priv->conn,
|
if (virConnectUnregisterCloseCallback(priv->conn,
|
||||||
@ -1787,6 +1734,7 @@ void remoteClientFreeFunc(void *data)
|
|||||||
|
|
||||||
VIR_FREE(priv);
|
VIR_FREE(priv);
|
||||||
}
|
}
|
||||||
|
#undef DEREG_CB
|
||||||
|
|
||||||
|
|
||||||
static void remoteClientCloseFunc(virNetServerClientPtr client)
|
static void remoteClientCloseFunc(virNetServerClientPtr client)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user