summaryrefslogtreecommitdiff
path: root/src/or/connection_edge.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2005-02-05 21:03:24 +0000
committerNick Mathewson <nickm@torproject.org>2005-02-05 21:03:24 +0000
commit322c728e978c3c2ad30d8b56de714029052cc070 (patch)
tree01abe31cfbff4ff2f0fd5e5bf8af3dfc09fc745a /src/or/connection_edge.c
parent0ff41a3b375f857002900e042d90c68cf2764c85 (diff)
downloadtor-322c728e978c3c2ad30d8b56de714029052cc070.tar.gz
tor-322c728e978c3c2ad30d8b56de714029052cc070.zip
Fix tor-resolve implementation to prevent crashes and send resolves when we should.
svn:r3561
Diffstat (limited to 'src/or/connection_edge.c')
-rw-r--r--src/or/connection_edge.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/src/or/connection_edge.c b/src/or/connection_edge.c
index 17b9cc41dd..e67be3dfcf 100644
--- a/src/or/connection_edge.c
+++ b/src/or/connection_edge.c
@@ -904,18 +904,17 @@ int connection_exit_begin_resolve(cell_t *cell, circuit_t *circ) {
dummy_conn->state = EXIT_CONN_STATE_RESOLVEFAILED;
dummy_conn->purpose = EXIT_PURPOSE_RESOLVE;
- dummy_conn->next_stream = circ->resolving_streams;
- circ->resolving_streams = dummy_conn;
-
/* send it off to the gethostbyname farm */
switch (dns_resolve(dummy_conn)) {
case 1: /* The result was cached; a resolved cell was sent. */
- case -1:
- /* dummy_conn got freed, don't touch it */
+ case -1: /* Impossible to resolve; a resolved cell was sent. */
+ connection_free(dummy_conn);
return 0;
case 0: /* resolve added to pending list */
+ dummy_conn->next_stream = circ->resolving_streams;
+ circ->resolving_streams = dummy_conn;
assert_circuit_ok(circ);
- ;
+ break;
}
return 0;
}