diff options
author | Daniel Stenberg <daniel@haxx.se> | 2018-07-20 23:24:47 +0200 |
---|---|---|
committer | Daniel Stenberg <daniel@haxx.se> | 2018-07-22 21:17:27 +0200 |
commit | 81377cace6a047308008d36740042231d6c7d122 (patch) | |
tree | d5bda7d76db96ccabc3b6e092eaab6924a1a3509 | |
parent | 6d13432bfa1097da7efb4a5fffac27a22af2002c (diff) |
vtls: set conn->data when closing TLS
Follow-up to 1b76c38904f0. The VTLS backends that close down the TLS
layer for a connection still needs a Curl_easy handle for the session_id
cache etc.
Fixes #2764
Closes #2771
-rw-r--r-- | lib/conncache.c | 1 | ||||
-rw-r--r-- | lib/url.c | 4 |
2 files changed, 4 insertions, 1 deletions
diff --git a/lib/conncache.c b/lib/conncache.c index 957ced3c7..6fbf3b1d2 100644 --- a/lib/conncache.c +++ b/lib/conncache.c @@ -314,7 +314,6 @@ void Curl_conncache_remove_conn(struct connectdata *conn, bool lock) if(lock) { CONN_LOCK(data); } - conn->data = NULL; /* detach */ bundle_remove_conn(bundle, conn); if(bundle->num_connections == 0) conncache_remove_bundle(connc, bundle); @@ -788,6 +788,9 @@ CURLcode Curl_disconnect(struct Curl_easy *data, free_fixed_hostname(&conn->http_proxy.host); free_fixed_hostname(&conn->socks_proxy.host); + DEBUGASSERT(conn->data == data); + /* this assumes that the pointer is still there after the connection was + detected from the cache */ Curl_ssl_close(conn, FIRSTSOCKET); conn_free(conn); @@ -969,6 +972,7 @@ static bool extract_if_dead(struct connectdata *conn, if(dead) { infof(data, "Connection %ld seems to be dead!\n", conn->connection_id); Curl_conncache_remove_conn(conn, FALSE); + conn->data = NULL; /* detach */ return TRUE; } } |