This reverts commit
44932b6c417e472d25039ec3d7b8bf14e07629bc.
The patch above was only necessary to handle partial headers or trailers
parsing. There was nothing to prevent the H2 multiplexer to start to add
headers or trailers in an HTX message and to stop the processing on error,
leaving the HTX message with no EOH/EOT block.
From the HTX API point of view, it is unexepected. And this was fixed thanks
to the commit
ba7dc46a9 ("BUG/MINOR: h2/h3: Never insert partial
headers/trailers in an HTX message").
So this patch can be reverted. It is important to not report a parsign error
too early, when there are still data to transfer to the upper layer.
This patch must be backport where
44932b6c4 was backported but only after
backporting
ba7dc46a9 first.
/* tell the stream layer whether there are data left or not */
if (h2s_rxbuf_cnt(h2s)) {
- /* Note that parsing errors can also arrive here, we may need
- * to propagate errors upstream otherwise no new activity will
- * unblock them.
- */
se_fl_set(h2s->sd, SE_FL_RCV_MORE | SE_FL_WANT_ROOM);
- if (h2s_htx && h2s_htx->flags & HTX_FL_PARSING_ERROR)
- h2s_propagate_term_flags(h2c, h2s);
BUG_ON_HOT(!buf->data);
}
else {