diff options
author | Dan McGee <dan@archlinux.org> | 2011-09-19 08:10:13 -0500 |
---|---|---|
committer | Max Kellermann <max@duempel.org> | 2011-09-19 17:11:09 +0200 |
commit | 27946a981ff4192f064feb3117567463c137933f (patch) | |
tree | 1e03c0564a65c43ba98a29d8ed7938464e32d3f3 /src/socket_util.c | |
parent | 74617389c88ccf630b8cce4b54d9e2fa5afb2259 (diff) | |
download | mpd-27946a981ff4192f064feb3117567463c137933f.tar.gz mpd-27946a981ff4192f064feb3117567463c137933f.tar.xz mpd-27946a981ff4192f064feb3117567463c137933f.zip |
Set socket TCP keepalive option on incoming connections
If a connected host disappears without our knowledge, as can happen over
wireless or a hibernating machine, we continue to hold the port open waiting
for messages. Because we never try to send anything down this now-broken
pipe, the connection will sit idle taking up a slot in our allowed incoming
connections list.
If enough of these happen, an unintended Denial of Service takes place,
where all connection slots are filled with now-broken, never ending
connections. Setting the TCP keepalive option at least allows these to time
out after the default two hours, which is sufficient in the non-malicious
case.
Signed-off-by: Dan McGee <dan@archlinux.org>
Diffstat (limited to '')
-rw-r--r-- | src/socket_util.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/src/socket_util.c b/src/socket_util.c index a89a67ed6..aa0a44e44 100644 --- a/src/socket_util.c +++ b/src/socket_util.c @@ -148,3 +148,18 @@ socket_bind_listen(int domain, int type, int protocol, return fd; } + +int +socket_keepalive(int fd) +{ + const int reuse = 1; + +#ifdef WIN32 + const char *optval = (const char *)&reuse; +#else + const void *optval = &reuse; +#endif + + return setsockopt(fd, SOL_SOCKET, SO_KEEPALIVE, + optval, sizeof(reuse)); +} |