diff options
author | Nick Mathewson <nickm@torproject.org> | 2007-02-28 20:24:23 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2007-02-28 20:24:23 +0000 |
commit | 3008c3b768f2cb8ab735e8ebbda2d4322910b19e (patch) | |
tree | 305dc3660e47d3e733d3928cda6fe621d9c1804b /src/or/eventdns.c | |
parent | 08c75f4349067815f4d131ca2cd4b425ec8fc38c (diff) | |
download | tor-3008c3b768f2cb8ab735e8ebbda2d4322910b19e.tar.gz tor-3008c3b768f2cb8ab735e8ebbda2d4322910b19e.zip |
r12000@catbus: nickm | 2007-02-28 15:12:21 -0500
Try to fix eventdns bug 326 again, this time by noting that rcode 2 (serverfailed) does not really mean "The server is useless."
svn:r9687
Diffstat (limited to 'src/or/eventdns.c')
-rw-r--r-- | src/or/eventdns.c | 21 |
1 files changed, 15 insertions, 6 deletions
diff --git a/src/or/eventdns.c b/src/or/eventdns.c index bb97c31c74..7270df5052 100644 --- a/src/or/eventdns.c +++ b/src/or/eventdns.c @@ -696,7 +696,6 @@ reply_handle(struct request *const req, u16 flags, u32 ttl, struct reply *reply) } switch(error) { - case DNS_ERR_SERVERFAILED: case DNS_ERR_NOTIMPL: case DNS_ERR_REFUSED: // we regard these errors as marking a bad nameserver @@ -708,6 +707,15 @@ reply_handle(struct request *const req, u16 flags, u32 ttl, struct reply *reply) if (!request_reissue(req)) return; } break; + case DNS_ERR_SERVERFAILED: + // rcode 2 (servfailed) sometimes means "we are broken" and + // sometimes (with some binds) means "that request was very + // confusing." Treat this as a timeout, not a failure. + /*XXXX refactor the parts of */ + log(EVDNS_LOG_DEBUG, "Got a SERVERFAILED from nameserver %s; " + "will allow the request to time out.", + debug_nota(req->ns->address)); + break; default: // we got a good reply from the nameserver nameserver_up(req->ns); @@ -1876,9 +1884,9 @@ evdns_request_transmit(struct request *req) { case 2: // failed in some other way retcode = 1; - // fall through + break; default: - // all ok + // transmitted; we need to check for timeout. log(EVDNS_LOG_DEBUG, "Setting timeout for request %lx", (unsigned long) req); evtimer_set(&req->timeout_event, evdns_request_timeout_callback, req); @@ -1888,10 +1896,11 @@ evdns_request_transmit(struct request *req) { (unsigned long) req); // ???? Do more? } - req->tx_count++; - req->transmit_me = 0; - return retcode; } + + req->tx_count++; + req->transmit_me = 0; + return retcode; } static void |