diff options
| author | Daniel Stenberg <daniel@haxx.se> | 2017-02-13 10:35:18 +0100 | 
|---|---|---|
| committer | Daniel Stenberg <daniel@haxx.se> | 2017-02-13 10:35:18 +0100 | 
| commit | bde1e2e09b5371cadadc33294592d2bc8188f167 (patch) | |
| tree | ab315e2bb1348fa2277a51c806ffc4936fdce487 /lib | |
| parent | e1187c42a4b58f16343d2da653be00c36d930e16 (diff) | |
http2: fix memory-leak when denying push streams
Reported-by: zelinchen@users.noreply.github.com
Fixes #1229
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/http2.c | 30 | 
1 files changed, 19 insertions, 11 deletions
| diff --git a/lib/http2.c b/lib/http2.c index dc7bd32e1..af69c7224 100644 --- a/lib/http2.c +++ b/lib/http2.c @@ -116,18 +116,11 @@ static int http2_getsock(struct connectdata *conn,    return http2_perform_getsock(conn, sock, numsocks);  } -static CURLcode http2_disconnect(struct connectdata *conn, -                                 bool dead_connection) +/* + * http2_stream_free() free HTTP2 stream related data + */ +static void http2_stream_free(struct HTTP *http)  { -  struct HTTP *http = conn->data->req.protop; -  struct http_conn *c = &conn->proto.httpc; -  (void)dead_connection; - -  DEBUGF(infof(conn->data, "HTTP/2 DISCONNECT starts now\n")); - -  nghttp2_session_del(c->h2); -  Curl_safefree(c->inbuf); -    if(http) {      Curl_add_buffer_free(http->header_recvbuf);      http->header_recvbuf = NULL; /* clear the pointer */ @@ -139,6 +132,19 @@ static CURLcode http2_disconnect(struct connectdata *conn,      free(http->push_headers);      http->push_headers = NULL;    } +} + +static CURLcode http2_disconnect(struct connectdata *conn, +                                 bool dead_connection) +{ +  struct http_conn *c = &conn->proto.httpc; +  (void)dead_connection; + +  DEBUGF(infof(conn->data, "HTTP/2 DISCONNECT starts now\n")); + +  nghttp2_session_del(c->h2); +  Curl_safefree(c->inbuf); +  http2_stream_free(conn->data->req.protop);    DEBUGF(infof(conn->data, "HTTP/2 DISCONNECT done\n")); @@ -419,6 +425,7 @@ static int push_promise(struct Curl_easy *data,      if(rv) {        /* denied, kill off the new handle again */ +      http2_stream_free(newhandle->req.protop);        (void)Curl_close(newhandle);        goto fail;      } @@ -433,6 +440,7 @@ static int push_promise(struct Curl_easy *data,      rc = Curl_multi_add_perform(data->multi, newhandle, conn);      if(rc) {        infof(data, "failed to add handle to multi\n"); +      http2_stream_free(newhandle->req.protop);        Curl_close(newhandle);        rv = 1;        goto fail; | 
