mirror of
https://git.freebsd.org/ports.git
synced 2025-06-04 12:26:27 -04:00
* Add patch to use TCP_KEEP{CNT, IDLE, INTVL, ALIVE} [2] Changes: http://pgfoundry.org/forum/forum.php?forum_id=1885 PR: ports/169463 [1] Submitted by: Dmitry <dmitry2004@yandex.ru> [1], Oleg A. Mamontov <oleg@mamontov.net> [2]
46 lines
1,005 B
Text
46 lines
1,005 B
Text
--- src/util.c.orig 2011-12-07 15:04:13.000000000 +0400
|
|
+++ src/util.c 2011-12-07 15:04:07.000000000 +0400
|
|
@@ -126,7 +126,7 @@
|
|
res = setsockopt(sock, SOL_SOCKET, SO_KEEPALIVE, &val, sizeof(val));
|
|
if (res < 0)
|
|
goto fail;
|
|
-#ifdef __linux__
|
|
+#ifdef TCP_KEEPCNT
|
|
/* set count of keepalive packets */
|
|
if (cf_tcp_keepcnt > 0) {
|
|
val = cf_tcp_keepcnt;
|
|
@@ -134,6 +134,8 @@
|
|
if (res < 0)
|
|
goto fail;
|
|
}
|
|
+#endif
|
|
+#ifdef TCP_KEEPIDLE
|
|
/* how long the connection can stay idle before sending keepalive pkts */
|
|
if (cf_tcp_keepidle) {
|
|
val = cf_tcp_keepidle;
|
|
@@ -141,6 +143,8 @@
|
|
if (res < 0)
|
|
goto fail;
|
|
}
|
|
+#endif
|
|
+#ifdef TCP_KEEPINTVL
|
|
/* time between packets */
|
|
if (cf_tcp_keepintvl) {
|
|
val = cf_tcp_keepintvl;
|
|
@@ -148,7 +152,7 @@
|
|
if (res < 0)
|
|
goto fail;
|
|
}
|
|
-#else
|
|
+#endif
|
|
#ifdef TCP_KEEPALIVE
|
|
if (cf_tcp_keepidle) {
|
|
val = cf_tcp_keepidle;
|
|
@@ -157,7 +161,6 @@
|
|
goto fail;
|
|
}
|
|
#endif
|
|
-#endif
|
|
}
|
|
|
|
/* set in-kernel socket buffer size */
|