summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2013-01-11 16:27:45 -0800
committerNick Mathewson <nickm@torproject.org>2013-01-11 16:36:54 -0800
commita5ee3834bf060c8a238be84ea7287bdfa8303a27 (patch)
treee8785e1ce22eed6e376e0e8bcc400bf7f0f02516 /src
parentdffc8e359bcfeb00813a3afde6aa2328f6a6a476 (diff)
downloadtor-a5ee3834bf060c8a238be84ea7287bdfa8303a27.tar.gz
tor-a5ee3834bf060c8a238be84ea7287bdfa8303a27.zip
Handle EWOULDBLOCK as EAGAIN if they happen to be different.
Fixes bug 7935. Reported by 'oftc_must_be_destroyed'.
Diffstat (limited to 'src')
-rw-r--r--src/common/compat.h7
-rw-r--r--src/ext/eventdns.c4
2 files changed, 10 insertions, 1 deletions
diff --git a/src/common/compat.h b/src/common/compat.h
index 9c544fa309..f597c122c2 100644
--- a/src/common/compat.h
+++ b/src/common/compat.h
@@ -53,6 +53,7 @@
#endif
#include <stdio.h>
+#include <errno.h>
#if defined (WINCE)
#include <fcntl.h>
@@ -538,10 +539,14 @@ int tor_socket_errno(tor_socket_t sock);
const char *tor_socket_strerror(int e);
#else
#define SOCK_ERRNO(e) e
+#if EAGAIN == EWOULDBLOCK
#define ERRNO_IS_EAGAIN(e) ((e) == EAGAIN)
+#else
+#define ERRNO_IS_EAGAIN(e) ((e) == EAGAIN || (e) == EWOULDBLOCK)
+#endif
#define ERRNO_IS_EINPROGRESS(e) ((e) == EINPROGRESS)
#define ERRNO_IS_CONN_EINPROGRESS(e) ((e) == EINPROGRESS)
-#define ERRNO_IS_ACCEPT_EAGAIN(e) ((e) == EAGAIN || (e) == ECONNABORTED)
+#define ERRNO_IS_ACCEPT_EAGAIN(e) (ERRNO_IS_EAGAIN(e) || (e) == ECONNABORTED)
#define ERRNO_IS_ACCEPT_RESOURCE_LIMIT(e) \
((e) == EMFILE || (e) == ENFILE || (e) == ENOBUFS || (e) == ENOMEM)
#define ERRNO_IS_EADDRINUSE(e) ((e) == EADDRINUSE)
diff --git a/src/ext/eventdns.c b/src/ext/eventdns.c
index 7e99f55626..b1f586b2fb 100644
--- a/src/ext/eventdns.c
+++ b/src/ext/eventdns.c
@@ -368,7 +368,11 @@ error_is_eagain(int err)
#define CLOSE_SOCKET(x) closesocket(x)
#else
#define last_error(sock) (errno)
+#if EAGAIN != EWOULDBLOCK
+#define error_is_eagain(err) ((err) == EAGAIN || (err) == EWOULDBLOCK)
+#else
#define error_is_eagain(err) ((err) == EAGAIN)
+#endif
#define CLOSE_SOCKET(x) close(x)
#endif