MINOR: quic: Do not try to accept a connection more than one time
We add a new flag to mark a connection as already enqueued for acception. This is useful for 0-RTT session where a connection is first enqueued for acception as soon as 0-RTT RX secrets could be derived. Then as for any other connection, we could accept one more time this connection after handshake completion which lead to very bad side effects. Thank you to Amaury for this nice patch.
This commit is contained in:
parent
298931d177
commit
91f083a365
@ -657,6 +657,8 @@ enum qc_mux_state {
|
|||||||
|
|
||||||
#define QUIC_FL_POST_HANDSHAKE_FRAMES_BUILT (1U << 2)
|
#define QUIC_FL_POST_HANDSHAKE_FRAMES_BUILT (1U << 2)
|
||||||
#define QUIC_FL_CONN_LISTENER (1U << 3)
|
#define QUIC_FL_CONN_LISTENER (1U << 3)
|
||||||
|
#define QUIC_FL_ACCEPT_REGISTERED_BIT 4
|
||||||
|
#define QUIC_FL_ACCEPT_REGISTERED (1U << QUIC_FL_ACCEPT_REGISTERED_BIT)
|
||||||
#define QUIC_FL_CONN_IMMEDIATE_CLOSE (1U << 31)
|
#define QUIC_FL_CONN_IMMEDIATE_CLOSE (1U << 31)
|
||||||
struct quic_conn {
|
struct quic_conn {
|
||||||
/* The quic_conn instance is refcounted as it can be used by threads
|
/* The quic_conn instance is refcounted as it can be used by threads
|
||||||
|
@ -255,13 +255,19 @@ void quic_sock_fd_iocb(int fd)
|
|||||||
struct quic_accept_queue *quic_accept_queues;
|
struct quic_accept_queue *quic_accept_queues;
|
||||||
|
|
||||||
/* Install <qc> on the queue ready to be accepted. The queue task is then woken
|
/* Install <qc> on the queue ready to be accepted. The queue task is then woken
|
||||||
* up.
|
* up. If <qc> accept is already scheduled or done, nothing is done.
|
||||||
*/
|
*/
|
||||||
void quic_accept_push_qc(struct quic_conn *qc)
|
void quic_accept_push_qc(struct quic_conn *qc)
|
||||||
{
|
{
|
||||||
struct quic_accept_queue *queue = &quic_accept_queues[qc->tid];
|
struct quic_accept_queue *queue = &quic_accept_queues[qc->tid];
|
||||||
struct li_per_thread *lthr = &qc->li->per_thr[qc->tid];
|
struct li_per_thread *lthr = &qc->li->per_thr[qc->tid];
|
||||||
|
|
||||||
|
/* early return if accept is already in progress/done for this
|
||||||
|
* connection
|
||||||
|
*/
|
||||||
|
if (HA_ATOMIC_BTS(&qc->flags, QUIC_FL_ACCEPT_REGISTERED_BIT))
|
||||||
|
return;
|
||||||
|
|
||||||
BUG_ON(MT_LIST_INLIST(&qc->accept_list));
|
BUG_ON(MT_LIST_INLIST(&qc->accept_list));
|
||||||
|
|
||||||
/* 1. insert the listener in the accept queue
|
/* 1. insert the listener in the accept queue
|
||||||
|
Loading…
x
Reference in New Issue
Block a user