[tor-commits] [torsocks/master] Fix: support non blocking socket
dgoulet at torproject.org
dgoulet at torproject.org
Fri Apr 4 22:40:25 UTC 2014
commit bea4e0b1a0815f384d963b184aaaea3dce6e59f3
Author: David Goulet <dgoulet at ev0ke.net>
Date: Sat Aug 17 20:07:34 2013 -0400
Fix: support non blocking socket
Signed-off-by: David Goulet <dgoulet at ev0ke.net>
---
src/common/socks5.c | 11 +++++++----
1 file changed, 7 insertions(+), 4 deletions(-)
diff --git a/src/common/socks5.c b/src/common/socks5.c
index d24f191..f1683c9 100644
--- a/src/common/socks5.c
+++ b/src/common/socks5.c
@@ -53,7 +53,7 @@ static ssize_t recv_data(int fd, void *buf, size_t len)
/* Return the number of bytes received up to this point. */
ret = index;
}
- goto error;
+ continue;
} else {
PERROR("recv socks5 data");
goto error;
@@ -97,7 +97,7 @@ static ssize_t send_data(int fd, const void *buf, size_t len)
/* Return the number of bytes sent up to this point. */
ret = index;
}
- goto error;
+ continue;
} else {
PERROR("send socks5 data");
goto error;
@@ -142,10 +142,13 @@ int socks5_connect(struct connection *conn)
goto error;
}
- /* Use the original libc connect() to the Tor. */
- ret = tsocks_libc_connect(conn->fd, socks5_addr, sizeof(*socks5_addr));
+ do {
+ /* Use the original libc connect() to the Tor. */
+ ret = tsocks_libc_connect(conn->fd, socks5_addr, sizeof(*socks5_addr));
+ } while (ret < 0 && (errno == EINTR || errno == EINPROGRESS));
if (ret < 0) {
ret = -errno;
+ PERROR("socks5 libc connect");
}
error:
More information about the tor-commits
mailing list