epoll*: favor shutdown(2) for keepalive timeout
commita5b987619f4b793203f6a50e424fe98c5b0794ba
authorEric Wong <normalperson@yhbt.net>
Mon, 18 Jun 2012 20:32:39 +0000 (18 20:32 +0000)
committerEric Wong <normalperson@yhbt.net>
Mon, 18 Jun 2012 20:32:39 +0000 (18 20:32 +0000)
tree1da94546c405e354851f18d2d21a854350ca4e8c
parent604f64f624d562f480dc8424a6597ec5b32947df
epoll*: favor shutdown(2) for keepalive timeout

Triggering Errno::EBADF is tricky in multithreaded situations
due to possible race conditions and yet-to-be discovered bugs.
shutdown(2) is also safe against apps the fork() internally but
do not execve(2) nor set FD_CLOEXEC.

n.b. calling fork() after pthreads are spawned may not be safe
on all platforms w.r.t. malloc, but /is/ the case for glibc on
GNU/Linux.
lib/rainbows/epoll/client.rb