diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-03-18 19:00:12 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-03-18 19:00:12 +0000 |
commit | e96d22e914e8b7a81cc472579df9fdb92ab48bb2 (patch) | |
tree | 6f5dc0e7de36e9081f0d2d45b2c3f400b1b76fab | |
parent | a62a24036ddb7449cd19f7c26de457779d30fdd1 (diff) | |
download | tor-e96d22e914e8b7a81cc472579df9fdb92ab48bb2.tar.gz tor-e96d22e914e8b7a81cc472579df9fdb92ab48bb2.zip |
r18941@catbus: nickm | 2008-03-18 14:59:43 -0400
Likely fix for bug 632: do not call start_reading on a placeholder connection.
svn:r14109
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | src/or/relay.c | 6 |
2 files changed, 11 insertions, 0 deletions
@@ -1,4 +1,9 @@ Changes in version 0.2.1.1-alpha - 2008-??-?? + o Major bugfixes: + - Fix assertion failure that could occur when a blocked circuit became + unblocked, and it had pending client DNS requests. Bugfix on + 0.2.0.1-alpha. Fixes bug 632. + o Minor bugfixes: - Stop giving double-close warn when we reject an address for client DNS. - On Windows, correctly detect errors when listing the contents of a diff --git a/src/or/relay.c b/src/or/relay.c index 0d863cd972..db7d1a3d77 100644 --- a/src/or/relay.c +++ b/src/or/relay.c @@ -1813,6 +1813,12 @@ set_streams_blocked_on_circ(circuit_t *circ, or_connection_t *orconn, connection_t *conn = TO_CONN(edge); conn->edge_blocked_on_circ = block; + if (!conn->read_event) { + /* This connection is a placeholder for something; probably a DNS + * request. It can't actually stop or start reading.*/ + continue; + } + if (block) { if (connection_is_reading(conn)) connection_stop_reading(conn); |