diff options
author | Nick Mathewson <nickm@torproject.org> | 2014-06-04 15:12:45 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2014-06-04 15:12:45 -0400 |
commit | 0073c5b517c7e42188214fa5b8c7b61fac6ba248 (patch) | |
tree | b415a72e158caef83dd8fd71a9341dc7a457481b | |
parent | e74c3601567ab0ca14c5e2a7b9b40b416a47001e (diff) | |
parent | 9815029a2f1568cffb24919f151400b00ab82041 (diff) | |
download | tor-0073c5b517c7e42188214fa5b8c7b61fac6ba248.tar.gz tor-0073c5b517c7e42188214fa5b8c7b61fac6ba248.zip |
Merge remote-tracking branch 'andrea/bug10616'
-rw-r--r-- | changes/bug10616 | 4 | ||||
-rw-r--r-- | src/or/connection_edge.c | 22 |
2 files changed, 19 insertions, 7 deletions
diff --git a/changes/bug10616 b/changes/bug10616 new file mode 100644 index 0000000000..26f0bda85e --- /dev/null +++ b/changes/bug10616 @@ -0,0 +1,4 @@ + o Bugfixes: + - Squelch a spurious LD_BUG message "No origin circuit for successful + SOCKS stream" in certain hidden service failure cases; fixes bug + #10616. diff --git a/src/or/connection_edge.c b/src/or/connection_edge.c index a8ad9ec2e2..49f9ba4978 100644 --- a/src/or/connection_edge.c +++ b/src/or/connection_edge.c @@ -2295,13 +2295,21 @@ connection_ap_handshake_socks_reply(entry_connection_t *conn, char *reply, endreason == END_STREAM_REASON_RESOURCELIMIT) { if (!conn->edge_.on_circuit || !CIRCUIT_IS_ORIGIN(conn->edge_.on_circuit)) { - // DNS remaps can trigger this. So can failed hidden service - // lookups. - log_info(LD_BUG, - "No origin circuit for successful SOCKS stream "U64_FORMAT - ". Reason: %d", - U64_PRINTF_ARG(ENTRY_TO_CONN(conn)->global_identifier), - endreason); + if (endreason != END_STREAM_REASON_RESOLVEFAILED) { + log_info(LD_BUG, + "No origin circuit for successful SOCKS stream "U64_FORMAT + ". Reason: %d", + U64_PRINTF_ARG(ENTRY_TO_CONN(conn)->global_identifier), + endreason); + } + /* + * Else DNS remaps and failed hidden service lookups can send us + * here with END_STREAM_REASON_RESOLVEFAILED; ignore it + * + * Perhaps we could make the test more precise; we can tell hidden + * services by conn->edge_.renddata != NULL; anything analogous for + * the DNS remap case? + */ } else { // XXX: Hrmm. It looks like optimistic data can't go through this // codepath, but someone should probably test it and make sure. |