[tor-commits] [tor/master] Fix two more coverity-spotted leaks in master.

nickm at torproject.org nickm at torproject.org
Mon Feb 11 22:06:32 UTC 2013


commit 99457ee7763a2a93cdbaa611a3243e2eb715db65
Author: Nick Mathewson <nickm at torproject.org>
Date:   Mon Feb 11 17:01:02 2013 -0500

    Fix two more coverity-spotted leaks in master.
    
    One is a probably-impossible leak if we fail to sign a consensus;
    another occurs when we can't look up the user we're trying to chown
    our sockets to.
---
 src/or/connection.c |    1 +
 src/or/dirvote.c    |    2 +-
 2 files changed, 2 insertions(+), 1 deletions(-)

diff --git a/src/or/connection.c b/src/or/connection.c
index 7b0f081..737da72 100644
--- a/src/or/connection.c
+++ b/src/or/connection.c
@@ -1068,6 +1068,7 @@ connection_listener_new(const struct sockaddr *listensockaddr,
         log_warn(LD_NET,"Unable to chown() %s socket: user %s not found.",
                  address, options->User);
         tor_close_socket(s);
+        goto err;
       } else if (chown(address, pw->pw_uid, pw->pw_gid) < 0) {
         log_warn(LD_NET,"Unable to chown() %s socket: %s.",
                  address, strerror(errno));
diff --git a/src/or/dirvote.c b/src/or/dirvote.c
index 66dc50d..358708b 100644
--- a/src/or/dirvote.c
+++ b/src/or/dirvote.c
@@ -2121,7 +2121,7 @@ networkstatus_compute_consensus(smartlist_t *votes,
                                        digest, digest_len,
                                        signing_key)) {
       log_warn(LD_BUG, "Couldn't sign consensus networkstatus.");
-      return NULL; /* This leaks, but it should never happen. */
+      goto done;
     }
     smartlist_add(chunks, tor_strdup(sigbuf));
 



More information about the tor-commits mailing list