]> git.ipfire.org Git - thirdparty/curl.git/commitdiff
quiche: clean up memory properly when failing to connect
authorDaniel Stenberg <daniel@haxx.se>
Mon, 25 May 2020 15:24:36 +0000 (17:24 +0200)
committerDaniel Stenberg <daniel@haxx.se>
Tue, 26 May 2020 08:15:18 +0000 (10:15 +0200)
Addresses the quiche side of #5447
Reported-by: Peter Wu
Closes #5450

lib/vquic/quiche.c

index 45c39925f511ef3f42d4113d766ce3faf77fd3e7..83815e037d21e192368b6c2f1c574de149d558f1 100644 (file)
@@ -89,18 +89,24 @@ static int quiche_perform_getsock(const struct connectdata *conn,
   return quiche_getsock((struct connectdata *)conn, socks);
 }
 
-static CURLcode quiche_disconnect(struct connectdata *conn,
-                                  bool dead_connection)
+static CURLcode qs_disconnect(struct quicsocket *qs)
 {
-  struct quicsocket *qs = conn->quic;
-  (void)dead_connection;
-  quiche_h3_config_free(qs->h3config);
-  quiche_h3_conn_free(qs->h3c);
+  if(qs->h3config)
+    quiche_h3_config_free(qs->h3config);
+  if(qs->h3c)
+    quiche_h3_conn_free(qs->h3c);
   quiche_config_free(qs->cfg);
   quiche_conn_free(qs->conn);
   return CURLE_OK;
 }
 
+static CURLcode quiche_disconnect(struct connectdata *conn,
+                                  bool dead_connection)
+{
+  struct quicsocket *qs = conn->quic;
+  (void)dead_connection;
+  return qs_disconnect(qs);
+}
 static unsigned int quiche_conncheck(struct connectdata *conn,
                                      unsigned int checks_to_perform)
 {
@@ -284,11 +290,11 @@ CURLcode Curl_quic_is_connected(struct connectdata *conn, int sockindex,
 
   result = process_ingress(conn, sockfd, qs);
   if(result)
-    return result;
+    goto error;
 
   result = flush_egress(conn, sockfd, qs);
   if(result)
-    return result;
+    goto error;
 
   if(quiche_conn_is_established(qs->conn)) {
     *done = TRUE;
@@ -297,6 +303,9 @@ CURLcode Curl_quic_is_connected(struct connectdata *conn, int sockindex,
   }
 
   return result;
+  error:
+  qs_disconnect(qs);
+  return result;
 }
 
 static CURLcode process_ingress(struct connectdata *conn, int sockfd,