From 07341c359487c45e6c8a8187f18d5271536c798b Mon Sep 17 00:00:00 2001 From: Gunnar Beutner Date: Sun, 16 May 2021 12:13:19 +0200 Subject: LibCore: Close accepted sockets on exec() and make them non-blocking Previously accept() would copy the listener socket's cloexec and non-blocking flag. With that fixed however TCPServer and LocalServer now leak file descriptors into child processes and are blocking. --- Base/res/icons/16x16/app-analog-clock.png | Bin 357 -> 10480 bytes Userland/Libraries/LibCore/LocalServer.cpp | 10 ++++++++++ Userland/Libraries/LibCore/TCPServer.cpp | 13 ++++++++++++- 3 files changed, 22 insertions(+), 1 deletion(-) diff --git a/Base/res/icons/16x16/app-analog-clock.png b/Base/res/icons/16x16/app-analog-clock.png index e57522add3..42d63fbda7 100644 Binary files a/Base/res/icons/16x16/app-analog-clock.png and b/Base/res/icons/16x16/app-analog-clock.png differ diff --git a/Userland/Libraries/LibCore/LocalServer.cpp b/Userland/Libraries/LibCore/LocalServer.cpp index 1d3d6099ca..1acb063cf1 100644 --- a/Userland/Libraries/LibCore/LocalServer.cpp +++ b/Userland/Libraries/LibCore/LocalServer.cpp @@ -141,12 +141,22 @@ RefPtr LocalServer::accept() VERIFY(m_listening); sockaddr_un un; socklen_t un_size = sizeof(un); +#ifndef AK_OS_MACOS + int accepted_fd = ::accept4(m_fd, (sockaddr*)&un, &un_size, SOCK_NONBLOCK | SOCK_CLOEXEC); +#else int accepted_fd = ::accept(m_fd, (sockaddr*)&un, &un_size); +#endif if (accepted_fd < 0) { perror("accept"); return nullptr; } +#ifdef AK_OS_MACOS + int option = 1; + ioctl(m_fd, FIONBIO, &option); + (void)fcntl(accepted_fd, F_SETFD, FD_CLOEXEC); +#endif + return LocalSocket::construct(accepted_fd); } diff --git a/Userland/Libraries/LibCore/TCPServer.cpp b/Userland/Libraries/LibCore/TCPServer.cpp index f242e9165b..97b4d397b0 100644 --- a/Userland/Libraries/LibCore/TCPServer.cpp +++ b/Userland/Libraries/LibCore/TCPServer.cpp @@ -9,12 +9,12 @@ #include #include #include +#include #include #include #include #ifndef SOCK_NONBLOCK -# include # include #endif namespace Core { @@ -69,12 +69,23 @@ RefPtr TCPServer::accept() VERIFY(m_listening); sockaddr_in in; socklen_t in_size = sizeof(in); +#ifndef AK_OS_MACOS + int accepted_fd = ::accept4(m_fd, (sockaddr*)&in, &in_size, SOCK_NONBLOCK | SOCK_CLOEXEC); +#else int accepted_fd = ::accept(m_fd, (sockaddr*)&in, &in_size); +#endif + if (accepted_fd < 0) { perror("accept"); return nullptr; } +#ifdef AK_OS_MACOS + int option = 1; + (void)ioctl(m_fd, FIONBIO, &option); + (void)fcntl(accepted_fd, F_SETFD, FD_CLOEXEC); +#endif + return TCPSocket::construct(accepted_fd); } -- cgit v1.2.3