mirror of
https://github.com/nginx/nginx.git
synced 2024-12-13 11:09:06 +08:00
QUIC: single function for frame debug logging.
The function may be called for any initialized frame, both rx and tx. While there, shortened level names.
This commit is contained in:
parent
83d7a949e8
commit
528e5bd1fb
@ -51,9 +51,9 @@
|
|||||||
#define NGX_QUIC_MAX_ACK_GAP 2
|
#define NGX_QUIC_MAX_ACK_GAP 2
|
||||||
|
|
||||||
#define ngx_quic_level_name(lvl) \
|
#define ngx_quic_level_name(lvl) \
|
||||||
(lvl == ssl_encryption_application) ? "application" \
|
(lvl == ssl_encryption_application) ? "app" \
|
||||||
: (lvl == ssl_encryption_initial) ? "initial" \
|
: (lvl == ssl_encryption_initial) ? "init" \
|
||||||
: (lvl == ssl_encryption_handshake) ? "handshake" : "early_data"
|
: (lvl == ssl_encryption_handshake) ? "hs" : "early"
|
||||||
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@ -366,6 +366,198 @@ static SSL_QUIC_METHOD quic_method = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
#if (NGX_DEBUG)
|
||||||
|
|
||||||
|
static void
|
||||||
|
ngx_quic_log_frame(ngx_log_t *log, ngx_quic_frame_t *f, ngx_uint_t tx)
|
||||||
|
{
|
||||||
|
u_char *p, *last, *pos, *end;
|
||||||
|
ssize_t n;
|
||||||
|
uint64_t gap, range;
|
||||||
|
ngx_uint_t i;
|
||||||
|
ngx_quic_ack_range_t *ranges;
|
||||||
|
u_char buf[NGX_MAX_ERROR_STR];
|
||||||
|
|
||||||
|
p = buf;
|
||||||
|
last = buf + sizeof(buf);
|
||||||
|
|
||||||
|
switch (f->type) {
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_CRYPTO:
|
||||||
|
p = ngx_slprintf(p, last, "CRYPTO len:%uL off:%uL",
|
||||||
|
f->u.crypto.length, f->u.crypto.offset);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_PADDING:
|
||||||
|
p = ngx_slprintf(p, last, "PADDING");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_ACK:
|
||||||
|
case NGX_QUIC_FT_ACK_ECN:
|
||||||
|
|
||||||
|
p = ngx_slprintf(p, last,
|
||||||
|
"ACK largest:%uL fr:%uL nranges:%ui delay:%uL",
|
||||||
|
f->u.ack.largest, f->u.ack.first_range,
|
||||||
|
f->u.ack.range_count, f->u.ack.delay);
|
||||||
|
|
||||||
|
if (tx) {
|
||||||
|
ranges = (ngx_quic_ack_range_t *) f->u.ack.ranges_start;
|
||||||
|
|
||||||
|
for (i = 0; i < f->u.ack.range_count; i++) {
|
||||||
|
p = ngx_slprintf(p, last, " %uL,%uL",
|
||||||
|
ranges[i].gap, ranges[i].range);
|
||||||
|
}
|
||||||
|
|
||||||
|
} else {
|
||||||
|
pos = f->u.ack.ranges_start;
|
||||||
|
end = f->u.ack.ranges_end;
|
||||||
|
|
||||||
|
for (i = 0; i < f->u.ack.range_count; i++) {
|
||||||
|
n = ngx_quic_parse_ack_range(log, pos, end, &gap, &range);
|
||||||
|
if (n == NGX_ERROR) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
pos += n;
|
||||||
|
|
||||||
|
p = ngx_slprintf(p, last, " %uL,%uL", gap, range);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (f->type == NGX_QUIC_FT_ACK_ECN) {
|
||||||
|
p = ngx_slprintf(p, last, " ECN counters ect0:%uL ect1:%uL ce:%uL",
|
||||||
|
f->u.ack.ect0, f->u.ack.ect1, f->u.ack.ce);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_PING:
|
||||||
|
p = ngx_slprintf(p, last, "PING");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_NEW_CONNECTION_ID:
|
||||||
|
p = ngx_slprintf(p, last, "NCID seq:%uL retire:%uL len:%ud",
|
||||||
|
f->u.ncid.seqnum, f->u.ncid.retire, f->u.ncid.len);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_RETIRE_CONNECTION_ID:
|
||||||
|
p = ngx_slprintf(p, last, "RETIRE_CONNECTION_ID seqnum:%uL",
|
||||||
|
f->u.retire_cid.sequence_number);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_CONNECTION_CLOSE:
|
||||||
|
case NGX_QUIC_FT_CONNECTION_CLOSE_APP:
|
||||||
|
p = ngx_slprintf(p, last, "CONNECTION_CLOSE%s err:%ui",
|
||||||
|
f->u.close.app ? "_APP" : "", f->u.close.error_code);
|
||||||
|
|
||||||
|
if (f->u.close.reason.len) {
|
||||||
|
p = ngx_slprintf(p, last, " %V", &f->u.close.reason);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (f->type == NGX_QUIC_FT_CONNECTION_CLOSE) {
|
||||||
|
p = ngx_slprintf(p, last, " ft:%ui", f->u.close.frame_type);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_STREAM0:
|
||||||
|
case NGX_QUIC_FT_STREAM1:
|
||||||
|
case NGX_QUIC_FT_STREAM2:
|
||||||
|
case NGX_QUIC_FT_STREAM3:
|
||||||
|
case NGX_QUIC_FT_STREAM4:
|
||||||
|
case NGX_QUIC_FT_STREAM5:
|
||||||
|
case NGX_QUIC_FT_STREAM6:
|
||||||
|
case NGX_QUIC_FT_STREAM7:
|
||||||
|
|
||||||
|
p = ngx_slprintf(p, last,
|
||||||
|
"STREAM type:0x%xi id:0x%xL offset:0x%xL "
|
||||||
|
"len:0x%xL bits off:%d len:%d fin:%d",
|
||||||
|
f->type, f->u.stream.stream_id, f->u.stream.offset,
|
||||||
|
f->u.stream.length, f->u.stream.off, f->u.stream.len,
|
||||||
|
f->u.stream.fin);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_MAX_DATA:
|
||||||
|
p = ngx_slprintf(p, last, "MAX_DATA max_data:%uL on recv",
|
||||||
|
f->u.max_data.max_data);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_RESET_STREAM:
|
||||||
|
p = ngx_slprintf(p, last, "RESET_STREAM"
|
||||||
|
" id:0x%xL error_code:0x%xL final_size:0x%xL",
|
||||||
|
f->u.reset_stream.id, f->u.reset_stream.error_code,
|
||||||
|
f->u.reset_stream.final_size);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_STOP_SENDING:
|
||||||
|
p = ngx_slprintf(p, last, "STOP_SENDING id:0x%xL err:0x%xL",
|
||||||
|
f->u.stop_sending.id, f->u.stop_sending.error_code);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_STREAMS_BLOCKED:
|
||||||
|
case NGX_QUIC_FT_STREAMS_BLOCKED2:
|
||||||
|
p = ngx_slprintf(p, last, "STREAMS_BLOCKED limit:%uL bidi:%ui",
|
||||||
|
f->u.streams_blocked.limit, f->u.streams_blocked.bidi);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_MAX_STREAMS:
|
||||||
|
case NGX_QUIC_FT_MAX_STREAMS2:
|
||||||
|
p = ngx_slprintf(p, last, "MAX_STREAMS limit:%uL bidi:%ui",
|
||||||
|
f->u.max_streams.limit, f->u.max_streams.bidi);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_MAX_STREAM_DATA:
|
||||||
|
p = ngx_slprintf(p, last, "MAX_STREAM_DATA id:0x%xL limit:%uL",
|
||||||
|
f->u.max_stream_data.id, f->u.max_stream_data.limit);
|
||||||
|
break;
|
||||||
|
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_DATA_BLOCKED:
|
||||||
|
p = ngx_slprintf(p, last, "DATA_BLOCKED limit:%uL",
|
||||||
|
f->u.data_blocked.limit);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_STREAM_DATA_BLOCKED:
|
||||||
|
p = ngx_slprintf(p, last, "STREAM_DATA_BLOCKED id:0x%xL limit:%uL",
|
||||||
|
f->u.stream_data_blocked.id,
|
||||||
|
f->u.stream_data_blocked.limit);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_PATH_CHALLENGE:
|
||||||
|
p = ngx_slprintf(p, last, "PATH_CHALLENGE data:0x%xL",
|
||||||
|
*(uint64_t *) &f->u.path_challenge.data);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_PATH_RESPONSE:
|
||||||
|
p = ngx_slprintf(p, last, "PATH_RESPONSE data:0x%xL",
|
||||||
|
f->u.path_response);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_NEW_TOKEN:
|
||||||
|
p = ngx_slprintf(p, last, "NEW_TOKEN");
|
||||||
|
break;
|
||||||
|
|
||||||
|
case NGX_QUIC_FT_HANDSHAKE_DONE:
|
||||||
|
p = ngx_slprintf(p, last, "HANDSHAKE DONE");
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
p = ngx_slprintf(p, last, "unknown type 0x%xi", f->type);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
ngx_log_debug4(NGX_LOG_DEBUG_EVENT, log, 0, "quic frame %s %s %*s",
|
||||||
|
tx ? "tx" : "rx", ngx_quic_level_name(f->level),
|
||||||
|
p - buf, buf);
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
#define ngx_quic_log_frame(log, f, tx)
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#if BORINGSSL_API_VERSION >= 10
|
#if BORINGSSL_API_VERSION >= 10
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -604,9 +796,6 @@ ngx_quic_add_handshake_data(ngx_ssl_conn_t *ssl_conn,
|
|||||||
fs->sent += fsize;
|
fs->sent += fsize;
|
||||||
p += fsize;
|
p += fsize;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "crypto, generated by SSL len=%ui level=%d",
|
|
||||||
fsize, level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(qc, frame);
|
ngx_quic_queue_frame(qc, frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2106,6 +2295,8 @@ ngx_quic_payload_handler(ngx_connection_t *c, ngx_quic_header_t *pkt)
|
|||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ngx_quic_log_frame(c->log, &frame, 0);
|
||||||
|
|
||||||
c->log->action = "handling frames";
|
c->log->action = "handling frames";
|
||||||
|
|
||||||
p += len;
|
p += len;
|
||||||
@ -2546,9 +2737,6 @@ ngx_quic_send_ack_range(ngx_connection_t *c, ngx_quic_send_ctx_t *ctx,
|
|||||||
frame->u.ack.range_count = 0;
|
frame->u.ack.range_count = 0;
|
||||||
frame->u.ack.first_range = largest - smallest;
|
frame->u.ack.first_range = largest - smallest;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "ACK for PN=%uL..%uL 0 ranges level=%d",
|
|
||||||
largest, smallest, frame->level);
|
|
||||||
|
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2645,9 +2833,6 @@ ngx_quic_send_ack(ngx_connection_t *c, ngx_quic_send_ctx_t *ctx)
|
|||||||
frame->u.ack.ranges_start = frame->data;
|
frame->u.ack.ranges_start = frame->data;
|
||||||
frame->u.ack.ranges_end = frame->data + ranges_len;
|
frame->u.ack.ranges_end = frame->data + ranges_len;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "ACK for PN=%uL %ui ranges level=%d",
|
|
||||||
ctx->largest_range, ctx->nranges, frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(c->quic, frame);
|
ngx_quic_queue_frame(c->quic, frame);
|
||||||
|
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
@ -2696,11 +2881,6 @@ ngx_quic_send_cc(ngx_connection_t *c)
|
|||||||
frame->u.close.reason.data = (u_char *) qc->error_reason;
|
frame->u.close.reason.data = (u_char *) qc->error_reason;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_snprintf(frame->info, sizeof(frame->info) - 1,
|
|
||||||
"CONNECTION_CLOSE%s err:%ui level:%d ft:%ui reason:\"%s\"",
|
|
||||||
qc->error_app ? "_APP" : "", qc->error, qc->error_level,
|
|
||||||
qc->error_ftype, qc->error_reason ? qc->error_reason : "-");
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(c->quic, frame);
|
ngx_quic_queue_frame(c->quic, frame);
|
||||||
|
|
||||||
qc->last_cc = ngx_current_msec;
|
qc->last_cc = ngx_current_msec;
|
||||||
@ -2732,7 +2912,7 @@ ngx_quic_send_new_token(ngx_connection_t *c)
|
|||||||
frame->type = NGX_QUIC_FT_NEW_TOKEN;
|
frame->type = NGX_QUIC_FT_NEW_TOKEN;
|
||||||
frame->u.token.length = token.len;
|
frame->u.token.length = token.len;
|
||||||
frame->u.token.data = token.data;
|
frame->u.token.data = token.data;
|
||||||
ngx_sprintf(frame->info, "NEW_TOKEN");
|
|
||||||
ngx_quic_queue_frame(c->quic, frame);
|
ngx_quic_queue_frame(c->quic, frame);
|
||||||
|
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
@ -2804,7 +2984,7 @@ ngx_quic_handle_ack_frame(ngx_connection_t *c, ngx_quic_header_t *pkt,
|
|||||||
|
|
||||||
for (i = 0; i < ack->range_count; i++) {
|
for (i = 0; i < ack->range_count; i++) {
|
||||||
|
|
||||||
n = ngx_quic_parse_ack_range(pkt, pos, end, &gap, &range);
|
n = ngx_quic_parse_ack_range(pkt->log, pos, end, &gap, &range);
|
||||||
if (n == NGX_ERROR) {
|
if (n == NGX_ERROR) {
|
||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
@ -3334,7 +3514,6 @@ ngx_quic_crypto_input(ngx_connection_t *c, ngx_quic_frame_t *frame, void *data)
|
|||||||
/* 12.4 Frames and frame types, figure 8 */
|
/* 12.4 Frames and frame types, figure 8 */
|
||||||
frame->level = ssl_encryption_application;
|
frame->level = ssl_encryption_application;
|
||||||
frame->type = NGX_QUIC_FT_HANDSHAKE_DONE;
|
frame->type = NGX_QUIC_FT_HANDSHAKE_DONE;
|
||||||
ngx_sprintf(frame->info, "HANDSHAKE DONE on handshake completed");
|
|
||||||
ngx_quic_queue_frame(c->quic, frame);
|
ngx_quic_queue_frame(c->quic, frame);
|
||||||
|
|
||||||
if (ngx_quic_send_new_token(c) != NGX_OK) {
|
if (ngx_quic_send_new_token(c) != NGX_OK) {
|
||||||
@ -3604,11 +3783,6 @@ ngx_quic_handle_stream_data_blocked_frame(ngx_connection_t *c,
|
|||||||
frame->u.max_stream_data.id = f->id;
|
frame->u.max_stream_data.id = f->id;
|
||||||
frame->u.max_stream_data.limit = n;
|
frame->u.max_stream_data.limit = n;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "MAX_STREAM_DATA id:0x%xL limit:%uL level=%d",
|
|
||||||
frame->u.max_stream_data.id,
|
|
||||||
frame->u.max_stream_data.limit,
|
|
||||||
frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(c->quic, frame);
|
ngx_quic_queue_frame(c->quic, frame);
|
||||||
|
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
@ -3828,9 +4002,6 @@ ngx_quic_handle_path_challenge_frame(ngx_connection_t *c,
|
|||||||
frame->type = NGX_QUIC_FT_PATH_RESPONSE;
|
frame->type = NGX_QUIC_FT_PATH_RESPONSE;
|
||||||
frame->u.path_response = *f;
|
frame->u.path_response = *f;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "PATH_RESPONSE data:0x%xL level:%d",
|
|
||||||
*(uint64_t *) &f->data, frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(c->quic, frame);
|
ngx_quic_queue_frame(c->quic, frame);
|
||||||
|
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
@ -3994,9 +4165,6 @@ ngx_quic_retire_connection_id(ngx_connection_t *c,
|
|||||||
frame->type = NGX_QUIC_FT_RETIRE_CONNECTION_ID;
|
frame->type = NGX_QUIC_FT_RETIRE_CONNECTION_ID;
|
||||||
frame->u.retire_cid.sequence_number = seqnum;
|
frame->u.retire_cid.sequence_number = seqnum;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "RETIRE_CONNECTION_ID seqnum=%uL level=%d",
|
|
||||||
seqnum, frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(c->quic, frame);
|
ngx_quic_queue_frame(c->quic, frame);
|
||||||
|
|
||||||
return NGX_OK;
|
return NGX_OK;
|
||||||
@ -4254,8 +4422,7 @@ ngx_quic_send_frames(ngx_connection_t *c, ngx_quic_send_ctx_t *ctx,
|
|||||||
{
|
{
|
||||||
f = ngx_queue_data(q, ngx_quic_frame_t, queue);
|
f = ngx_queue_data(q, ngx_quic_frame_t, queue);
|
||||||
|
|
||||||
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, c->log, 0,
|
ngx_quic_log_frame(c->log, f, 1);
|
||||||
"quic frame out: %s", f->info);
|
|
||||||
|
|
||||||
len = ngx_quic_create_frame(p, f);
|
len = ngx_quic_create_frame(p, f);
|
||||||
if (len == -1) {
|
if (len == -1) {
|
||||||
@ -4966,12 +5133,6 @@ ngx_quic_stream_recv(ngx_connection_t *c, u_char *buf, size_t size)
|
|||||||
frame->u.max_stream_data.limit = qs->fs.received + (b->pos - b->start)
|
frame->u.max_stream_data.limit = qs->fs.received + (b->pos - b->start)
|
||||||
+ (b->end - b->last);
|
+ (b->end - b->last);
|
||||||
|
|
||||||
ngx_sprintf(frame->info,
|
|
||||||
"MAX_STREAM_DATA id:0x%xL limit:%uL l=%d on recv",
|
|
||||||
frame->u.max_stream_data.id,
|
|
||||||
frame->u.max_stream_data.limit,
|
|
||||||
frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(pc->quic, frame);
|
ngx_quic_queue_frame(pc->quic, frame);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4989,9 +5150,6 @@ ngx_quic_stream_recv(ngx_connection_t *c, u_char *buf, size_t size)
|
|||||||
frame->type = NGX_QUIC_FT_MAX_DATA;
|
frame->type = NGX_QUIC_FT_MAX_DATA;
|
||||||
frame->u.max_data.max_data = qc->streams.recv_max_data;
|
frame->u.max_data.max_data = qc->streams.recv_max_data;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "MAX_DATA max_data:%uL level=%d on recv",
|
|
||||||
frame->u.max_data.max_data, frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(pc->quic, frame);
|
ngx_quic_queue_frame(pc->quic, frame);
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, c->log, 0,
|
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, c->log, 0,
|
||||||
@ -5110,9 +5268,6 @@ ngx_quic_stream_send_chain(ngx_connection_t *c, ngx_chain_t *in, off_t limit)
|
|||||||
frame->u.stream.length = n;
|
frame->u.stream.length = n;
|
||||||
frame->u.stream.data = frame->data;
|
frame->u.stream.data = frame->data;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "STREAM id:0x%xL offset:%O len:%uz level:%d",
|
|
||||||
qs->id, c->sent, n, frame->level);
|
|
||||||
|
|
||||||
c->sent += n;
|
c->sent += n;
|
||||||
qc->streams.sent += n;
|
qc->streams.sent += n;
|
||||||
max_flow -= n;
|
max_flow -= n;
|
||||||
@ -5259,9 +5414,6 @@ ngx_quic_stream_cleanup_handler(void *data)
|
|||||||
frame->u.stop_sending.id = qs->id;
|
frame->u.stop_sending.id = qs->id;
|
||||||
frame->u.stop_sending.error_code = 0x100; /* HTTP/3 no error */
|
frame->u.stop_sending.error_code = 0x100; /* HTTP/3 no error */
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "STOP_SENDING id:0x%xL err:0x%xL level:%d",
|
|
||||||
qs->id, frame->u.stop_sending.error_code, frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(qc, frame);
|
ngx_quic_queue_frame(qc, frame);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -5284,11 +5436,6 @@ ngx_quic_stream_cleanup_handler(void *data)
|
|||||||
frame->u.max_streams.bidi = 1;
|
frame->u.max_streams.bidi = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "MAX_STREAMS limit:%uL bidi:%ui level=%d",
|
|
||||||
frame->u.max_streams.limit,
|
|
||||||
frame->u.max_streams.bidi,
|
|
||||||
(int) frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(qc, frame);
|
ngx_quic_queue_frame(qc, frame);
|
||||||
|
|
||||||
if (qs->id & NGX_QUIC_STREAM_UNIDIRECTIONAL) {
|
if (qs->id & NGX_QUIC_STREAM_UNIDIRECTIONAL) {
|
||||||
@ -5317,9 +5464,6 @@ ngx_quic_stream_cleanup_handler(void *data)
|
|||||||
frame->u.stream.length = 0;
|
frame->u.stream.length = 0;
|
||||||
frame->u.stream.data = NULL;
|
frame->u.stream.data = NULL;
|
||||||
|
|
||||||
ngx_sprintf(frame->info, "STREAM id:0x%xL offset:%O fin:1 level:%d",
|
|
||||||
qs->id, c->sent, frame->level);
|
|
||||||
|
|
||||||
ngx_quic_queue_frame(qc, frame);
|
ngx_quic_queue_frame(qc, frame);
|
||||||
|
|
||||||
(void) ngx_quic_output(pc);
|
(void) ngx_quic_output(pc);
|
||||||
|
@ -699,10 +699,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: CRYPTO length: %uL off:%uL",
|
|
||||||
f->u.crypto.length, f->u.crypto.offset);
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_PADDING:
|
case NGX_QUIC_FT_PADDING:
|
||||||
@ -741,13 +737,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
|
|
||||||
f->u.ack.ranges_end = p;
|
f->u.ack.ranges_end = p;
|
||||||
|
|
||||||
ngx_log_debug4(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in ACK largest:%uL delay:%uL"
|
|
||||||
" count:%uL first:%uL", f->u.ack.largest,
|
|
||||||
f->u.ack.delay,
|
|
||||||
f->u.ack.range_count,
|
|
||||||
f->u.ack.first_range);
|
|
||||||
|
|
||||||
if (f->type == NGX_QUIC_FT_ACK_ECN) {
|
if (f->type == NGX_QUIC_FT_ACK_ECN) {
|
||||||
|
|
||||||
if (!((p = ngx_quic_parse_int(p, end, &f->u.ack.ect0))
|
if (!((p = ngx_quic_parse_int(p, end, &f->u.ack.ect0))
|
||||||
@ -802,9 +791,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug3(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: NCID seq:%uL retire:%uL len:%ud",
|
|
||||||
f->u.ncid.seqnum, f->u.ncid.retire, f->u.ncid.len);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_RETIRE_CONNECTION_ID:
|
case NGX_QUIC_FT_RETIRE_CONNECTION_ID:
|
||||||
@ -814,10 +800,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: RETIRE_CONNECTION_ID"
|
|
||||||
" sequence_number:%uL",
|
|
||||||
f->u.retire_cid.sequence_number);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_CONNECTION_CLOSE:
|
case NGX_QUIC_FT_CONNECTION_CLOSE:
|
||||||
@ -848,22 +830,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (f->type == NGX_QUIC_FT_CONNECTION_CLOSE) {
|
|
||||||
|
|
||||||
ngx_log_debug4(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in CONNECTION_CLOSE"
|
|
||||||
" err:%s code:0x%xL type:0x%xL reason:'%V'",
|
|
||||||
ngx_quic_error_text(f->u.close.error_code),
|
|
||||||
f->u.close.error_code, f->u.close.frame_type,
|
|
||||||
&f->u.close.reason);
|
|
||||||
} else {
|
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: CONNECTION_CLOSE_APP:"
|
|
||||||
" code:0x%xL reason:'%V'",
|
|
||||||
f->u.close.error_code, &f->u.close.reason);
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_STREAM0:
|
case NGX_QUIC_FT_STREAM0:
|
||||||
@ -912,13 +878,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug7(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: STREAM type:0x%xi id:0x%xL offset:0x%xL "
|
|
||||||
"len:0x%xL bits off:%d len:%d fin:%d",
|
|
||||||
f->type, f->u.stream.stream_id, f->u.stream.offset,
|
|
||||||
f->u.stream.length, f->u.stream.off, f->u.stream.len,
|
|
||||||
f->u.stream.fin);
|
|
||||||
|
|
||||||
#ifdef NGX_QUIC_DEBUG_FRAMES
|
#ifdef NGX_QUIC_DEBUG_FRAMES
|
||||||
ngx_quic_hexdump(pkt->log, "quic STREAM frame",
|
ngx_quic_hexdump(pkt->log, "quic STREAM frame",
|
||||||
f->u.stream.data, f->u.stream.length);
|
f->u.stream.data, f->u.stream.length);
|
||||||
@ -932,9 +891,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: MAX_DATA max_data:%uL",
|
|
||||||
f->u.max_data.max_data);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_RESET_STREAM:
|
case NGX_QUIC_FT_RESET_STREAM:
|
||||||
@ -947,11 +903,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug3(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: RESET_STREAM"
|
|
||||||
" id:0x%xL error_code:0x%xL final_size:0x%xL",
|
|
||||||
f->u.reset_stream.id, f->u.reset_stream.error_code,
|
|
||||||
f->u.reset_stream.final_size);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_STOP_SENDING:
|
case NGX_QUIC_FT_STOP_SENDING:
|
||||||
@ -966,10 +917,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: STOP_SENDING id:0x%xL error_code:0x%xL",
|
|
||||||
f->u.stop_sending.id, f->u.stop_sending.error_code);
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_STREAMS_BLOCKED:
|
case NGX_QUIC_FT_STREAMS_BLOCKED:
|
||||||
@ -982,12 +929,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
|
|
||||||
f->u.streams_blocked.bidi =
|
f->u.streams_blocked.bidi =
|
||||||
(f->type == NGX_QUIC_FT_STREAMS_BLOCKED) ? 1 : 0;
|
(f->type == NGX_QUIC_FT_STREAMS_BLOCKED) ? 1 : 0;
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: STREAMS_BLOCKED limit:%uL bidi:%ui",
|
|
||||||
f->u.streams_blocked.limit,
|
|
||||||
f->u.streams_blocked.bidi);
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_MAX_STREAMS:
|
case NGX_QUIC_FT_MAX_STREAMS:
|
||||||
@ -1000,10 +941,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
|
|
||||||
f->u.max_streams.bidi = (f->type == NGX_QUIC_FT_MAX_STREAMS) ? 1 : 0;
|
f->u.max_streams.bidi = (f->type == NGX_QUIC_FT_MAX_STREAMS) ? 1 : 0;
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: MAX_STREAMS limit:%uL bidi:%ui",
|
|
||||||
f->u.max_streams.limit,
|
|
||||||
f->u.max_streams.bidi);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_MAX_STREAM_DATA:
|
case NGX_QUIC_FT_MAX_STREAM_DATA:
|
||||||
@ -1018,10 +955,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: MAX_STREAM_DATA id:0x%xL limit:%uL",
|
|
||||||
f->u.max_stream_data.id,
|
|
||||||
f->u.max_stream_data.limit);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_DATA_BLOCKED:
|
case NGX_QUIC_FT_DATA_BLOCKED:
|
||||||
@ -1031,9 +964,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: DATA_BLOCKED limit:%uL",
|
|
||||||
f->u.data_blocked.limit);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_STREAM_DATA_BLOCKED:
|
case NGX_QUIC_FT_STREAM_DATA_BLOCKED:
|
||||||
@ -1048,11 +978,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: STREAM_DATA_BLOCKED"
|
|
||||||
" id:0x%xL limit:%uL",
|
|
||||||
f->u.stream_data_blocked.id,
|
|
||||||
f->u.stream_data_blocked.limit);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_PATH_CHALLENGE:
|
case NGX_QUIC_FT_PATH_CHALLENGE:
|
||||||
@ -1062,9 +987,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: PATH_CHALLENGE data:0x%xL",
|
|
||||||
*(uint64_t *) &f->u.path_challenge.data);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case NGX_QUIC_FT_PATH_RESPONSE:
|
case NGX_QUIC_FT_PATH_RESPONSE:
|
||||||
@ -1074,9 +996,6 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug1(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic frame in: PATH_RESPONSE data:0x%xL",
|
|
||||||
*(uint64_t *) &f->u.path_response.data);
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
@ -1085,6 +1004,8 @@ ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
f->level = pkt->level;
|
||||||
|
|
||||||
return p - start;
|
return p - start;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
@ -1173,7 +1094,7 @@ ngx_quic_frame_allowed(ngx_quic_header_t *pkt, ngx_uint_t frame_type)
|
|||||||
|
|
||||||
|
|
||||||
ssize_t
|
ssize_t
|
||||||
ngx_quic_parse_ack_range(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
ngx_quic_parse_ack_range(ngx_log_t *log, u_char *start, u_char *end,
|
||||||
uint64_t *gap, uint64_t *range)
|
uint64_t *gap, uint64_t *range)
|
||||||
{
|
{
|
||||||
u_char *p;
|
u_char *p;
|
||||||
@ -1182,21 +1103,18 @@ ngx_quic_parse_ack_range(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
|
|
||||||
p = ngx_quic_parse_int(p, end, gap);
|
p = ngx_quic_parse_int(p, end, gap);
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
ngx_log_error(NGX_LOG_INFO, pkt->log, 0,
|
ngx_log_error(NGX_LOG_INFO, log, 0,
|
||||||
"quic failed to parse ack frame gap");
|
"quic failed to parse ack frame gap");
|
||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
p = ngx_quic_parse_int(p, end, range);
|
p = ngx_quic_parse_int(p, end, range);
|
||||||
if (p == NULL) {
|
if (p == NULL) {
|
||||||
ngx_log_error(NGX_LOG_INFO, pkt->log, 0,
|
ngx_log_error(NGX_LOG_INFO, log, 0,
|
||||||
"quic failed to parse ack frame range");
|
"quic failed to parse ack frame range");
|
||||||
return NGX_ERROR;
|
return NGX_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
ngx_log_debug2(NGX_LOG_DEBUG_EVENT, pkt->log, 0,
|
|
||||||
"quic ACK range: gap %uL range %uL", *gap, *range);
|
|
||||||
|
|
||||||
return p - start;
|
return p - start;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -284,7 +284,6 @@ struct ngx_quic_frame_s {
|
|||||||
ngx_quic_path_challenge_frame_t path_challenge;
|
ngx_quic_path_challenge_frame_t path_challenge;
|
||||||
ngx_quic_path_challenge_frame_t path_response;
|
ngx_quic_path_challenge_frame_t path_response;
|
||||||
} u;
|
} u;
|
||||||
u_char info[128]; /* for debug */
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -344,7 +343,7 @@ ssize_t ngx_quic_parse_frame(ngx_quic_header_t *pkt, u_char *start, u_char *end,
|
|||||||
ngx_quic_frame_t *frame);
|
ngx_quic_frame_t *frame);
|
||||||
ssize_t ngx_quic_create_frame(u_char *p, ngx_quic_frame_t *f);
|
ssize_t ngx_quic_create_frame(u_char *p, ngx_quic_frame_t *f);
|
||||||
|
|
||||||
ssize_t ngx_quic_parse_ack_range(ngx_quic_header_t *pkt, u_char *start,
|
ssize_t ngx_quic_parse_ack_range(ngx_log_t *log, u_char *start,
|
||||||
u_char *end, uint64_t *gap, uint64_t *range);
|
u_char *end, uint64_t *gap, uint64_t *range);
|
||||||
|
|
||||||
ngx_int_t ngx_quic_parse_transport_params(u_char *p, u_char *end,
|
ngx_int_t ngx_quic_parse_transport_params(u_char *p, u_char *end,
|
||||||
|
Loading…
Reference in New Issue
Block a user