mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-21 20:15:17 +00:00
tools: console: check if console was shutdown in callbacks
On error in main thread virConsoleShutdown is called which deletes fd watches/stream callback and yet callbacks can be called after. Thus we can incorrectly allocate terminalToStream.data memory and get memory leak for example. Let's check if console was shutdown in the very beginning of callbacks. Reviewed-by: Cole Robinson <crobinso@redhat.com> Signed-off-by: Nikolay Shirokovskiy <nshirokovskiy@virtuozzo.com>
This commit is contained in:
parent
cb7c1cddc5
commit
4525de7356
@ -139,6 +139,10 @@ virConsoleEventOnStream(virStreamPtr st,
|
||||
|
||||
virObjectLock(con);
|
||||
|
||||
/* we got late event after console was shutdown */
|
||||
if (!con->st)
|
||||
goto cleanup;
|
||||
|
||||
if (events & VIR_STREAM_EVENT_READABLE) {
|
||||
size_t avail = con->streamToTerminal.length -
|
||||
con->streamToTerminal.offset;
|
||||
@ -219,6 +223,10 @@ virConsoleEventOnStdin(int watch ATTRIBUTE_UNUSED,
|
||||
|
||||
virObjectLock(con);
|
||||
|
||||
/* we got late event after console was shutdown */
|
||||
if (!con->st)
|
||||
goto cleanup;
|
||||
|
||||
if (events & VIR_EVENT_HANDLE_READABLE) {
|
||||
size_t avail = con->terminalToStream.length -
|
||||
con->terminalToStream.offset;
|
||||
@ -279,6 +287,10 @@ virConsoleEventOnStdout(int watch ATTRIBUTE_UNUSED,
|
||||
|
||||
virObjectLock(con);
|
||||
|
||||
/* we got late event after console was shutdown */
|
||||
if (!con->st)
|
||||
goto cleanup;
|
||||
|
||||
if (events & VIR_EVENT_HANDLE_WRITABLE &&
|
||||
con->streamToTerminal.offset) {
|
||||
ssize_t done;
|
||||
|
Loading…
x
Reference in New Issue
Block a user