From: Roger Dingledine Date: Tue, 24 Jun 2003 23:09:21 +0000 (+0000) Subject: improve robustness: connection_get_by_* ignores conns marked for close X-Git-Tag: tor-0.0.2pre8~116 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=dfdc93eccb2a98c40c886e984a8e3c9160bfdfea;p=thirdparty%2Ftor.git improve robustness: connection_get_by_* ignores conns marked for close svn:r352 --- diff --git a/src/or/main.c b/src/or/main.c index bc1e65e4c4..a9c3064d27 100644 --- a/src/or/main.c +++ b/src/or/main.c @@ -119,7 +119,7 @@ connection_t *connection_twin_get_by_addr_port(uint32_t addr, uint16_t port) { /* first check if it's there exactly */ conn = connection_exact_get_by_addr_port(addr,port); - if(conn && connection_state_is_open(conn)) { + if(conn && connection_state_is_open(conn) && !conn->marked_for_close) { log(LOG_INFO,"connection_twin_get_by_addr_port(): Found exact match."); return conn; } @@ -150,7 +150,7 @@ connection_t *connection_exact_get_by_addr_port(uint32_t addr, uint16_t port) { for(i=0;iaddr == addr && conn->port == port) + if(conn->addr == addr && conn->port == port && !conn->marked_for_close) return conn; } return NULL; @@ -162,7 +162,7 @@ connection_t *connection_get_by_type(int type) { for(i=0;itype == type) + if(conn->type == type && !conn->marked_for_close) return conn; } return NULL; @@ -174,7 +174,7 @@ connection_t *connection_get_by_type_state(int type, int state) { for(i=0;itype == type && conn->state == state) + if(conn->type == type && conn->state == state && !conn->marked_for_close) return conn; } return NULL;