From 19607e7886ad0318749adacc8e09d8e3c1e94c52 Mon Sep 17 00:00:00 2001 From: Andrew Bettison Date: Tue, 6 Mar 2018 15:13:13 +1030 Subject: [PATCH] Improve MDP request debug logging --- mdp_client.c | 23 ++++++++++++++++++++--- network_cli.c | 4 ++-- 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/mdp_client.c b/mdp_client.c index 4761b08d..accf622c 100644 --- a/mdp_client.c +++ b/mdp_client.c @@ -352,6 +352,23 @@ int overlay_mdp_recv(int mdp_sockfd, overlay_mdp_frame *mdp, mdp_port_t port, in return WHYF("Expected packet length of %zu, received only %zd bytes", (size_t) expected_len, (size_t) len); /* Valid packet received */ + strbuf b = strbuf_alloca(80); + switch (mdp->packetTypeAndFlags & MDP_TYPE_MASK) { + case MDP_ROUTING_TABLE: strbuf_puts(b, "MDP_ROUTING_TABLE"); break; + case MDP_GOODBYE: strbuf_puts(b, "MDP_GOODBYE"); break; + case MDP_ADDRLIST: strbuf_puts(b, "MDP_ADDRLIST"); break; + case MDP_GETADDRS: strbuf_puts(b, "MDP_GETADDRS"); break; + case MDP_TX: strbuf_puts(b, "MDP_TX"); break; + case MDP_BIND: strbuf_puts(b, "MDP_BIND"); break; + case MDP_SCAN: strbuf_puts(b, "MDP_SCAN"); break; + case MDP_ERROR: strbuf_puts(b, "MDP_ERROR"); break; + default: strbuf_sprintf(b, "%u", mdp->packetTypeAndFlags & MDP_TYPE_MASK); break; + } + if (mdp->packetTypeAndFlags & MDP_FORCE) strbuf_puts(b, "|MDP_FORCE"); + if (mdp->packetTypeAndFlags & MDP_NOCRYPT) strbuf_puts(b, "|MDP_NOCRYPT"); + if (mdp->packetTypeAndFlags & MDP_NOSIGN) strbuf_puts(b, "|MDP_NOSIGN"); + DEBUGF(mdprequests, "Received %s", strbuf_str(b)); + return 0; } @@ -408,8 +425,8 @@ int overlay_mdp_getmyaddr(int mdp_sockfd, unsigned index, sid_t *sidp) ssize_t overlay_mdp_relevant_bytes(overlay_mdp_frame *mdp) { size_t len; - switch(mdp->packetTypeAndFlags&MDP_TYPE_MASK) - { + unsigned type = mdp->packetTypeAndFlags & MDP_TYPE_MASK; + switch (type) { case MDP_ROUTING_TABLE: case MDP_GOODBYE: /* no arguments for saying goodbye */ @@ -439,7 +456,7 @@ ssize_t overlay_mdp_relevant_bytes(overlay_mdp_frame *mdp) len=(&mdp->error.message[0]-(char *)mdp) + strlen(mdp->error.message)+1; break; default: - return WHY("Illegal MDP frame type."); + return WHYF("Illegal MDP frame type %u", type); } return len; } diff --git a/network_cli.c b/network_cli.c index 30c5fc54..51b2746b 100644 --- a/network_cli.c +++ b/network_cli.c @@ -677,7 +677,7 @@ static void lookup_send_request(int mdp_sockfd, const sid_t *srcsid, int srcport bcopy(did,&mdp.out.payload[0],strlen(did)+1); mdp.out.payload_length=strlen(did)+1; - DEBUGF(mdprequests, "Send %s dst.sid=%s dst.port="PRImdp_port_t" payload_length=%u", + DEBUGF(mdprequests, "Send %s dst.sid=%s dst.port=%"PRImdp_port_t" payload_length=%u", desc, alloca_tohex_sid_t(mdp.out.dst.sid), mdp.out.dst.port, @@ -689,7 +689,7 @@ static void lookup_send_request(int mdp_sockfd, const sid_t *srcsid, int srcport if (!is_sid_t_any(config.directory.service)) { mdp.out.dst.sid = config.directory.service; mdp.packetTypeAndFlags=MDP_TX; - DEBUGF(mdprequests, "Send MDP_TX dst.sid=%s dst.port="PRImdp_port_t" payload_length=%u", + DEBUGF(mdprequests, "Send MDP_TX dst.sid=%s dst.port=%"PRImdp_port_t" payload_length=%u", alloca_tohex_sid_t(mdp.out.dst.sid), mdp.out.dst.port, mdp.out.payload_length);