From e3ae318059439cbd7210d18940cca09aeaf38256 Mon Sep 17 00:00:00 2001 From: thorkill Date: Sat, 4 Jul 2015 03:21:01 +0200 Subject: [PATCH] Cleanup local_address in protocol_edge.c In line 131 local_address has been defined, but the memory was never freed on return. --- src/protocol_edge.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/src/protocol_edge.c b/src/protocol_edge.c index 661f0b37..555b654b 100644 --- a/src/protocol_edge.c +++ b/src/protocol_edge.c @@ -140,6 +140,7 @@ bool add_edge_h(connection_t *c, const char *request) { logger(DEBUG_PROTOCOL, LOG_WARNING, "Got %s from %s (%s) for ourself which does not match existing entry", "ADD_EDGE", c->name, c->hostname); send_add_edge(c, e); + sockaddrfree(&local_address); return true; } else { logger(DEBUG_PROTOCOL, LOG_WARNING, "Got %s from %s (%s) which does not match existing entry", @@ -154,9 +155,11 @@ bool add_edge_h(connection_t *c, const char *request) { logger(DEBUG_PROTOCOL, LOG_WARNING, "Got %s from %s (%s) for ourself which does not match existing entry", "ADD_EDGE", c->name, c->hostname); send_add_edge(c, e); + sockaddrfree(&local_address); return true; } // Otherwise, just ignore it. + sockaddrfree(&local_address); return true; } else if(local_address.sa.sa_family) { // We learned a new local address for this edge. @@ -169,8 +172,10 @@ bool add_edge_h(connection_t *c, const char *request) { return true; } - } else + } else { + sockaddrfree(&local_address); return true; + } } else if(from == myself) { logger(DEBUG_PROTOCOL, LOG_WARNING, "Got %s from %s (%s) for ourself which does not exist", "ADD_EDGE", c->name, c->hostname); @@ -180,6 +185,7 @@ bool add_edge_h(connection_t *c, const char *request) { e->to = to; send_del_edge(c, e); free_edge(e); + sockaddrfree(&local_address); return true; }