BUG/MINOR: mux-quic: prevent a crash in session_free on mux.destroy
Implement qc_destroy. This callback is used to quickly release all MUX
resources.
session_free uses this callback. Currently, it can only be called if
there was an error during connection initialization. If not defined, the
process crashes.
diff --git a/src/mux_quic.c b/src/mux_quic.c
index 58e4759..a4ffe97 100644
--- a/src/mux_quic.c
+++ b/src/mux_quic.c
@@ -1057,6 +1057,15 @@
return -1;
}
+static void qc_destroy(void *ctx)
+{
+ struct qcc *qcc = ctx;
+
+ TRACE_ENTER(QMUX_EV_QCC_END, qcc->conn);
+ qc_release(qcc);
+ TRACE_LEAVE(QMUX_EV_QCC_END);
+}
+
static void qc_detach(struct conn_stream *cs)
{
struct qcs *qcs = __cs_mux(cs);
@@ -1346,6 +1355,7 @@
static const struct mux_ops qc_ops = {
.init = qc_init,
+ .destroy = qc_destroy,
.detach = qc_detach,
.rcv_buf = qc_rcv_buf,
.snd_buf = qc_snd_buf,