summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/or/connection.c10
-rw-r--r--src/or/main.c3
-rw-r--r--src/or/or.h3
3 files changed, 12 insertions, 4 deletions
diff --git a/src/or/connection.c b/src/or/connection.c
index 56643fd972..50903cf362 100644
--- a/src/or/connection.c
+++ b/src/or/connection.c
@@ -494,7 +494,7 @@ void connection_bucket_decrement(connection_t *conn, int num_read) {
/* keep a timeval to know when time has passed enough to refill buckets */
static struct timeval current_time;
-void connection_bucket_init() {
+void connection_bucket_init(void) {
tor_gettimeofday(&current_time);
global_read_bucket = options.BandwidthBurst; /* start it at max traffic */
}
@@ -533,6 +533,7 @@ void connection_bucket_refill(struct timeval *now) {
conn->state != OR_CONN_STATE_OPEN ||
conn->receiver_bucket > 0)) {
/* and either a non-cell conn or a cell conn with non-empty bucket */
+ log_fn(LOG_DEBUG,"waking up conn (fd %d)",conn->s);
conn->wants_to_read = 0;
connection_start_reading(conn);
if(conn->wants_to_write == 1) {
@@ -600,8 +601,10 @@ int connection_read_to_buf(connection_t *conn) {
at_most = connection_bucket_read_limit(conn);
if(connection_speaks_cells(conn) && conn->state != OR_CONN_STATE_CONNECTING) {
- if(conn->state == OR_CONN_STATE_HANDSHAKING)
+ if(conn->state == OR_CONN_STATE_HANDSHAKING) {
+ /* continue handshaking even if global token bucket is empty */
return connection_tls_continue_handshake(conn);
+ }
/* else open, or closing */
result = read_to_buf_tls(conn->tls, at_most, conn->inbuf);
@@ -616,7 +619,8 @@ int connection_read_to_buf(connection_t *conn) {
return 0;
case TOR_TLS_WANTREAD: /* we're already reading */
case TOR_TLS_DONE: /* no data read, so nothing to process */
- return 0;
+ result = 0;
+ break; /* so we call bucket_decrement below */
}
} else {
result = read_to_buf(conn->s, at_most, conn->inbuf,
diff --git a/src/or/main.c b/src/or/main.c
index e3c5a5a8c6..356dbc0943 100644
--- a/src/or/main.c
+++ b/src/or/main.c
@@ -421,7 +421,8 @@ static int prepare_for_poll(void) {
for(i=0;i<nfds;i++) {
conn = connection_array[i];
- if(connection_has_pending_tls_data(conn)) {
+ if(connection_has_pending_tls_data(conn) &&
+ connection_is_reading(conn)) {
log_fn(LOG_DEBUG,"sock %d has pending bytes.",conn->s);
return 0; /* has pending bytes to read; don't let poll wait. */
}
diff --git a/src/or/or.h b/src/or/or.h
index e25a0692c3..8efbba62f3 100644
--- a/src/or/or.h
+++ b/src/or/or.h
@@ -693,6 +693,9 @@ int connection_create_listener(char *bindaddress, uint16_t bindport, int type);
int connection_connect(connection_t *conn, char *address, uint32_t addr, uint16_t port);
int retry_all_connections(void);
+void connection_bucket_init(void);
+void connection_bucket_refill(struct timeval *now);
+
int connection_handle_read(connection_t *conn);
int connection_read_to_buf(connection_t *conn);