summaryrefslogtreecommitdiff
path: root/databases/redis-devel/files/patch-deps-hiredis-net.c
diff options
context:
space:
mode:
authorSergey A. Osokin <osa@FreeBSD.org>2017-05-06 18:03:15 +0000
committerSergey A. Osokin <osa@FreeBSD.org>2017-05-06 18:03:15 +0000
commit7411659448689e58e025c22a1a90792fd540fb33 (patch)
tree0259ee7c2d41ac2d371fe0c3c29ded656d39b743 /databases/redis-devel/files/patch-deps-hiredis-net.c
parentBump(add) PORTREVISION for r440281 (diff)
Upgrade from 4.0-rc2 to 4.0-rc3.
Notes
Notes: svn path=/head/; revision=440283
Diffstat (limited to 'databases/redis-devel/files/patch-deps-hiredis-net.c')
-rw-r--r--databases/redis-devel/files/patch-deps-hiredis-net.c66
1 files changed, 59 insertions, 7 deletions
diff --git a/databases/redis-devel/files/patch-deps-hiredis-net.c b/databases/redis-devel/files/patch-deps-hiredis-net.c
index c9d361732901..b230b0b91e4c 100644
--- a/databases/redis-devel/files/patch-deps-hiredis-net.c
+++ b/databases/redis-devel/files/patch-deps-hiredis-net.c
@@ -1,12 +1,64 @@
---- deps/hiredis/net.c.orig 2014-09-12 09:16:58.000000000 -0500
-+++ deps/hiredis/net.c 2014-09-16 19:45:20.339820576 -0500
-@@ -138,7 +138,8 @@ int redisKeepAlive(redisContext *c, int
+--- deps/hiredis/net.c.orig 2017-04-22 07:23:27.000000000 -0400
++++ deps/hiredis/net.c 2017-05-05 20:02:09.292479000 -0400
+@@ -135,13 +135,12 @@
+
+ val = interval;
+
+-#ifdef _OSX
++#if defined(_OSX)
+ if (setsockopt(fd, IPPROTO_TCP, TCP_KEEPALIVE, &val, sizeof(val)) < 0) {
+ __redisSetError(c,REDIS_ERR_OTHER,strerror(errno));
return REDIS_ERR;
}
- #else
--#ifndef __sun
-+#if !defined(__sun) && defined(TCP_KEEPIDLE) && defined(TCP_KEEPINTVL) && \
-+ defined(TCP_KEEPCNT)
+-#else
+-#if defined(__GLIBC__) && !defined(__FreeBSD_kernel__)
++#elif defined(__GLIBC__)
val = interval;
if (setsockopt(fd, IPPROTO_TCP, TCP_KEEPIDLE, &val, sizeof(val)) < 0) {
__redisSetError(c,REDIS_ERR_OTHER,strerror(errno));
+@@ -160,6 +159,27 @@
+ __redisSetError(c,REDIS_ERR_OTHER,strerror(errno));
+ return REDIS_ERR;
+ }
++#else
++#if !defined(__sun) && defined(TCP_KEEPIDLE) && defined(TCP_KEEPINTVL) && \
++ defined(TCP_KEEPCNT)
++ val = interval;
++ if (setsockopt(fd, IPPROTO_TCP, TCP_KEEPIDLE, &val, sizeof(val)) < 0) {
++ __redisSetError(c,REDIS_ERR_OTHER,strerror(errno));
++ return REDIS_ERR;
++ }
++
++ val = interval/3;
++ if (val == 0) val = 1;
++ if (setsockopt(fd, IPPROTO_TCP, TCP_KEEPINTVL, &val, sizeof(val)) < 0) {
++ __redisSetError(c,REDIS_ERR_OTHER,strerror(errno));
++ return REDIS_ERR;
++ }
++
++ val = 3;
++ if (setsockopt(fd, IPPROTO_TCP, TCP_KEEPCNT, &val, sizeof(val)) < 0) {
++ __redisSetError(c,REDIS_ERR_OTHER,strerror(errno));
++ return REDIS_ERR;
++ }
+ #endif
+ #endif
+
+@@ -431,7 +451,7 @@
+ struct sockaddr_un sa;
+ long timeout_msec = -1;
+
+- if (redisCreateSocket(c,AF_LOCAL) < 0)
++ if (redisCreateSocket(c,AF_UNIX) < 0)
+ return REDIS_ERR;
+ if (redisSetBlocking(c,0) != REDIS_OK)
+ return REDIS_ERR;
+@@ -456,7 +476,7 @@
+ if (redisContextTimeoutMsec(c,&timeout_msec) != REDIS_OK)
+ return REDIS_ERR;
+
+- sa.sun_family = AF_LOCAL;
++ sa.sun_family = AF_UNIX;
+ strncpy(sa.sun_path,path,sizeof(sa.sun_path)-1);
+ if (connect(c->fd, (struct sockaddr*)&sa, sizeof(sa)) == -1) {
+ if (errno == EINPROGRESS && !blocking) {