From da6618681c0926003df2f197d60c541285dbfa37 Mon Sep 17 00:00:00 2001 From: Jonathon Jongsma Date: Tue, 27 Jan 2015 14:15:07 -0600 Subject: [PATCH] Move jpeg_state to RedsState struct Also required adding reds_get_jpeg_state() for external access. Acked-by: Frediano Ziglio --- server/red-worker.c | 2 +- server/reds-private.h | 1 + server/reds.c | 9 +++++++-- server/reds.h | 2 +- 4 files changed, 10 insertions(+), 4 deletions(-) diff --git a/server/red-worker.c b/server/red-worker.c index f98b2f47..f6c4f457 100644 --- a/server/red-worker.c +++ b/server/red-worker.c @@ -1507,7 +1507,7 @@ RedWorker* red_worker_new(QXLInstance *qxl, RedDispatcher *red_dispatcher) } worker->image_compression = spice_server_get_image_compression(reds); - worker->jpeg_state = jpeg_state; + worker->jpeg_state = reds_get_jpeg_state(reds); worker->zlib_glz_state = zlib_glz_state; worker->driver_cap_monitors_config = 0; #ifdef RED_STATISTICS diff --git a/server/reds-private.h b/server/reds-private.h index fd2aa102..9028f6a5 100644 --- a/server/reds-private.h +++ b/server/reds-private.h @@ -215,6 +215,7 @@ struct RedsState { uint8_t spice_uuid[16]; SpiceImageCompression image_compression; + spice_wan_compression_t jpeg_state; }; #endif diff --git a/server/reds.c b/server/reds.c index 74dd033e..9ec80f21 100644 --- a/server/reds.c +++ b/server/reds.c @@ -148,7 +148,6 @@ static int ticketing_enabled = 1; //Ticketing is enabled by default static pthread_mutex_t *lock_cs; static long *lock_count; uint32_t streaming_video = SPICE_STREAM_VIDEO_FILTER; -spice_wan_compression_t jpeg_state = SPICE_WAN_COMPRESSION_AUTO; spice_wan_compression_t zlib_glz_state = SPICE_WAN_COMPRESSION_AUTO; int agent_mouse = TRUE; int agent_copypaste = TRUE; @@ -3422,6 +3421,7 @@ SPICE_GNUC_VISIBLE SpiceServer *spice_server_new(void) reds->spice_uuid_is_set = FALSE; memset(reds->spice_uuid, 0, sizeof(reds->spice_uuid)); reds->image_compression = SPICE_IMAGE_COMPRESSION_AUTO_GLZ; + reds->jpeg_state = SPICE_WAN_COMPRESSION_AUTO; return reds; } @@ -3686,7 +3686,7 @@ SPICE_GNUC_VISIBLE int spice_server_set_jpeg_compression(SpiceServer *s, spice_w return -1; } // todo: support dynamically changing the state - jpeg_state = comp; + s->jpeg_state = comp; return 0; } @@ -4008,3 +4008,8 @@ SPICE_GNUC_VISIBLE void spice_server_set_keepalive_timeout(SpiceServer *s, int t reds->keepalive_timeout = timeout; spice_debug("keepalive timeout=%d", timeout); } + +spice_wan_compression_t reds_get_jpeg_state(const RedsState *reds) +{ + return reds->jpeg_state; +} diff --git a/server/reds.h b/server/reds.h index 27bf90b1..0cc6ec74 100644 --- a/server/reds.h +++ b/server/reds.h @@ -75,7 +75,6 @@ extern uint32_t num_renderers; extern struct SpiceCoreInterfaceInternal *core; extern uint32_t streaming_video; -extern spice_wan_compression_t jpeg_state; extern spice_wan_compression_t zlib_glz_state; // Temporary measures to make splitting reds.c to inputs-channel.c easier @@ -113,5 +112,6 @@ void reds_on_main_channel_migrate(RedsState *reds, MainChannelClient *mcc); void reds_on_char_device_state_destroy(RedsState *reds, SpiceCharDeviceState *dev); void reds_set_client_mm_time_latency(RedsState *reds, RedClient *client, uint32_t latency); +spice_wan_compression_t reds_get_jpeg_state(const RedsState *reds); #endif