mirror of
https://github.com/nginx/nginx.git
synced 2025-02-25 18:55:26 -06:00
QUIC: changed ctx->largest_ack initial value to type maximum.
In particular, this prevents declaring packet number 0 as lost if there aren't yet any acknowledgements in this packet number space. For example, only Initial packets were acknowledged in handshake.
This commit is contained in:
parent
9a0fb643bf
commit
160242dd2e
@ -690,6 +690,7 @@ ngx_quic_new_connection(ngx_connection_t *c, ngx_ssl_t *ssl,
|
|||||||
ngx_queue_init(&qc->send_ctx[i].frames);
|
ngx_queue_init(&qc->send_ctx[i].frames);
|
||||||
ngx_queue_init(&qc->send_ctx[i].sent);
|
ngx_queue_init(&qc->send_ctx[i].sent);
|
||||||
qc->send_ctx[i].largest_pn = (uint64_t) -1;
|
qc->send_ctx[i].largest_pn = (uint64_t) -1;
|
||||||
|
qc->send_ctx[i].largest_ack = (uint64_t) -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < NGX_QUIC_ENCRYPTION_LAST; i++) {
|
for (i = 0; i < NGX_QUIC_ENCRYPTION_LAST; i++) {
|
||||||
@ -2346,7 +2347,7 @@ ngx_quic_handle_ack_frame(ngx_connection_t *c, ngx_quic_header_t *pkt,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* 13.2.3. Receiver Tracking of ACK Frames */
|
/* 13.2.3. Receiver Tracking of ACK Frames */
|
||||||
if (ctx->largest_ack < max) {
|
if (ctx->largest_ack < max || ctx->largest_ack == (uint64_t) -1) {
|
||||||
ctx->largest_ack = max;
|
ctx->largest_ack = max;
|
||||||
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, c->log, 0,
|
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, c->log, 0,
|
||||||
"quic updated largest received ack: %uL", max);
|
"quic updated largest received ack: %uL", max);
|
||||||
|
Loading…
Reference in New Issue
Block a user