Add a new state that permits reconnection, because it's < CONNECTING. It also simplifies some code by removing unneeded variables in spice_channel_coroutine(): the channel.tls and session.protocol version properties are already modified during initial connection steps. --- gtk/spice-channel-priv.h | 1 + gtk/spice-channel.c | 19 ++++++++----------- 2 files changed, 9 insertions(+), 11 deletions(-) diff --git a/gtk/spice-channel-priv.h b/gtk/spice-channel-priv.h index 671e9fe..bd7f490 100644 --- a/gtk/spice-channel-priv.h +++ b/gtk/spice-channel-priv.h @@ -67,6 +67,7 @@ struct _SpiceMsgIn { enum spice_channel_state { SPICE_CHANNEL_STATE_UNCONNECTED = 0, SPICE_CHANNEL_STATE_FAILED_AUTHENTICATION, + SPICE_CHANNEL_STATE_RECONNECTING, SPICE_CHANNEL_STATE_CONNECTING, SPICE_CHANNEL_STATE_READY, SPICE_CHANNEL_STATE_SWITCHING, diff --git a/gtk/spice-channel.c b/gtk/spice-channel.c index 524a13e..4081e0b 100644 --- a/gtk/spice-channel.c +++ b/gtk/spice-channel.c @@ -1183,12 +1183,11 @@ static void spice_channel_send_link(SpiceChannel *channel) } /* coroutine context */ -static gboolean spice_channel_recv_link_hdr(SpiceChannel *channel, gboolean *switch_protocol) +static gboolean spice_channel_recv_link_hdr(SpiceChannel *channel) { SpiceChannelPrivate *c = channel->priv; int rc; - *switch_protocol = FALSE; rc = spice_channel_read(channel, &c->peer_hdr, sizeof(c->peer_hdr)); if (rc != sizeof(c->peer_hdr)) { g_warning("incomplete link header (%d/%" G_GSIZE_FORMAT ")", @@ -1221,7 +1220,7 @@ error: incompatible. Try with the oldest protocol in this case: */ if (c->link_hdr.major_version != 1) { SPICE_DEBUG("%s: error, switching to protocol 1 (spice 0.4)", c->name); - *switch_protocol = TRUE; + c->state = SPICE_CHANNEL_STATE_RECONNECTING; g_object_set(c->session, "protocol", 1, NULL); return FALSE; } @@ -1680,7 +1679,7 @@ cleanup: #endif /* HAVE_SASL */ /* coroutine context */ -static gboolean spice_channel_recv_link_msg(SpiceChannel *channel, gboolean *switch_tls) +static gboolean spice_channel_recv_link_msg(SpiceChannel *channel) { SpiceChannelPrivate *c; int rc, num_caps, i; @@ -1705,8 +1704,9 @@ static gboolean spice_channel_recv_link_msg(SpiceChannel *channel, gboolean *swi /* nothing */ break; case SPICE_LINK_ERR_NEED_SECURED: - *switch_tls = true; + c->state = SPICE_CHANNEL_STATE_RECONNECTING; CHANNEL_DEBUG(channel, "switching to tls"); + c->tls = TRUE; return FALSE; default: g_warning("%s: %s: unhandled error %d", @@ -2280,8 +2280,6 @@ static void *spice_channel_coroutine(void *data) SpiceChannelPrivate *c = channel->priv; guint verify; int rc, delay_val = 1; - gboolean switch_tls = FALSE; - gboolean switch_protocol = FALSE; /* When some other SSL/TLS version becomes obsolete, add it to this * variable. */ long ssl_options = SSL_OP_NO_SSLv2 | SSL_OP_NO_SSLv3; @@ -2415,8 +2413,8 @@ connected: } spice_channel_send_link(channel); - if (!spice_channel_recv_link_hdr(channel, &switch_protocol) || - !spice_channel_recv_link_msg(channel, &switch_tls) || + if (!spice_channel_recv_link_hdr(channel) || + !spice_channel_recv_link_msg(channel) || !spice_channel_recv_auth(channel)) goto cleanup; @@ -2428,8 +2426,7 @@ cleanup: SPICE_CHANNEL_GET_CLASS(channel)->channel_disconnect(channel); - if (switch_protocol || (switch_tls && !c->tls)) { - c->tls = switch_tls; + if (c->state == SPICE_CHANNEL_STATE_RECONNECTING) { spice_channel_connect(channel); g_object_unref(channel); } else -- 2.1.0 _______________________________________________ Spice-devel mailing list Spice-devel@xxxxxxxxxxxxxxxxxxxxx http://lists.freedesktop.org/mailman/listinfo/spice-devel