[Spice-devel] [PATCH spice-server v2 03/13] red-stream: Avoid useless copy of mechlist
Frediano Ziglio
fziglio at redhat.com
Wed Dec 20 09:35:00 UTC 2017
The list will persist while the SASL connection is not disposed
(or another sasl_listmech called).
>From documentation:
* results:
* result -- NUL terminated result which persists until next
* call to sasl_listmech for this sasl_conn_t
Signed-off-by: Frediano Ziglio <fziglio at redhat.com>
---
server/red-stream.c | 7 +++----
1 file changed, 3 insertions(+), 4 deletions(-)
diff --git a/server/red-stream.c b/server/red-stream.c
index 3dbdfca82..bf2aff7a3 100644
--- a/server/red-stream.c
+++ b/server/red-stream.c
@@ -68,7 +68,7 @@ typedef struct RedSASL {
SpiceBuffer inbuffer;
- char *mechlist;
+ const char *mechlist;
char *mechname;
/* temporary data during authentication */
@@ -354,9 +354,7 @@ void red_stream_free(RedStream *s)
s->priv->sasl.len = 0;
s->priv->sasl.encodedLength = s->priv->sasl.encodedOffset = 0;
s->priv->sasl.encoded = NULL;
- g_free(s->priv->sasl.mechlist);
g_free(s->priv->sasl.mechname);
- s->priv->sasl.mechlist = NULL;
g_free(s->priv->sasl.data);
sasl_dispose(&s->priv->sasl.conn);
s->priv->sasl.conn = NULL;
@@ -1110,7 +1108,7 @@ bool red_sasl_start_auth(RedStream *stream, AsyncReadDone read_cb, void *opaque)
spice_debug("Available mechanisms for client: '%s'", mechlist);
- sasl->mechlist = g_strdup(mechlist);
+ sasl->mechlist = mechlist;
mechlistlen = strlen(mechlist);
if (!red_stream_write_all(stream, &mechlistlen, sizeof(uint32_t))
@@ -1126,6 +1124,7 @@ bool red_sasl_start_auth(RedStream *stream, AsyncReadDone read_cb, void *opaque)
return true;
error_dispose:
+ sasl->mechlist = NULL;
sasl_dispose(&sasl->conn);
sasl->conn = NULL;
error:
--
2.14.3
More information about the Spice-devel
mailing list