summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2003-07-03 03:40:47 +0000
committerRoger Dingledine <arma@torproject.org>2003-07-03 03:40:47 +0000
commit75440d08c2fecb4d658b8ecf39261513ef4b226f (patch)
treed2616cef593460e955abc9c86ecdce019eae08de
parent300984c05773084b3a70de88c8deedd8723645e7 (diff)
downloadtor-75440d08c2fecb4d658b8ecf39261513ef4b226f.tar.gz
tor-75440d08c2fecb4d658b8ecf39261513ef4b226f.zip
fix many bugs in package_window handling
svn:r363
-rw-r--r--src/or/circuit.c3
-rw-r--r--src/or/connection.c25
-rw-r--r--src/or/connection_edge.c5
-rw-r--r--src/or/connection_or.c2
4 files changed, 17 insertions, 18 deletions
diff --git a/src/or/circuit.c b/src/or/circuit.c
index eab3d78904..98f0b14430 100644
--- a/src/or/circuit.c
+++ b/src/or/circuit.c
@@ -405,9 +405,10 @@ void circuit_resume_edge_reading(circuit_t *circ, int edge_type, crypt_path_t *l
(edge_type == EDGE_AP && conn->package_window > 0 && conn->cpath_layer == layer_hint)) {
connection_start_reading(conn);
connection_package_raw_inbuf(conn); /* handle whatever might still be on the inbuf */
+ if(circuit_consider_stop_edge_reading(circ, edge_type, layer_hint))
+ return;
}
}
- circuit_consider_stop_edge_reading(circ, edge_type, layer_hint);
}
/* returns 1 if the window is empty, else 0. If it's empty, tell edge conns to stop reading. */
diff --git a/src/or/connection.c b/src/or/connection.c
index 2d3a9cc434..ce56c2f05d 100644
--- a/src/or/connection.c
+++ b/src/or/connection.c
@@ -550,12 +550,20 @@ int connection_package_raw_inbuf(connection_t *conn) {
assert(conn);
assert(!connection_speaks_cells(conn));
- /* this function should never get called if either package_window is 0 */
-
+
repeat_connection_package_raw_inbuf:
+ circ = circuit_get_by_conn(conn);
+ if(!circ) {
+ log_fn(LOG_DEBUG,"conn has no circuits!");
+ return -1;
+ }
+
+ if(circuit_consider_stop_edge_reading(circ, conn->type, conn->cpath_layer))
+ return 0;
+
amount_to_process = conn->inbuf_datalen;
-
+
if(!amount_to_process)
return 0;
@@ -570,12 +578,6 @@ repeat_connection_package_raw_inbuf:
connection_fetch_from_buf(cell.payload+RELAY_HEADER_SIZE, cell.length, conn);
- circ = circuit_get_by_conn(conn);
- if(!circ) {
- log_fn(LOG_DEBUG,"conn has no circuits!");
- return -1;
- }
-
log_fn(LOG_DEBUG,"(%d) Packaging %d bytes (%d waiting).",conn->s,cell.length, conn->inbuf_datalen);
@@ -605,14 +607,11 @@ repeat_connection_package_raw_inbuf:
conn->cpath_layer->package_window--;
}
- if(circuit_consider_stop_edge_reading(circ,
- conn->type == CONN_TYPE_EXIT ? EDGE_EXIT : EDGE_AP, conn->cpath_layer))
- return 0;
-
assert(conn->package_window > 0);
if(--conn->package_window <= 0) { /* is it 0 after decrement? */
connection_stop_reading(conn);
log_fn(LOG_DEBUG,"conn->package_window reached 0.");
+ circuit_consider_stop_edge_reading(circ, conn->type, conn->cpath_layer);
return 0; /* don't process the inbuf any more */
}
log_fn(LOG_DEBUG,"conn->package_window is %d",conn->package_window);
diff --git a/src/or/connection_edge.c b/src/or/connection_edge.c
index 5ae9a85a43..165db46e6d 100644
--- a/src/or/connection_edge.c
+++ b/src/or/connection_edge.c
@@ -50,7 +50,6 @@ int connection_edge_process_inbuf(connection_t *conn) {
case EXIT_CONN_STATE_OPEN:
if(connection_package_raw_inbuf(conn) < 0)
return -1;
- circuit_consider_stop_edge_reading(circuit_get_by_conn(conn), conn->type == CONN_TYPE_AP ? EDGE_AP : EDGE_EXIT, conn->cpath_layer);
return 0;
case EXIT_CONN_STATE_CONNECTING:
log_fn(LOG_DEBUG,"text from server while in 'connecting' state at exit. Leaving it on buffer.");
@@ -247,9 +246,9 @@ int connection_edge_process_relay_cell(cell_t *cell, circuit_t *circ, connection
return 0;
}
conn->package_window += STREAMWINDOW_INCREMENT;
+ log_fn(LOG_DEBUG,"stream-level sendme, packagewindow now %d.", conn->package_window);
connection_start_reading(conn);
- if(!circuit_consider_stop_edge_reading(circ, edge_type, layer_hint))
- connection_package_raw_inbuf(conn); /* handle whatever might still be on the inbuf */
+ connection_package_raw_inbuf(conn); /* handle whatever might still be on the inbuf */
break;
default:
log_fn(LOG_DEBUG,"unknown relay command %d.",relay_command);
diff --git a/src/or/connection_or.c b/src/or/connection_or.c
index b5f63d48b9..683c966554 100644
--- a/src/or/connection_or.c
+++ b/src/or/connection_or.c
@@ -205,7 +205,7 @@ int connection_or_create_listener(struct sockaddr_in *bindaddr) {
}
int connection_or_handle_listener_read(connection_t *conn) {
- log(LOG_NOTICE,"OR: Received a connection request from a router. Attempting to authenticate.");
+ log(LOG_NOTICE,"OR: Received a connection request. Attempting to authenticate.");
return connection_handle_listener_read(conn, CONN_TYPE_OR, OR_CONN_STATE_SERVER_AUTH_WAIT);
}