retry streams where the connected cell hasn't arrived in 15 seconds

svn:r1100
This commit is contained in:
Roger Dingledine 2004-02-17 21:07:15 +00:00
parent 72568d2620
commit 39efb0ed52

View File

@ -538,11 +538,13 @@ void connection_ap_expire_beginning(void) {
if (conn->type != CONN_TYPE_AP ||
conn->state != AP_CONN_STATE_CONNECTING)
continue;
if (now - conn->timestamp_lastread > 30) {
log_fn(LOG_WARN,"Stream is %d seconds late. Closing.",
if (now - conn->timestamp_lastread >= 15) {
log_fn(LOG_WARN,"Stream is %d seconds late. Retrying.",
(int)(now - conn->timestamp_lastread));
/* XXX here is where it should move back into 'pending' state */
conn->marked_for_close = 1;
/* move it back into 'pending' state. It's possible it will
* reattach to this same circuit, but that's good enough for now.
*/
conn->state = AP_CONN_STATE_CIRCUIT_WAIT;
}
}
}