comparison src/event/quic/ngx_event_quic_socket.c @ 8911:b09f055daa4e quic

QUIC: fixed handling of RETIRE_CONNECTION_ID frame. Previously, the retired socket was not closed if it didn't match active or backup. New sockets could not be created (due to count limit), since retired socket was not closed before calling ngx_quic_create_sockets(). When replacing retired socket, new socket is only requested after closing old one, to avoid hitting the limit on the number of active connection ids. Together with added restrictions, this fixes an issue when a current socket could be closed during migration, recreated and erroneously reused leading to null pointer dereference.
author Vladimir Homutov <vl@nginx.com>
date Thu, 18 Nov 2021 14:19:36 +0300
parents 6d1488b62dc5
children aae8b91e0280
comparison
equal deleted inserted replaced
8910:f8848f5a1014 8911:b09f055daa4e
11 11
12 12
13 static ngx_int_t ngx_quic_create_temp_socket(ngx_connection_t *c, 13 static ngx_int_t ngx_quic_create_temp_socket(ngx_connection_t *c,
14 ngx_quic_connection_t *qc, ngx_str_t *dcid, ngx_quic_path_t *path, 14 ngx_quic_connection_t *qc, ngx_str_t *dcid, ngx_quic_path_t *path,
15 ngx_quic_client_id_t *cid); 15 ngx_quic_client_id_t *cid);
16
17 static void ngx_quic_unref_path(ngx_connection_t *c, ngx_quic_path_t *path);
18 16
19 17
20 ngx_int_t 18 ngx_int_t
21 ngx_quic_open_sockets(ngx_connection_t *c, ngx_quic_connection_t *qc, 19 ngx_quic_open_sockets(ngx_connection_t *c, ngx_quic_connection_t *qc,
22 ngx_quic_header_t *pkt) 20 ngx_quic_header_t *pkt)
205 "quic socket #%L closed nsock:%ui", 203 "quic socket #%L closed nsock:%ui",
206 (int64_t) qsock->sid.seqnum, qc->nsockets); 204 (int64_t) qsock->sid.seqnum, qc->nsockets);
207 } 205 }
208 206
209 207
210 static void 208 void
211 ngx_quic_unref_path(ngx_connection_t *c, ngx_quic_path_t *path) 209 ngx_quic_unref_path(ngx_connection_t *c, ngx_quic_path_t *path)
212 { 210 {
213 ngx_quic_connection_t *qc; 211 ngx_quic_connection_t *qc;
214 212
215 path->refcnt--; 213 path->refcnt--;