summaryrefslogtreecommitdiff
path: root/src/or/main.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2007-06-13 19:50:18 +0000
committerNick Mathewson <nickm@torproject.org>2007-06-13 19:50:18 +0000
commit4b162fd1f41c53e52746628b8dec41450e72b38a (patch)
treed8e8516cc0b23ef079e1ad1870a9409034980a73 /src/or/main.c
parenteab7c6890d462a20dd9808318ae48a56359a1fb7 (diff)
downloadtor-4b162fd1f41c53e52746628b8dec41450e72b38a.tar.gz
tor-4b162fd1f41c53e52746628b8dec41450e72b38a.zip
r13401@catbus: nickm | 2007-06-13 15:50:16 -0400
Add dnsport connection to the global connection list. (Bug found by mwenge.) svn:r10592
Diffstat (limited to 'src/or/main.c')
-rw-r--r--src/or/main.c19
1 files changed, 12 insertions, 7 deletions
diff --git a/src/or/main.c b/src/or/main.c
index 73a0401178..5c7fcb5476 100644
--- a/src/or/main.c
+++ b/src/or/main.c
@@ -162,18 +162,23 @@ int
connection_add(connection_t *conn)
{
tor_assert(conn);
- tor_assert(conn->s >= 0 || conn->linked);
+ tor_assert(conn->s >= 0 ||
+ conn->linked ||
+ (conn->type == CONN_TYPE_AP &&
+ TO_EDGE_CONN(conn)->dns_server_request));
tor_assert(conn->conn_array_index == -1); /* can only connection_add once */
conn->conn_array_index = smartlist_len(connection_array);
smartlist_add(connection_array, conn);
- conn->read_event = tor_malloc_zero(sizeof(struct event));
- conn->write_event = tor_malloc_zero(sizeof(struct event));
- event_set(conn->read_event, conn->s, EV_READ|EV_PERSIST,
- conn_read_callback, conn);
- event_set(conn->write_event, conn->s, EV_WRITE|EV_PERSIST,
- conn_write_callback, conn);
+ if (conn->s >= 0) {
+ conn->read_event = tor_malloc_zero(sizeof(struct event));
+ conn->write_event = tor_malloc_zero(sizeof(struct event));
+ event_set(conn->read_event, conn->s, EV_READ|EV_PERSIST,
+ conn_read_callback, conn);
+ event_set(conn->write_event, conn->s, EV_WRITE|EV_PERSIST,
+ conn_write_callback, conn);
+ }
log_debug(LD_NET,"new conn type %s, socket %d, n_conns %d.",
conn_type_to_string(conn->type), conn->s,