summaryrefslogtreecommitdiff
path: root/lib/http2.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/http2.c')
-rw-r--r--lib/http2.c15
1 files changed, 7 insertions, 8 deletions
diff --git a/lib/http2.c b/lib/http2.c
index a1628ef44..cf19bcd19 100644
--- a/lib/http2.c
+++ b/lib/http2.c
@@ -1786,8 +1786,7 @@ static ssize_t h2_cf_recv(struct Curl_cfilter *cf, struct Curl_easy *data,
if(ctx->inbuflen == 0) {
/* Receive data from the "lower" filters */
nread = Curl_conn_cf_recv(cf->next, data, ctx->inbuf, H2_BUFSIZE, err);
-
- if(nread == -1) {
+ if(nread < 0) {
if(*err != CURLE_AGAIN)
failf(data, "Failed receiving HTTP2 data");
else if(stream->closed)
@@ -1796,8 +1795,7 @@ static ssize_t h2_cf_recv(struct Curl_cfilter *cf, struct Curl_easy *data,
return -1;
}
-
- if(nread == 0) {
+ else if(nread == 0) {
if(!stream->closed) {
/* This will happen when the server or proxy server is SIGKILLed
during data transfer. We should emit an error since our data
@@ -1814,21 +1812,22 @@ static ssize_t h2_cf_recv(struct Curl_cfilter *cf, struct Curl_easy *data,
return 0;
}
- H2BUGF(infof(data, "nread=%zd", nread));
-
+ H2BUGF(infof(data, "http2_recv: recvd %zd bytes", nread));
ctx->inbuflen = nread;
-
DEBUGASSERT(ctx->nread_inbuf == 0);
}
else {
nread = ctx->inbuflen - ctx->nread_inbuf;
- (void)nread; /* silence warning, used in debug */
H2BUGF(infof(data, "Use data left in connection buffer, nread=%zd",
nread));
}
if(h2_process_pending_input(cf, data, err))
return -1;
+ if(Curl_conn_cf_data_pending(cf->next, data)) {
+ H2BUGF(infof(data, "conn has pending data, set drain"));
+ drain_this(cf, data);
+ }
}
if(stream->memlen) {
ssize_t retlen = stream->memlen;