@@ -216,10 +216,12 @@ ncp_get_best_cipher(const char *server_list, const char *server_cipher,
const char *peer_info, const char *remote_cipher,
struct gc_arena *gc)
{
- const char *peer_ncp_list = tls_peer_ncp_list(peer_info, gc);
- char *tmp_ciphers = string_alloc(server_list, NULL);
- char *tmp_ciphers_orig = tmp_ciphers;
+ struct gc_arena gc_tmp = gc_new();
+
+ const char *peer_ncp_list = tls_peer_ncp_list(peer_info, &gc_tmp);
+
+ char *tmp_ciphers = string_alloc(server_list, &gc_tmp);
const char *token = strsep(&tmp_ciphers, ":");
while (token)
@@ -247,7 +249,7 @@ ncp_get_best_cipher(const char *server_list, const char *server_cipher,
ret = string_alloc(token, gc);
}
- free(tmp_ciphers_orig);
+ gc_free(&gc_tmp);
return ret;
}