Commit 3efdac20 authored by Daniel Black's avatar Daniel Black Committed by Vladislav Vaintroub

MDEV-22173: socket accept - test for failure

accept might return an error, including SOCKET_EAGAIN/
SOCKET_EINTR. The caller, usually handle_connections_sockets
can these however and invalid file descriptor isn't something
to call fcntl on.

Thanks to Etienne Guesnet (ATOS) for diagnosis,
sample patch description and testing.
parent c43a6666
...@@ -1048,10 +1048,14 @@ inline_mysql_socket_accept ...@@ -1048,10 +1048,14 @@ inline_mysql_socket_accept
#else #else
socket_accept.fd= accept(socket_listen.fd, addr, &addr_length); socket_accept.fd= accept(socket_listen.fd, addr, &addr_length);
#ifdef FD_CLOEXEC #ifdef FD_CLOEXEC
flags= fcntl(socket_accept.fd, F_GETFD); if (socket_accept.fd != INVALID_SOCKET)
if (flags != -1) { {
flags |= FD_CLOEXEC; flags= fcntl(socket_accept.fd, F_GETFD);
fcntl(socket_accept.fd, F_SETFD, flags); if (flags != -1)
{
flags |= FD_CLOEXEC;
fcntl(socket_accept.fd, F_SETFD, flags);
}
} }
#endif #endif
#endif #endif
...@@ -1070,10 +1074,14 @@ inline_mysql_socket_accept ...@@ -1070,10 +1074,14 @@ inline_mysql_socket_accept
#else #else
socket_accept.fd= accept(socket_listen.fd, addr, &addr_length); socket_accept.fd= accept(socket_listen.fd, addr, &addr_length);
#ifdef FD_CLOEXEC #ifdef FD_CLOEXEC
flags= fcntl(socket_accept.fd, F_GETFD); if (socket_accept.fd != INVALID_SOCKET)
if (flags != -1) { {
flags |= FD_CLOEXEC; flags= fcntl(socket_accept.fd, F_GETFD);
fcntl(socket_accept.fd, F_SETFD, flags); if (flags != -1)
{
flags |= FD_CLOEXEC;
fcntl(socket_accept.fd, F_SETFD, flags);
}
} }
#endif #endif
#endif #endif
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment