#include <haproxy/api.h>
#include <haproxy/connection.h>
#include <haproxy/mux_quic-t.h>
+#include <haproxy/stream.h>
#include <haproxy/xprt_quic-t.h>
struct qcs *qcs_new(struct qcc *qcc, uint64_t id, enum qcs_type type);
return eb64_entry(node, struct qc_stream_desc, by_id);
}
+static inline struct conn_stream *qc_attach_cs(struct qcs *qcs, struct buffer *buf)
+{
+ struct conn_stream *cs = cs_new();
+ if (!cs)
+ return NULL;
+ cs_attach_endp(cs, &qcs->qcc->conn->obj_type, qcs);
+
+ cs->ctx = qcs;
+ stream_new(qcs->qcc->conn->owner, cs, buf);
+
+ return cs;
+}
+
#endif /* USE_QUIC */
#endif /* _HAPROXY_MUX_QUIC_H */
#include <haproxy/http.h>
#include <haproxy/htx.h>
#include <haproxy/istbuf.h>
-#include <haproxy/mux_quic-t.h>
+#include <haproxy/mux_quic.h>
#include <haproxy/pool.h>
#include <haproxy/qpack-dec.h>
#include <haproxy/qpack-enc.h>
#include <haproxy/quic_enc.h>
-#include <haproxy/stream.h>
#include <haproxy/tools.h>
#include <haproxy/xprt_quic.h>
if (fin)
htx->flags |= HTX_FL_EOM;
- cs = cs_new();
+ cs = qc_attach_cs(qcs, &htx_buf);
if (!cs)
return 1;
- cs_attach_endp(cs, &qcs->qcc->conn->obj_type, qcs);
-
cs->flags |= CS_FL_NOT_FIRST;
- cs->ctx = qcs;
- stream_new(qcs->qcc->conn->owner, cs, &htx_buf);
/* buffer is transferred to conn_stream and set to NULL
* except on stream creation error.
#include <haproxy/dynbuf.h>
#include <haproxy/htx.h>
#include <haproxy/http.h>
-#include <haproxy/mux_quic-t.h>
-#include <haproxy/stream.h>
+#include <haproxy/mux_quic.h>
static int hq_interop_decode_qcs(struct qcs *qcs, int fin, void *ctx)
{
htx_add_endof(htx, HTX_BLK_EOH);
htx_to_buf(htx, &htx_buf);
- cs = cs_new();
+ cs = qc_attach_cs(qcs, &htx_buf);
if (!cs)
return -1;
- cs_attach_endp(cs, &qcs->qcc->conn->obj_type, qcs);
- cs->ctx = qcs;
- stream_new(qcs->qcc->conn->owner, cs, &htx_buf);
b_del(rxbuf, b_data(rxbuf));
b_free(&htx_buf);