mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-22 04:25:18 +00:00
tools: console: add missing locks in callbacks
Stream/fd callbacks accessing console object are called from the event loop thread and the console object is also accessed from the main thread so we are better add locking to handlers. Reviewed-by: Cole Robinson <crobinso@redhat.com> Signed-off-by: Nikolay Shirokovskiy <nshirokovskiy@virtuozzo.com>
This commit is contained in:
parent
cbd9e3624d
commit
cb7c1cddc5
@ -137,6 +137,8 @@ virConsoleEventOnStream(virStreamPtr st,
|
|||||||
{
|
{
|
||||||
virConsolePtr con = opaque;
|
virConsolePtr con = opaque;
|
||||||
|
|
||||||
|
virObjectLock(con);
|
||||||
|
|
||||||
if (events & VIR_STREAM_EVENT_READABLE) {
|
if (events & VIR_STREAM_EVENT_READABLE) {
|
||||||
size_t avail = con->streamToTerminal.length -
|
size_t avail = con->streamToTerminal.length -
|
||||||
con->streamToTerminal.offset;
|
con->streamToTerminal.offset;
|
||||||
@ -146,7 +148,7 @@ virConsoleEventOnStream(virStreamPtr st,
|
|||||||
if (VIR_REALLOC_N(con->streamToTerminal.data,
|
if (VIR_REALLOC_N(con->streamToTerminal.data,
|
||||||
con->streamToTerminal.length + 1024) < 0) {
|
con->streamToTerminal.length + 1024) < 0) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
con->streamToTerminal.length += 1024;
|
con->streamToTerminal.length += 1024;
|
||||||
avail += 1024;
|
avail += 1024;
|
||||||
@ -157,10 +159,10 @@ virConsoleEventOnStream(virStreamPtr st,
|
|||||||
con->streamToTerminal.offset,
|
con->streamToTerminal.offset,
|
||||||
avail);
|
avail);
|
||||||
if (got == -2)
|
if (got == -2)
|
||||||
return; /* blocking */
|
goto cleanup; /* blocking */
|
||||||
if (got <= 0) {
|
if (got <= 0) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
con->streamToTerminal.offset += got;
|
con->streamToTerminal.offset += got;
|
||||||
if (con->streamToTerminal.offset)
|
if (con->streamToTerminal.offset)
|
||||||
@ -176,10 +178,10 @@ virConsoleEventOnStream(virStreamPtr st,
|
|||||||
con->terminalToStream.data,
|
con->terminalToStream.data,
|
||||||
con->terminalToStream.offset);
|
con->terminalToStream.offset);
|
||||||
if (done == -2)
|
if (done == -2)
|
||||||
return; /* blocking */
|
goto cleanup; /* blocking */
|
||||||
if (done < 0) {
|
if (done < 0) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
memmove(con->terminalToStream.data,
|
memmove(con->terminalToStream.data,
|
||||||
con->terminalToStream.data + done,
|
con->terminalToStream.data + done,
|
||||||
@ -201,6 +203,9 @@ virConsoleEventOnStream(virStreamPtr st,
|
|||||||
events & VIR_STREAM_EVENT_HANGUP) {
|
events & VIR_STREAM_EVENT_HANGUP) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
virObjectUnlock(con);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -212,6 +217,8 @@ virConsoleEventOnStdin(int watch ATTRIBUTE_UNUSED,
|
|||||||
{
|
{
|
||||||
virConsolePtr con = opaque;
|
virConsolePtr con = opaque;
|
||||||
|
|
||||||
|
virObjectLock(con);
|
||||||
|
|
||||||
if (events & VIR_EVENT_HANDLE_READABLE) {
|
if (events & VIR_EVENT_HANDLE_READABLE) {
|
||||||
size_t avail = con->terminalToStream.length -
|
size_t avail = con->terminalToStream.length -
|
||||||
con->terminalToStream.offset;
|
con->terminalToStream.offset;
|
||||||
@ -221,7 +228,7 @@ virConsoleEventOnStdin(int watch ATTRIBUTE_UNUSED,
|
|||||||
if (VIR_REALLOC_N(con->terminalToStream.data,
|
if (VIR_REALLOC_N(con->terminalToStream.data,
|
||||||
con->terminalToStream.length + 1024) < 0) {
|
con->terminalToStream.length + 1024) < 0) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
con->terminalToStream.length += 1024;
|
con->terminalToStream.length += 1024;
|
||||||
avail += 1024;
|
avail += 1024;
|
||||||
@ -234,15 +241,15 @@ virConsoleEventOnStdin(int watch ATTRIBUTE_UNUSED,
|
|||||||
if (got < 0) {
|
if (got < 0) {
|
||||||
if (errno != EAGAIN)
|
if (errno != EAGAIN)
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
if (got == 0) {
|
if (got == 0) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
if (con->terminalToStream.data[con->terminalToStream.offset] == con->escapeChar) {
|
if (con->terminalToStream.data[con->terminalToStream.offset] == con->escapeChar) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
con->terminalToStream.offset += got;
|
con->terminalToStream.offset += got;
|
||||||
@ -256,6 +263,9 @@ virConsoleEventOnStdin(int watch ATTRIBUTE_UNUSED,
|
|||||||
events & VIR_EVENT_HANDLE_HANGUP) {
|
events & VIR_EVENT_HANDLE_HANGUP) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
virObjectUnlock(con);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -267,6 +277,8 @@ virConsoleEventOnStdout(int watch ATTRIBUTE_UNUSED,
|
|||||||
{
|
{
|
||||||
virConsolePtr con = opaque;
|
virConsolePtr con = opaque;
|
||||||
|
|
||||||
|
virObjectLock(con);
|
||||||
|
|
||||||
if (events & VIR_EVENT_HANDLE_WRITABLE &&
|
if (events & VIR_EVENT_HANDLE_WRITABLE &&
|
||||||
con->streamToTerminal.offset) {
|
con->streamToTerminal.offset) {
|
||||||
ssize_t done;
|
ssize_t done;
|
||||||
@ -277,7 +289,7 @@ virConsoleEventOnStdout(int watch ATTRIBUTE_UNUSED,
|
|||||||
if (done < 0) {
|
if (done < 0) {
|
||||||
if (errno != EAGAIN)
|
if (errno != EAGAIN)
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
return;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
memmove(con->streamToTerminal.data,
|
memmove(con->streamToTerminal.data,
|
||||||
con->streamToTerminal.data + done,
|
con->streamToTerminal.data + done,
|
||||||
@ -299,6 +311,9 @@ virConsoleEventOnStdout(int watch ATTRIBUTE_UNUSED,
|
|||||||
events & VIR_EVENT_HANDLE_HANGUP) {
|
events & VIR_EVENT_HANDLE_HANGUP) {
|
||||||
virConsoleShutdown(con);
|
virConsoleShutdown(con);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cleanup:
|
||||||
|
virObjectUnlock(con);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user