MINOR: quic: Add traces for quic_packet_encrypt().
authorFrédéric Lécaille <flecaille@haproxy.com>
Fri, 18 Dec 2020 08:48:20 +0000 (09:48 +0100)
committerWilly Tarreau <w@1wt.eu>
Wed, 23 Dec 2020 10:57:26 +0000 (11:57 +0100)
Add traces to have an idea why this function may fail. In fact
in never fails when the passed parameters are correct, especially the
lengths. This is not the case when a packet is not correctly built
before being encrypted.

include/haproxy/xprt_quic-t.h
src/xprt_quic.c

index 16883fb..143b228 100644 (file)
@@ -181,6 +181,7 @@ enum quic_pkt_type {
 #define           QUIC_EV_CONN_RWSEC     (1ULL << 5)
 #define           QUIC_EV_CONN_LPKT      (1ULL << 6)
 #define           QUIC_EV_CONN_SPKT      (1ULL << 7)
+#define           QUIC_EV_CONN_ENCPKT    (1ULL << 8)
 #define           QUIC_EV_CONN_HPKT      (1ULL << 9)
 #define           QUIC_EV_CONN_PAPKT     (1ULL << 10)
 #define           QUIC_EV_CONN_PAPKTS    (1ULL << 11)
index 931361c..7eb48c2 100644 (file)
@@ -67,6 +67,7 @@ static const struct trace_event quic_trace_events[] = {
        { .mask = QUIC_EV_CONN_WSEC,     .name = "write_secs",       .desc = "write secrets derivation" },
        { .mask = QUIC_EV_CONN_LPKT,     .name = "lstnr_packet",     .desc = "new listener received packet" },
        { .mask = QUIC_EV_CONN_SPKT,     .name = "srv_packet",       .desc = "new server received packet" },
+       { .mask = QUIC_EV_CONN_ENCPKT,   .name = "enc_hdshk_pkt",    .desc = "handhshake packet encrytion" },
        { .mask = QUIC_EV_CONN_HPKT,     .name = "hdshk_pkt",        .desc = "handhshake packet building" },
        { .mask = QUIC_EV_CONN_PAPKT,    .name = "phdshk_apkt",      .desc = "post handhshake application packet preparation" },
        { .mask = QUIC_EV_CONN_PAPKTS,   .name = "phdshk_apkts",     .desc = "post handhshake application packets preparation" },
@@ -189,6 +190,27 @@ static inline void chunk_tx_frm_appendf(struct buffer *buf,
        }
 }
 
+/* Only for debug purpose */
+struct enc_debug_info {
+       unsigned char *payload;
+       size_t payload_len;
+       unsigned char *aad;
+       size_t aad_len;
+       uint64_t pn;
+};
+
+/* Initializes a enc_debug_info struct (only for debug purpose) */
+static inline void enc_debug_info_init(struct enc_debug_info *edi,
+                                       unsigned char *payload, size_t payload_len,
+                                       unsigned char *aad, size_t aad_len, uint64_t pn)
+{
+       edi->payload = payload;
+       edi->payload_len = payload_len;
+       edi->aad = aad;
+       edi->aad_len = aad_len;
+       edi->pn = pn;
+}
+
 /* Trace callback for QUIC.
  * These traces always expect that arg1, if non-null, is of type connection.
  */
@@ -400,6 +422,18 @@ static void quic_trace(enum trace_level level, uint64_t mask, const struct trace
                        }
                }
 
+               if (mask & QUIC_EV_CONN_ENCPKT) {
+                       const struct enc_debug_info *edi = a2;
+
+                       if (edi)
+                               chunk_appendf(&trace_buf,
+                                             " payload=@%p payload_len=%llu"
+                                             " aad=@%p aad_len=%llu pn=%llu",
+                                             edi->payload, (unsigned long long)edi->payload_len,
+                                             edi->aad, (unsigned long long)edi->aad_len,
+                                             (unsigned long long)edi->pn);
+               }
+
                if (mask & QUIC_EV_CONN_RMHP) {
                        const struct quic_rx_packet *pkt = a2;
 
@@ -1055,19 +1089,25 @@ static int quic_packet_encrypt(unsigned char *payload, size_t payload_len,
        unsigned char iv[12];
        unsigned char *tx_iv = tls_ctx->tx.iv;
        size_t tx_iv_sz = sizeof tls_ctx->tx.iv;
+       struct enc_debug_info edi;
 
        if (!quic_aead_iv_build(iv, sizeof iv, tx_iv, tx_iv_sz, pn)) {
                TRACE_DEVEL("AEAD IV building for encryption failed", QUIC_EV_CONN_HPKT, conn);
-               return 0;
+               goto err;
        }
 
        if (!quic_tls_encrypt(payload, payload_len, aad, aad_len,
                              tls_ctx->tx.aead, tls_ctx->tx.key, iv)) {
                TRACE_DEVEL("QUIC packet encryption failed", QUIC_EV_CONN_HPKT, conn);
-               return 0;
+               goto err;
        }
 
        return 1;
+
+ err:
+       enc_debug_info_init(&edi, payload, payload_len, aad, aad_len, pn);
+       TRACE_DEVEL("leaving in error", QUIC_EV_CONN_ENCPKT, conn, &edi);
+       return 0;
 }
 
 /* Decrypt <pkt> QUIC packet with <tls_ctx> as QUIC TLS cryptographic context.