aboutsummaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2020-10-07 08:09:59 -0400
committerNick Mathewson <nickm@torproject.org>2020-10-07 08:09:59 -0400
commit968b6c30c1158fde003a99a7d22a575e3b211c91 (patch)
treeb9739c3a093e0427769de5778fbfc86b03d64f75 /src/lib
parente0e0ef713e96a196782fec754b11874675263c04 (diff)
parent40eb6b19a33f1261168e5d64ba162d6f7d80e5a1 (diff)
downloadtor-968b6c30c1158fde003a99a7d22a575e3b211c91.tar.gz
tor-968b6c30c1158fde003a99a7d22a575e3b211c91.zip
Merge remote-tracking branch 'tor-gitlab/mr/43' into maint-0.3.5
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/tls/tortls_nss.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/lib/tls/tortls_nss.c b/src/lib/tls/tortls_nss.c
index 1436442e1c..6f6c47674e 100644
--- a/src/lib/tls/tortls_nss.c
+++ b/src/lib/tls/tortls_nss.c
@@ -418,6 +418,16 @@ tor_tls_new(tor_socket_t sock, int is_server)
return NULL;
}
+ /* even if though the socket is already nonblocking, we need to tell NSS
+ * about the fact, so that it knows what to do when it says EAGAIN. */
+ PRSocketOptionData data;
+ data.option = PR_SockOpt_Nonblocking;
+ data.value.non_blocking = 1;
+ if (PR_SetSocketOption(ssl, &data) != PR_SUCCESS) {
+ PR_Close(ssl);
+ return NULL;
+ }
+
tor_tls_t *tls = tor_malloc_zero(sizeof(tor_tls_t));
tls->magic = TOR_TLS_MAGIC;
tls->context = ctx;