diff options
author | Roger Dingledine <arma@torproject.org> | 2018-06-20 19:43:58 -0400 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2018-06-20 19:43:58 -0400 |
commit | 7b1a3c51644891c4548ccdfd4e8d444cd91b91b0 (patch) | |
tree | abc092986f47d881d26fecca0bc9499b82745249 /src | |
parent | a360bf287d8220ec2e4899c57ed47a2a91e3bcb9 (diff) | |
download | tor-7b1a3c51644891c4548ccdfd4e8d444cd91b91b0.tar.gz tor-7b1a3c51644891c4548ccdfd4e8d444cd91b91b0.zip |
fix memory leak in protover.c
Fix a memory leak where directory authorities would leak a chunk of
memory for every router descriptor every time they considered voting.
This bug was taking down directory authorities in the live network due
to out-of-memory issues.
Fixes bug 26435; bugfix on 0.3.3.6.
Diffstat (limited to 'src')
-rw-r--r-- | src/or/protover.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/or/protover.c b/src/or/protover.c index b2ec3372c9..5145881ba9 100644 --- a/src/or/protover.c +++ b/src/or/protover.c @@ -283,9 +283,12 @@ parse_protocol_list(const char *s) bool protover_contains_long_protocol_names(const char *s) { - if (!parse_protocol_list(s)) - return true; - return false; + smartlist_t *list = parse_protocol_list(s); + if (!list) + return true; /* yes, has a dangerous name */ + SMARTLIST_FOREACH(list, proto_entry_t *, ent, proto_entry_free(ent)); + smartlist_free(list); + return false; /* no, looks fine */ } /** |