close callback: make unregister clean after connect close event

If connect close is fired then following unregister will fail
as we set callback to NULL and thus callback equality checking
will fail.

Callback is set to NULL to make it fired only one time probabaly.
Instead lets use connection equality to NULL to check if callback
is already fired.

Signed-off-by: Nikolay Shirokovskiy <nshirokovskiy@virtuozzo.com>
This commit is contained in:
Nikolay Shirokovskiy 2016-02-17 15:14:56 +03:00 committed by Daniel P. Berrange
parent a16cd9a6eb
commit 42b0f7510d

View File

@ -239,7 +239,7 @@ void virConnectCloseCallbackDataCall(virConnectCloseCallbackDataPtr close,
{ {
virObjectLock(close); virObjectLock(close);
if (!close->callback) if (!close->conn)
goto exit; goto exit;
VIR_DEBUG("Triggering connection close callback %p reason=%d, opaque=%p", VIR_DEBUG("Triggering connection close callback %p reason=%d, opaque=%p",
@ -248,7 +248,6 @@ void virConnectCloseCallbackDataCall(virConnectCloseCallbackDataPtr close,
if (close->freeCallback) if (close->freeCallback)
close->freeCallback(close->opaque); close->freeCallback(close->opaque);
close->callback = NULL;
close->freeCallback = NULL; close->freeCallback = NULL;
virObjectUnref(close->conn); virObjectUnref(close->conn);
close->conn = NULL; close->conn = NULL;