summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorSergey Kandaurov <pluknet@nginx.com>2020-11-17 21:32:06 +0000
committerSergey Kandaurov <pluknet@nginx.com>2020-11-17 21:32:06 +0000
commit97dcde97991169da1106117da464516445c36a77 (patch)
tree756ff6d8d550b8675b16d3c8a8d087b67c9bff98
parent5e32d82dea03e25c472f8549afe167d827104100 (diff)
downloadnginx-97dcde97991169da1106117da464516445c36a77.tar.gz
nginx-97dcde97991169da1106117da464516445c36a77.tar.bz2
QUIC: hide header creation internals in ngx_event_quic_transport.c.
It doesn't make sense to expose the header type in a public function.
-rw-r--r--src/event/ngx_event_quic.c2
-rw-r--r--src/event/ngx_event_quic_protection.c4
-rw-r--r--src/event/ngx_event_quic_transport.c17
-rw-r--r--src/event/ngx_event_quic_transport.h5
4 files changed, 20 insertions, 8 deletions
diff --git a/src/event/ngx_event_quic.c b/src/event/ngx_event_quic.c
index a11300407..2d19ebea4 100644
--- a/src/event/ngx_event_quic.c
+++ b/src/event/ngx_event_quic.c
@@ -4858,7 +4858,7 @@ ngx_quic_send_frames(ngx_connection_t *c, ngx_quic_send_ctx_t *ctx,
if (start->level == ssl_encryption_initial && pkt.need_ack) {
pad_len = NGX_QUIC_MIN_INITIAL_SIZE - EVP_GCM_TLS_TAG_LEN
- - ngx_quic_create_long_header(&pkt, NULL, out.len, NULL);
+ - ngx_quic_create_header(&pkt, NULL, out.len, NULL);
pad_len = ngx_min(pad_len, NGX_QUIC_MIN_INITIAL_SIZE);
} else {
diff --git a/src/event/ngx_event_quic_protection.c b/src/event/ngx_event_quic_protection.c
index a5c73f3a6..0b491d976 100644
--- a/src/event/ngx_event_quic_protection.c
+++ b/src/event/ngx_event_quic_protection.c
@@ -837,7 +837,7 @@ ngx_quic_create_long_packet(ngx_quic_header_t *pkt, ngx_str_t *res)
out.len = pkt->payload.len + EVP_GCM_TLS_TAG_LEN;
ad.data = res->data;
- ad.len = ngx_quic_create_long_header(pkt, ad.data, out.len, &pnp);
+ ad.len = ngx_quic_create_header(pkt, ad.data, out.len, &pnp);
out.data = res->data + ad.len;
@@ -895,7 +895,7 @@ ngx_quic_create_short_packet(ngx_quic_header_t *pkt, ngx_str_t *res)
out.len = pkt->payload.len + EVP_GCM_TLS_TAG_LEN;
ad.data = res->data;
- ad.len = ngx_quic_create_short_header(pkt, ad.data, out.len, &pnp);
+ ad.len = ngx_quic_create_header(pkt, ad.data, out.len, &pnp);
out.data = res->data + ad.len;
diff --git a/src/event/ngx_event_quic_transport.c b/src/event/ngx_event_quic_transport.c
index 50ec26f09..9f0485d54 100644
--- a/src/event/ngx_event_quic_transport.c
+++ b/src/event/ngx_event_quic_transport.c
@@ -80,6 +80,11 @@ static ngx_int_t ngx_quic_parse_long_header(ngx_quic_header_t *pkt);
static ngx_int_t ngx_quic_supported_version(uint32_t version);
static ngx_int_t ngx_quic_parse_long_header_v1(ngx_quic_header_t *pkt);
+static size_t ngx_quic_create_long_header(ngx_quic_header_t *pkt, u_char *out,
+ size_t pkt_len, u_char **pnp);
+static size_t ngx_quic_create_short_header(ngx_quic_header_t *pkt, u_char *out,
+ size_t pkt_len, u_char **pnp);
+
static ngx_int_t ngx_quic_frame_allowed(ngx_quic_header_t *pkt,
ngx_uint_t frame_type);
static size_t ngx_quic_create_ack(u_char *p, ngx_quic_ack_frame_t *ack);
@@ -562,6 +567,16 @@ ngx_quic_create_version_negotiation(ngx_quic_header_t *pkt, u_char *out)
size_t
+ngx_quic_create_header(ngx_quic_header_t *pkt, u_char *out, size_t pkt_len,
+ u_char **pnp)
+{
+ return ngx_quic_short_pkt(pkt->flags)
+ ? ngx_quic_create_short_header(pkt, out, pkt_len, pnp)
+ : ngx_quic_create_long_header(pkt, out, pkt_len, pnp);
+}
+
+
+static size_t
ngx_quic_create_long_header(ngx_quic_header_t *pkt, u_char *out,
size_t pkt_len, u_char **pnp)
{
@@ -612,7 +627,7 @@ ngx_quic_create_long_header(ngx_quic_header_t *pkt, u_char *out,
}
-size_t
+static size_t
ngx_quic_create_short_header(ngx_quic_header_t *pkt, u_char *out,
size_t pkt_len, u_char **pnp)
{
diff --git a/src/event/ngx_event_quic_transport.h b/src/event/ngx_event_quic_transport.h
index bd41842ad..ee89855bd 100644
--- a/src/event/ngx_event_quic_transport.h
+++ b/src/event/ngx_event_quic_transport.h
@@ -335,10 +335,7 @@ ngx_int_t ngx_quic_parse_packet(ngx_quic_header_t *pkt);
size_t ngx_quic_create_version_negotiation(ngx_quic_header_t *pkt, u_char *out);
-size_t ngx_quic_create_long_header(ngx_quic_header_t *pkt, u_char *out,
- size_t pkt_len, u_char **pnp);
-
-size_t ngx_quic_create_short_header(ngx_quic_header_t *pkt, u_char *out,
+size_t ngx_quic_create_header(ngx_quic_header_t *pkt, u_char *out,
size_t pkt_len, u_char **pnp);
size_t ngx_quic_create_retry_itag(ngx_quic_header_t *pkt, u_char *out,