diff options
author | Nick Mathewson <nickm@torproject.org> | 2013-04-10 19:30:41 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2013-04-12 01:11:31 -0400 |
commit | 39ac1db60e8b920e1e6b07e08f7f3343960ece79 (patch) | |
tree | 9d934519662d30f52baaa84d844236910ffc8170 /src/or/connection.c | |
parent | 9630fb917f3549b3fcbd4a3885e0c47f4be9be36 (diff) | |
download | tor-39ac1db60e8b920e1e6b07e08f7f3343960ece79.tar.gz tor-39ac1db60e8b920e1e6b07e08f7f3343960ece79.zip |
Avoid busy-looping on WANTREAD within connection_handle_write
Fix for bug 5650. Also, if we get a WANTREAD while reading while
writing, make sure we're reading.
Diffstat (limited to 'src/or/connection.c')
-rw-r--r-- | src/or/connection.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/src/or/connection.c b/src/or/connection.c index eac9c4f32b..e366e0e77f 100644 --- a/src/or/connection.c +++ b/src/or/connection.c @@ -2825,7 +2825,20 @@ connection_read_to_buf(connection_t *conn, ssize_t *max_to_read, case TOR_TLS_WANTWRITE: connection_start_writing(conn); return 0; - case TOR_TLS_WANTREAD: /* we're already reading */ + case TOR_TLS_WANTREAD: + if (conn->in_connection_handle_write) { + /* We've been invoked from connection_handle_write, because we're + * waiting for a TLS renegotiation, the renegotiation started, and + * SSL_read returned WANTWRITE. But now SSL_read is saying WANTREAD + * again. Stop waiting for write events now, or else we'll + * busy-loop until data arrives for us to read. */ + connection_stop_writing(conn); + if (!connection_is_reading(conn)) + connection_start_reading(conn); + } + /* we're already reading, one hopes */ + result = 0; + break; case TOR_TLS_DONE: /* no data read, so nothing to process */ result = 0; break; /* so we call bucket_decrement below */ @@ -3337,7 +3350,9 @@ connection_handle_write(connection_t *conn, int force) { int res; tor_gettimeofday_cache_clear(); + conn->in_connection_handle_write = 1; res = connection_handle_write_impl(conn, force); + conn->in_connection_handle_write = 0; return res; } |