summaryrefslogtreecommitdiff
path: root/src/common/tortls.c
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2003-10-18 08:00:19 +0000
committerRoger Dingledine <arma@torproject.org>2003-10-18 08:00:19 +0000
commitc627ba26323f236afd549fefeb9dd52263065902 (patch)
treead7db6f481aa7b555d117c0799983136658e4853 /src/common/tortls.c
parent9d3f2b232b632a4519bf4f0c49ccd1bab8407978 (diff)
downloadtor-c627ba26323f236afd549fefeb9dd52263065902.tar.gz
tor-c627ba26323f236afd549fefeb9dd52263065902.zip
first steps toward a WANTWRITE SSL_write tls bug fix
how exactly the same do the arguments need to be? :( svn:r625
Diffstat (limited to 'src/common/tortls.c')
-rw-r--r--src/common/tortls.c19
1 files changed, 16 insertions, 3 deletions
diff --git a/src/common/tortls.c b/src/common/tortls.c
index 5882e0c786..138ff85871 100644
--- a/src/common/tortls.c
+++ b/src/common/tortls.c
@@ -31,6 +31,7 @@ struct tor_tls_st {
TOR_TLS_ST_SENTCLOSE, TOR_TLS_ST_CLOSED
} state;
int isServer;
+ int wantwrite_n; /* 0 normally, >0 if we returned wantwrite last time */
};
static X509* tor_tls_create_certificate(crypto_pk_env_t *rsa,
@@ -293,6 +294,7 @@ tor_tls_new(int sock, int isServer)
SSL_set_fd(result->ssl, sock);
result->state = TOR_TLS_ST_HANDSHAKE;
result->isServer = isServer;
+ result->wantwrite_n = 0;
return result;
}
@@ -343,13 +345,24 @@ tor_tls_write(tor_tls *tls, char *cp, int n)
assert(tls->state == TOR_TLS_ST_OPEN);
if (n == 0)
return 0;
+ if(tls->wantwrite_n) {
+ /* if WANTWRITE last time, we must use the _same_ n as before */
+ assert(n >= tls->wantwrite_n);
+ log_fn(LOG_INFO,"resuming pending-write, (%d to flush, reusing %d)",
+ n, tls->wantwrite_n);
+ n = tls->wantwrite_n;
+ tls->wantwrite_n = 0;
+ }
r = SSL_write(tls->ssl, cp, n);
err = tor_tls_get_error(tls, r, 0, "writing", LOG_INFO);
if (err == TOR_TLS_DONE) {
return r;
- } else {
- return err;
- }
+ }
+ if (err == TOR_TLS_WANTWRITE) {
+ log_fn(LOG_INFO,"wantwrite. remembering the number %d.",n);
+ tls->wantwrite_n = n;
+ }
+ return err;
}
/* Perform initial handshake on 'tls'. When finished, returns