From: Jonathon Jongsma <jjongsma@xxxxxxxxxx> Move them into the RedsState struct, adjust functions that use these variables to take a RedsState arg. --- server/reds-private.h | 5 +++++ server/reds.c | 27 ++++++++++++--------------- 2 files changed, 17 insertions(+), 15 deletions(-) diff --git a/server/reds-private.h b/server/reds-private.h index 9d67427..63e856e 100644 --- a/server/reds-private.h +++ b/server/reds-private.h @@ -135,6 +135,8 @@ typedef struct RedsClientMonitorsConfig { int buffer_pos; } RedsClientMonitorsConfig; +typedef struct ChannelSecurityOptions ChannelSecurityOptions; + struct RedsState { int listen_socket; int secure_listen_socket; @@ -190,6 +192,9 @@ struct RedsState { RedsClientMonitorsConfig client_monitors_config; int mm_time_enabled; uint32_t mm_time_latency; + + int default_channel_security; + ChannelSecurityOptions *channels_security; }; #endif diff --git a/server/reds.c b/server/reds.c index 8b17a76..5804d13 100644 --- a/server/reds.c +++ b/server/reds.c @@ -196,7 +196,6 @@ typedef struct RedSSLParameters { char ciphersuite[256]; } RedSSLParameters; -typedef struct ChannelSecurityOptions ChannelSecurityOptions; struct ChannelSecurityOptions { uint32_t channel_id; uint32_t options; @@ -216,15 +215,11 @@ static VDIReadBuf *vdi_port_read_buf_get(RedsState *reds); static VDIReadBuf *vdi_port_read_buf_ref(VDIReadBuf *buf); static void vdi_port_read_buf_unref(RedsState *reds, VDIReadBuf *buf); -static ChannelSecurityOptions *channels_security = NULL; -static int default_channel_security = - SPICE_CHANNEL_SECURITY_NONE | SPICE_CHANNEL_SECURITY_SSL; - static RedSSLParameters ssl_parameters; -static ChannelSecurityOptions *find_channel_security(int id) +static ChannelSecurityOptions *reds_find_channel_security(RedsState *reds, int id) { - ChannelSecurityOptions *now = channels_security; + ChannelSecurityOptions *now = reds->channels_security; while (now && now->channel_id != id) { now = now->next; } @@ -2151,8 +2146,8 @@ static void reds_handle_auth_mechanism(void *opaque) static int reds_security_check(RedLinkInfo *link) { - ChannelSecurityOptions *security_option = find_channel_security(link->link_mess->channel_type); - uint32_t security = security_option ? security_option->options : default_channel_security; + ChannelSecurityOptions *security_option = reds_find_channel_security(reds, link->link_mess->channel_type); + uint32_t security = security_option ? security_option->options : reds->default_channel_security; return (reds_stream_is_ssl(link->stream) && (security & SPICE_CHANNEL_SECURITY_SSL)) || (!reds_stream_is_ssl(link->stream) && (security & SPICE_CHANNEL_SECURITY_NONE)); } @@ -2804,19 +2799,19 @@ static void set_image_compression(SpiceImageCompression val) red_dispatcher_on_ic_change(); } -static void set_one_channel_security(int id, uint32_t security) +static void reds_set_one_channel_security(RedsState *reds, int id, uint32_t security) { ChannelSecurityOptions *security_options; - if ((security_options = find_channel_security(id))) { + if ((security_options = reds_find_channel_security(reds, id))) { security_options->options = security; return; } security_options = spice_new(ChannelSecurityOptions, 1); security_options->channel_id = id; security_options->options = security; - security_options->next = channels_security; - channels_security = security_options; + security_options->next = reds->channels_security; + reds->channels_security = security_options; } #define REDS_SAVE_VERSION 1 @@ -3447,6 +3442,8 @@ SPICE_GNUC_VISIBLE SpiceServer *spice_server_new(void) spice_assert(reds == NULL); reds = spice_new0(RedsState, 1); + reds->default_channel_security = + SPICE_CHANNEL_SECURITY_NONE | SPICE_CHANNEL_SECURITY_SSL; return reds; } @@ -3745,12 +3742,12 @@ SPICE_GNUC_VISIBLE int spice_server_set_channel_security(SpiceServer *s, const c spice_assert(reds == s); if (channel == NULL) { - default_channel_security = security; + s->default_channel_security = security; return 0; } for (i = 0; i < SPICE_N_ELEMENTS(names); i++) { if (names[i] && strcmp(names[i], channel) == 0) { - set_one_channel_security(i, security); + reds_set_one_channel_security(s, i, security); return 0; } } -- 2.4.3 _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/spice-devel