MINOR: quic: Replace the RX unprotected packet list by a thread safety one.

This list is shared between the I/O dgram handler and the task responsible
for processing the QUIC packets inside.
diff --git a/include/haproxy/xprt_quic-t.h b/include/haproxy/xprt_quic-t.h
index 9bf5b40..da09d5a 100644
--- a/include/haproxy/xprt_quic-t.h
+++ b/include/haproxy/xprt_quic-t.h
@@ -394,7 +394,7 @@
 #define QUIC_FL_RX_PACKET_ACK_ELICITING (1UL << 0)
 
 struct quic_rx_packet {
-	struct list list;
+	struct mt_list list;
 	struct mt_list rx_list;
 	struct quic_conn *qc;
 	unsigned char type;
@@ -533,7 +533,7 @@
 		/* <pkts> must be protected from concurrent accesses */
 		__decl_thread(HA_RWLOCK_T rwlock);
 		/* Liste of QUIC packets with protected header. */
-		struct list pqpkts;
+		struct mt_list pqpkts;
 		/* Crypto frames */
 		struct {
 			uint64_t offset;
diff --git a/include/haproxy/xprt_quic.h b/include/haproxy/xprt_quic.h
index 65a2aa4..8a82b37 100644
--- a/include/haproxy/xprt_quic.h
+++ b/include/haproxy/xprt_quic.h
@@ -1100,17 +1100,17 @@
 }
 
 /* Add <pkt> RX packet to <list>, incrementing its reference counter. */
-static inline void quic_rx_packet_list_addq(struct list *list,
+static inline void quic_rx_packet_list_addq(struct mt_list *list,
                                             struct quic_rx_packet *pkt)
 {
-	LIST_APPEND(list, &pkt->list);
+	MT_LIST_APPEND(list, &pkt->list);
 	quic_rx_packet_refinc(pkt);
 }
 
 /* Remove <pkt> RX packet from <list>, decrementing its reference counter. */
 static inline void quic_rx_packet_list_del(struct quic_rx_packet *pkt)
 {
-	LIST_DELETE(&pkt->list);
+	MT_LIST_DELETE(&pkt->list);
 	quic_rx_packet_refdec(pkt);
 }
 
diff --git a/src/xprt_quic.c b/src/xprt_quic.c
index cb052b4..6b6c927 100644
--- a/src/xprt_quic.c
+++ b/src/xprt_quic.c
@@ -2369,7 +2369,8 @@
 static inline void qc_rm_hp_pkts(struct quic_enc_level *el, struct ssl_sock_ctx *ctx)
 {
 	struct quic_tls_ctx *tls_ctx;
-	struct quic_rx_packet *pqpkt, *qqpkt;
+	struct quic_rx_packet *pqpkt;
+	struct mt_list *pkttmp1, pkttmp2;
 	struct quic_enc_level *app_qel;
 
 	TRACE_ENTER(QUIC_EV_CONN_ELRMHP, ctx->conn);
@@ -2382,7 +2383,7 @@
 		goto out;
 	}
 	tls_ctx = &el->tls_ctx;
-	list_for_each_entry_safe(pqpkt, qqpkt, &el->rx.pqpkts, list) {
+	mt_list_for_each_entry_safe(pqpkt, &el->rx.pqpkts, list, pkttmp1, pkttmp2) {
 		if (!qc_do_rm_hp(pqpkt, tls_ctx, el->pktns->rx.largest_pn,
 		                 pqpkt->data + pqpkt->pn_offset,
 		                 pqpkt->data, pqpkt->data + pqpkt->len, ctx)) {
@@ -2399,7 +2400,8 @@
 			HA_RWLOCK_WRUNLOCK(QUIC_LOCK, &el->rx.rwlock);
 			TRACE_PROTO("hp removed", QUIC_EV_CONN_ELRMHP, ctx->conn, pqpkt);
 		}
-		quic_rx_packet_list_del(pqpkt);
+		MT_LIST_DELETE_SAFE(pkttmp1);
+		quic_rx_packet_refdec(pqpkt);
 	}
 
   out:
@@ -2529,7 +2531,7 @@
 	/* If the header protection key for this level has been derived,
 	 * remove the packet header protections.
 	 */
-	if (!LIST_ISEMPTY(&qel->rx.pqpkts) &&
+	if (!MT_LIST_ISEMPTY(&qel->rx.pqpkts) &&
 	    (tls_ctx->rx.flags & QUIC_FL_TLS_SECRETS_SET))
 		qc_rm_hp_pkts(qel, ctx);
 
@@ -2546,7 +2548,7 @@
 	/* Check if there is something to do for the next level.
 	 */
 	if ((next_qel->tls_ctx.rx.flags & QUIC_FL_TLS_SECRETS_SET) &&
-	    (!LIST_ISEMPTY(&next_qel->rx.pqpkts) || !eb_is_empty(&next_qel->rx.pkts))) {
+	    (!MT_LIST_ISEMPTY(&next_qel->rx.pqpkts) || !eb_is_empty(&next_qel->rx.pkts))) {
 		qel = next_qel;
 		goto next_level;
 	}
@@ -2619,7 +2621,7 @@
 
 	qel->rx.pkts = EB_ROOT;
 	HA_RWLOCK_INIT(&qel->rx.rwlock);
-	LIST_INIT(&qel->rx.pqpkts);
+	MT_LIST_INIT(&qel->rx.pqpkts);
 
 	/* Allocate only one buffer. */
 	qel->tx.crypto.bufs = malloc(sizeof *qel->tx.crypto.bufs);