# HG changeset patch # User Roman Arutyunyan # Date 1615465338 -10800 # Node ID d62a16fff3a42d26cf0275f4b74f622e6b296342 # Parent 90ae21799f67c3d67c32033a10c1645653e7864b QUIC: do not reallocate c->sockaddr. When a connection is created, enough memory is allocated to accomodate any future address change. diff --git a/src/event/ngx_event_udp.c b/src/event/ngx_event_udp.c --- a/src/event/ngx_event_udp.c +++ b/src/event/ngx_event_udp.c @@ -24,6 +24,7 @@ static ngx_connection_t *ngx_lookup_udp_ void ngx_event_recvmsg(ngx_event_t *ev) { + size_t len; ssize_t n; ngx_str_t key; ngx_buf_t buf; @@ -302,7 +303,15 @@ ngx_event_recvmsg(ngx_event_t *ev) return; } - c->sockaddr = ngx_palloc(c->pool, socklen); + len = socklen; + +#if (NGX_QUIC) + if (ls->quic) { + len = NGX_SOCKADDRLEN; + } +#endif + + c->sockaddr = ngx_palloc(c->pool, len); if (c->sockaddr == NULL) { ngx_close_accepted_udp_connection(c); return; @@ -704,13 +713,6 @@ ngx_lookup_udp_connection(ngx_listening_ } #endif - if (c->socklen < socklen) { - c->sockaddr = ngx_palloc(c->pool, socklen); - if (c->sockaddr == NULL) { - return c; - } - } - ngx_memcpy(c->sockaddr, sockaddr, socklen); c->socklen = socklen; }