MEDIUM: mux-pt: Don't always set a final error on SE on the sending path
SE_FL_ERROR must be set on the SE descriptor only if EOS was already
reported. So call se_fl_set_error() function to properly the
ERR_PENDING/ERROR flags. It is not really a bug because the mux-pt is really
simple. But it is better to do it now the right way.
diff --git a/src/mux_pt.c b/src/mux_pt.c
index baa67ce..86a1f23 100644
--- a/src/mux_pt.c
+++ b/src/mux_pt.c
@@ -557,7 +557,7 @@
b_del(buf, ret);
if (conn->flags & CO_FL_ERROR) {
- se_fl_set(ctx->sd, SE_FL_ERROR);
+ se_fl_set_error(ctx->sd);
TRACE_DEVEL("error on connection", PT_EV_TX_DATA|PT_EV_CONN_ERR, conn, sc);
}
@@ -625,7 +625,7 @@
ret = conn->xprt->snd_pipe(conn, conn->xprt_ctx, pipe);
if (conn->flags & CO_FL_ERROR) {
- se_fl_set(ctx->sd, SE_FL_ERROR);
+ se_fl_set_error(ctx->sd);
TRACE_DEVEL("error on connection", PT_EV_TX_DATA|PT_EV_CONN_ERR, conn, sc);
}