diff options
author | Nick Mathewson <nickm@torproject.org> | 2007-02-13 21:18:56 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2007-02-13 21:18:56 +0000 |
commit | a10ccac9cb78bebf480f7e17b63998402fbee3e5 (patch) | |
tree | 936c286e4d8e9261fcd1fbf7056af463975eb5d2 /src/or/dns.c | |
parent | c3281759bad92cd5fb4d184526f64bc4f8e8a7d8 (diff) | |
download | tor-a10ccac9cb78bebf480f7e17b63998402fbee3e5.tar tor-a10ccac9cb78bebf480f7e17b63998402fbee3e5.tar.gz |
r11797@catbus: nickm | 2007-02-13 16:17:40 -0500
Fix a longstanding dnsworker-related bug: when we decide to kill a DNS worker for having been in use too long, and we independently decide to close one of the exit connections waiting for that DNS worker (perhaps because we got an END relay cell), it was possible for us to try to double-free the connection. We were smart enough to detect this and assert, but not smart enough to fix this bug before now. This should resolve bug 390. Backport candidate.
svn:r9581
Diffstat (limited to 'src/or/dns.c')
-rw-r--r-- | src/or/dns.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/or/dns.c b/src/or/dns.c index 5513c71ed..8224423e9 100644 --- a/src/or/dns.c +++ b/src/or/dns.c @@ -868,7 +868,8 @@ dns_cancel_pending_resolve(const char *address) circ = circuit_get_by_edge_conn(pendconn); if (circ) circuit_detach_stream(circ, pendconn); - connection_free(TO_CONN(pendconn)); + if (!pendconn->_base.marked_for_close) + connection_free(TO_CONN(pendconn)); resolve->pending_connections = pend->next; tor_free(pend); } |