summary refs log tree commit diff
path: root/irc.c
diff options
context:
space:
mode:
authorC. McEnroe2021-06-20 16:48:53 -0400
committerC. McEnroe2021-06-20 16:48:53 -0400
commitb3631a7e325ee98b73f6544ae7174d7c0e8a3025 (patch)
tree5623649b2e589a6290a49c165aafb3a78ad23a72 /irc.c
parenta5a225c52c39f438a95b0ed2481ee273aab02640 (diff)
Handle TLS_WANNT_POLL{IN,OUT} from tls_handshake(3)
For blocking sockets it should be retried immediately.
Diffstat (limited to 'irc.c')
-rw-r--r--irc.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/irc.c b/irc.c
index 166d4ed..089f9ea 100644
--- a/irc.c
+++ b/irc.c
@@ -165,7 +165,9 @@ int ircConnect(const char *bindHost, const char *host, const char *port) {
 	error = tls_connect_socket(client, sock, host);
 	if (error) errx(EX_PROTOCOL, "tls_connect: %s", tls_error(client));
 
-	error = tls_handshake(client);
+	do {
+		error = tls_handshake(client);
+	} while (error == TLS_WANT_POLLIN || error == TLS_WANT_POLLOUT);
 	if (error) errx(EX_PROTOCOL, "tls_handshake: %s", tls_error(client));
 
 	return sock;