summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaiki Ueno <ueno@gnu.org>2020-07-02 18:26:19 +0000
committerDaiki Ueno <ueno@gnu.org>2020-07-02 18:26:19 +0000
commit22e0678dd23d138eb0f30851ac8361a3b7399f13 (patch)
treea1a2a9a9d39b1706ee7efd28b15c000587ceb7fb
parent850e9b33c995dd264b9c6074ccd9081bd9b2d1da (diff)
parent8dd1ebb5c3796e03b1303477b1f3e0012ea3cb40 (diff)
downloadgnutls-22e0678dd23d138eb0f30851ac8361a3b7399f13.tar.gz
Merge branch 'macos-connectx' into 'master'
Detect the availability of connectx at runtime See merge request gnutls/gnutls!1294
-rw-r--r--lib/system/fastopen.c14
1 files changed, 11 insertions, 3 deletions
diff --git a/lib/system/fastopen.c b/lib/system/fastopen.c
index 8d8409e482..bf1ee0929f 100644
--- a/lib/system/fastopen.c
+++ b/lib/system/fastopen.c
@@ -38,7 +38,9 @@
/* TCP Fast Open on OSX behaves differently from Linux, so define these helpers */
#if defined __APPLE__ && defined __MACH__ && defined CONNECT_DATA_IDEMPOTENT && defined CONNECT_RESUME_ON_READ_WRITE
-# define TCP_FASTOPEN_OSX
+# if defined __has_builtin && __has_builtin(__builtin_available)
+# define TCP_FASTOPEN_OSX
+# endif
#elif defined TCP_FASTOPEN && defined MSG_FASTOPEN
# define TCP_FASTOPEN_LINUX
#endif
@@ -129,9 +131,15 @@ tfo_writev(gnutls_transport_ptr_t ptr, const giovec_t * iovec, int iovec_cnt)
}
# elif defined(TCP_FASTOPEN_OSX)
{
- sa_endpoints_t endpoints = { .sae_dstaddr = (struct sockaddr*)&p->connect_addr, .sae_dstaddrlen = p->connect_addrlen };
+ if(__builtin_available(macOS 10.11, iOS 9.0, tvOS 9.0, watchOS 2.0, *)) {
+ sa_endpoints_t endpoints = { .sae_dstaddr = (struct sockaddr*)&p->connect_addr, .sae_dstaddrlen = p->connect_addrlen };
- ret = connectx(fd, &endpoints, SAE_ASSOCID_ANY, CONNECT_RESUME_ON_READ_WRITE | CONNECT_DATA_IDEMPOTENT, NULL, 0, NULL, NULL);
+ ret = connectx(fd, &endpoints, SAE_ASSOCID_ANY, CONNECT_RESUME_ON_READ_WRITE | CONNECT_DATA_IDEMPOTENT, NULL, 0, NULL, NULL);
+ }
+ else
+ {
+ ret = connect(fd, (struct sockaddr*)&p->connect_addr, p->connect_addrlen);
+ }
if (errno == ENOTCONN || errno == EINPROGRESS) {
gnutls_assert();
errno = EAGAIN;