diff options
| author | Roman Arutyunyan <arut@nginx.com> | 2022-04-20 16:01:17 +0400 |
|---|---|---|
| committer | Roman Arutyunyan <arut@nginx.com> | 2022-04-20 16:01:17 +0400 |
| commit | 9d81ef744cdaacf1e52bcaec4224d375af5ba59b (patch) | |
| tree | db3f8a9fc1381a2c848d934fd1c7f9bbaf1a9dca /src/event/quic/ngx_event_quic_migration.c | |
| parent | c24c27bb074b571fc9e9d75e19be31b83c69c253 (diff) | |
| download | nginx-9d81ef744cdaacf1e52bcaec4224d375af5ba59b.tar.gz nginx-9d81ef744cdaacf1e52bcaec4224d375af5ba59b.tar.bz2 | |
QUIC: separate UDP framework for QUIC.
Previously, QUIC used the existing UDP framework, which was created for UDP in
Stream. However the way QUIC connections are created and looked up is different
from the way UDP connections in Stream are created and looked up. Now these
two implementations are decoupled.
Diffstat (limited to 'src/event/quic/ngx_event_quic_migration.c')
| -rw-r--r-- | src/event/quic/ngx_event_quic_migration.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/src/event/quic/ngx_event_quic_migration.c b/src/event/quic/ngx_event_quic_migration.c index e07c53250..36a2af73c 100644 --- a/src/event/quic/ngx_event_quic_migration.c +++ b/src/event/quic/ngx_event_quic_migration.c @@ -264,7 +264,7 @@ ngx_quic_set_path(ngx_connection_t *c, ngx_quic_header_t *pkt) len = pkt->raw->last - pkt->raw->start; - if (c->udp->dgram == NULL) { + if (c->udp->buffer == NULL) { /* first ever packet in connection, path already exists */ path = qc->path; goto update; @@ -278,7 +278,7 @@ ngx_quic_set_path(ngx_connection_t *c, ngx_quic_header_t *pkt) { path = ngx_queue_data(q, ngx_quic_path_t, queue); - if (ngx_cmp_sockaddr(c->udp->dgram->sockaddr, c->udp->dgram->socklen, + if (ngx_cmp_sockaddr(&qsock->sockaddr.sockaddr, qsock->socklen, path->sockaddr, path->socklen, 1) == NGX_OK) { @@ -315,8 +315,7 @@ ngx_quic_set_path(ngx_connection_t *c, ngx_quic_header_t *pkt) return NGX_DONE; } - path = ngx_quic_new_path(c, c->udp->dgram->sockaddr, - c->udp->dgram->socklen, cid); + path = ngx_quic_new_path(c, &qsock->sockaddr.sockaddr, qsock->socklen, cid); if (path == NULL) { return NGX_ERROR; } |
