aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2009-05-18 16:17:12 -0400
committerNick Mathewson <nickm@torproject.org>2009-05-18 16:17:12 -0400
commit79762aac17e984f13a0e539fe0cd761907ab05f7 (patch)
tree33f3cc89ae52d4514689efc5bf3add2b6a2c2803 /src
parent14a549552a6f2d05db7eed0cf2f2d277df8bc79c (diff)
parent34030a3d23ec6506bc6389cb95cc1fc4b3efdc57 (diff)
downloadtor-79762aac17e984f13a0e539fe0cd761907ab05f7.tar
tor-79762aac17e984f13a0e539fe0cd761907ab05f7.tar.gz
Merge commit 'origin/maint-0.2.1'
Diffstat (limited to 'src')
-rw-r--r--src/or/eventdns.c25
1 files changed, 24 insertions, 1 deletions
diff --git a/src/or/eventdns.c b/src/or/eventdns.c
index 63851483f..4958b9ae3 100644
--- a/src/or/eventdns.c
+++ b/src/or/eventdns.c
@@ -490,7 +490,7 @@ _del_timeout_event(u16 *lineno, struct event *ev, int line)
{
if (*lineno) {
log(EVDNS_LOG_WARN,
- "Duplicate timeout event_del from line %d: first call "
+ "BUG: Duplicate timeout event_del from line %d: first call "
"was at %d.", line, (int)*lineno);
return 0;
} else {
@@ -501,6 +501,24 @@ _del_timeout_event(u16 *lineno, struct event *ev, int line)
#define del_timeout_event(s) \
(_del_timeout_event(&(s)->timeout_event_deleted, &(s)->timeout_event, \
__LINE__))
+/* For debugging bug 929/957. XXXX021 */
+static int
+_del_timeout_event_if_set(u16 *lineno, struct event *ev, int line)
+{
+ if (*lineno == 0) {
+ log(EVDNS_LOG_WARN,
+ "BUG: Event that I thought was non-added as of line %d "
+ "was actually added on line %d",
+ line, (int)*lineno);
+ *lineno = line;
+ return event_del(ev);
+ }
+ return 0;
+}
+#define del_timeout_event_if_set(s) \
+ _del_timeout_event_if_set(&(s)->timeout_event_deleted, \
+ &(s)->timeout_event, \
+ __LINE__)
/* This walks the list of inflight requests to find the */
/* one with a matching transaction id. Returns NULL on */
@@ -549,6 +567,7 @@ nameserver_probe_failed(struct nameserver *const ns) {
global_nameserver_timeouts_length - 1)];
ns->failed_times++;
+ del_timeout_event_if_set(ns);
evtimer_set(&ns->timeout_event, nameserver_prod_callback, ns);
if (add_timeout_event(ns, (struct timeval *) timeout) < 0) {
log(EVDNS_LOG_WARN,
@@ -578,6 +597,7 @@ nameserver_failed(struct nameserver *const ns, const char *msg) {
ns->state = 0;
ns->failed_times = 1;
+ del_timeout_event_if_set(ns);
evtimer_set(&ns->timeout_event, nameserver_prod_callback, ns);
if (add_timeout_event(ns, (struct timeval *) &global_nameserver_timeouts[0]) < 0) {
log(EVDNS_LOG_WARN,
@@ -2089,6 +2109,7 @@ evdns_request_transmit(struct evdns_request *req) {
/* transmitted; we need to check for timeout. */
log(EVDNS_LOG_DEBUG,
"Setting timeout for request %lx", (unsigned long) req);
+ del_timeout_event_if_set(req);
evtimer_set(&req->timeout_event, evdns_request_timeout_callback, req);
if (add_timeout_event(req, &global_timeout) < 0) {
log(EVDNS_LOG_WARN,
@@ -2297,6 +2318,7 @@ _evdns_nameserver_add_impl(const struct sockaddr *address,
if (!ns) return -1;
memset(ns, 0, sizeof(struct nameserver));
+ ns->timeout_event_deleted = __LINE__;
ns->socket = socket(PF_INET, SOCK_DGRAM, 0);
if (ns->socket < 0) { err = 1; goto out1; }
@@ -2531,6 +2553,7 @@ request_new(int type, const char *name, int flags,
}
memset(req, 0, sizeof(struct evdns_request));
+ req->timeout_event_deleted = __LINE__;
if (global_randomize_case) {
unsigned i;