mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 00:03:54 -06:00
ui: convert VNC server to use QIOChannelSocket
The minimal first step conversion to use QIOChannelSocket classes instead of directly using POSIX sockets API. This will later be extended to also cover the TLS, SASL and websockets code. Reviewed-by: Gerd Hoffmann <kraxel@redhat.com> Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
This commit is contained in:
parent
18f49881cf
commit
04d2529da2
7 changed files with 435 additions and 328 deletions
|
@ -166,13 +166,16 @@ void vnc_jobs_consume_buffer(VncState *vs)
|
|||
|
||||
vnc_lock_output(vs);
|
||||
if (vs->jobs_buffer.offset) {
|
||||
if (vs->csock != -1 && buffer_empty(&vs->output)) {
|
||||
qemu_set_fd_handler(vs->csock, vnc_client_read,
|
||||
vnc_client_write, vs);
|
||||
if (vs->ioc != NULL && buffer_empty(&vs->output)) {
|
||||
if (vs->ioc_tag) {
|
||||
g_source_remove(vs->ioc_tag);
|
||||
}
|
||||
vs->ioc_tag = qio_channel_add_watch(
|
||||
vs->ioc, G_IO_IN | G_IO_OUT, vnc_client_io, vs, NULL);
|
||||
}
|
||||
buffer_move(&vs->output, &vs->jobs_buffer);
|
||||
}
|
||||
flush = vs->csock != -1 && vs->abort != true;
|
||||
flush = vs->ioc != NULL && vs->abort != true;
|
||||
vnc_unlock_output(vs);
|
||||
|
||||
if (flush) {
|
||||
|
@ -186,7 +189,8 @@ void vnc_jobs_consume_buffer(VncState *vs)
|
|||
static void vnc_async_encoding_start(VncState *orig, VncState *local)
|
||||
{
|
||||
buffer_init(&local->output, "vnc-worker-output");
|
||||
local->csock = -1; /* Don't do any network work on this thread */
|
||||
local->sioc = NULL; /* Don't do any network work on this thread */
|
||||
local->ioc = NULL; /* Don't do any network work on this thread */
|
||||
|
||||
local->vnc_encoding = orig->vnc_encoding;
|
||||
local->features = orig->features;
|
||||
|
@ -231,7 +235,7 @@ static int vnc_worker_thread_loop(VncJobQueue *queue)
|
|||
}
|
||||
|
||||
vnc_lock_output(job->vs);
|
||||
if (job->vs->csock == -1 || job->vs->abort == true) {
|
||||
if (job->vs->ioc == NULL || job->vs->abort == true) {
|
||||
vnc_unlock_output(job->vs);
|
||||
goto disconnected;
|
||||
}
|
||||
|
@ -259,7 +263,7 @@ static int vnc_worker_thread_loop(VncJobQueue *queue)
|
|||
QLIST_FOREACH_SAFE(entry, &job->rectangles, next, tmp) {
|
||||
int n;
|
||||
|
||||
if (job->vs->csock == -1) {
|
||||
if (job->vs->ioc == NULL) {
|
||||
vnc_unlock_display(job->vs->vd);
|
||||
/* Copy persistent encoding data */
|
||||
vnc_async_encoding_end(job->vs, &vs);
|
||||
|
@ -281,7 +285,7 @@ static int vnc_worker_thread_loop(VncJobQueue *queue)
|
|||
vs.output.buffer[saved_offset + 1] = n_rectangles & 0xFF;
|
||||
|
||||
vnc_lock_output(job->vs);
|
||||
if (job->vs->csock != -1) {
|
||||
if (job->vs->ioc != NULL) {
|
||||
buffer_move(&job->vs->jobs_buffer, &vs.output);
|
||||
/* Copy persistent encoding data */
|
||||
vnc_async_encoding_end(job->vs, &vs);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue