SPDY: fixed the DATA frame length handling in case of some errors.
There are a few cases in ngx_http_spdy_state_read_data() related to error
handling when ngx_http_spdy_state_skip() might be called with an inconsistent
state between *pos and sc->length, that leads to violation of frame layout
parsing and resuted in corruption of spdy connection.
Based on a patch by Xiaochen Wang.
diff --git a/src/http/ngx_http_spdy.c b/src/http/ngx_http_spdy.c
index 9c80feb..bada9c8 100644
--- a/src/http/ngx_http_spdy.c
+++ b/src/http/ngx_http_spdy.c
@@ -1528,7 +1528,6 @@
complete = 1;
} else {
- sc->length -= size;
complete = 0;
}
@@ -1571,6 +1570,8 @@
}
}
+ sc->length -= size;
+
if (tf) {
buf->start = pos;
buf->pos = pos;