aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2016-08-08 14:21:37 -0700
committerJunio C Hamano <gitster@pobox.com>2016-08-08 14:21:37 -0700
commit172b811322e30ecb3cd660319890e41bc40006bc (patch)
tree69c96d5ea70cc4d53dbecee794cb8a09dfad449f
parentaa9136a87e3ce299fe966da4686a571d6a528311 (diff)
parentfab60274800efba101b3f08a297639d14ecbf840 (diff)
downloadgit-172b811322e30ecb3cd660319890e41bc40006bc.tar.gz
git-172b811322e30ecb3cd660319890e41bc40006bc.tar.xz
Merge branch 'ew/daemon-socket-keepalive' into maint
Recent update to "git daemon" tries to enable the socket-level KEEPALIVE, but when it is spawned via inetd, the standard input file descriptor may not necessarily be connected to a socket. Suppress an ENOTSOCK error from setsockopt(). * ew/daemon-socket-keepalive: Windows: add missing definition of ENOTSOCK daemon: ignore ENOTSOCK from setsockopt
-rw-r--r--compat/mingw.h3
-rw-r--r--daemon.c8
2 files changed, 8 insertions, 3 deletions
diff --git a/compat/mingw.h b/compat/mingw.h
index 9a8803b87..ef22cbb05 100644
--- a/compat/mingw.h
+++ b/compat/mingw.h
@@ -73,6 +73,9 @@ typedef int pid_t;
#ifndef ECONNABORTED
#define ECONNABORTED WSAECONNABORTED
#endif
+#ifndef ENOTSOCK
+#define ENOTSOCK WSAENOTSOCK
+#endif
struct passwd {
char *pw_name;
diff --git a/daemon.c b/daemon.c
index 46dddaca5..a84495113 100644
--- a/daemon.c
+++ b/daemon.c
@@ -673,9 +673,11 @@ static void set_keep_alive(int sockfd)
{
int ka = 1;
- if (setsockopt(sockfd, SOL_SOCKET, SO_KEEPALIVE, &ka, sizeof(ka)) < 0)
- logerror("unable to set SO_KEEPALIVE on socket: %s",
- strerror(errno));
+ if (setsockopt(sockfd, SOL_SOCKET, SO_KEEPALIVE, &ka, sizeof(ka)) < 0) {
+ if (errno != ENOTSOCK)
+ logerror("unable to set SO_KEEPALIVE on socket: %s",
+ strerror(errno));
+ }
}
static int execute(void)