mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-14 16:45:20 +00:00
conf: Remove console stream callback only when freeing console helper
Commit ba226d334acbc49f6751b430e0c4e00f69eef6bf tried to fix crash of the daemon when a domain with an open console was destroyed. The fix was wrong as it tried to remove the callback also when the stream was aborted, where at that point the fd stream driver was already freed and removed. This patch clears the callbacks with a helper right before the hash is freed, so that it doesn't interfere with other codepaths where the stream object is freed.
This commit is contained in:
parent
f8ef393ee3
commit
45edefc7a7
@ -219,9 +219,6 @@ static void virConsoleHashEntryFree(void *data,
|
|||||||
const char *pty = name;
|
const char *pty = name;
|
||||||
virStreamPtr st = data;
|
virStreamPtr st = data;
|
||||||
|
|
||||||
/* remove callback from stream */
|
|
||||||
virFDStreamSetInternalCloseCb(st, NULL, NULL, NULL);
|
|
||||||
|
|
||||||
/* free stream reference */
|
/* free stream reference */
|
||||||
virStreamFree(st);
|
virStreamFree(st);
|
||||||
|
|
||||||
@ -289,6 +286,18 @@ error:
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper to clear stream callbacks when freeing the hash
|
||||||
|
*/
|
||||||
|
static void virConsoleFreeClearCallbacks(void *payload,
|
||||||
|
const void *name ATTRIBUTE_UNUSED,
|
||||||
|
void *data ATTRIBUTE_UNUSED)
|
||||||
|
{
|
||||||
|
virStreamPtr st = payload;
|
||||||
|
|
||||||
|
virFDStreamSetInternalCloseCb(st, NULL, NULL, NULL);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Free structures for handling open console streams.
|
* Free structures for handling open console streams.
|
||||||
*
|
*
|
||||||
@ -300,6 +309,7 @@ void virConsoleFree(virConsolesPtr cons)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
virMutexLock(&cons->lock);
|
virMutexLock(&cons->lock);
|
||||||
|
virHashForEach(cons->hash, virConsoleFreeClearCallbacks, NULL);
|
||||||
virHashFree(cons->hash);
|
virHashFree(cons->hash);
|
||||||
virMutexUnlock(&cons->lock);
|
virMutexUnlock(&cons->lock);
|
||||||
virMutexDestroy(&cons->lock);
|
virMutexDestroy(&cons->lock);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user