BUG/MEDIUM: h2: don't try (and fail) to send non-existing data in the mux
The call to xprt->snd_buf() was not conditionned on the presence of
data in the buffer, resulting in snd_buf() returning 0 and never
disabling the polling. It was revealed by the previous bug on error
processing but must properly be handled.
diff --git a/src/mux_h2.c b/src/mux_h2.c
index aea1f98..789f8ea 100644
--- a/src/mux_h2.c
+++ b/src/mux_h2.c
@@ -1987,7 +1987,7 @@
if (h2c->flags & (H2_CF_MUX_MFULL | H2_CF_DEM_MBUSY | H2_CF_DEM_MROOM))
flags |= CO_SFL_MSG_MORE;
- if (conn->xprt->snd_buf(conn, h2c->mbuf, flags) <= 0)
+ if (h2c->mbuf->o && conn->xprt->snd_buf(conn, h2c->mbuf, flags) <= 0)
break;
/* wrote at least one byte, the buffer is not full anymore */