diff options
author | Eric Wong <e@80x24.org> | 2016-07-18 06:59:11 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2016-07-18 20:09:52 +0200 |
commit | 49c58d86ceb7816c5f0ca36e38e26cd6b8506d74 (patch) | |
tree | 4241ca444e05546e5343a78a0282e164c92601fe /daemon.c | |
parent | daemon: enable SO_KEEPALIVE for all sockets (diff) | |
download | git-49c58d86ceb7816c5f0ca36e38e26cd6b8506d74.tar.xz git-49c58d86ceb7816c5f0ca36e38e26cd6b8506d74.zip |
daemon: ignore ENOTSOCK from setsockopt
In inetd mode, we are not guaranteed stdin or stdout is a
socket; callers could filter the data through a pipe
or be testing with regular files.
This prevents t5802 from polluting syslog.
Signed-off-by: Eric Wong <e@80x24.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'daemon.c')
-rw-r--r-- | daemon.c | 8 |
1 files changed, 5 insertions, 3 deletions
@@ -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) |