WindowServer: Open all fds as CLOEXEC

This will allow forking the window server cleanly :D
This commit is contained in:
Bananymous 2024-09-11 22:17:31 +03:00
parent 86dcb5c471
commit 98c011e6a6
2 changed files with 5 additions and 5 deletions

View File

@ -9,7 +9,7 @@
Framebuffer open_framebuffer() Framebuffer open_framebuffer()
{ {
int framebuffer_fd = open("/dev/fb0", O_RDWR); int framebuffer_fd = open("/dev/fb0", O_RDWR | O_CLOEXEC);
if (framebuffer_fd == -1) if (framebuffer_fd == -1)
{ {
perror("open"); perror("open");

View File

@ -104,7 +104,7 @@ int open_server_fd()
if (stat(LibGUI::s_window_server_socket.data(), &st) != -1) if (stat(LibGUI::s_window_server_socket.data(), &st) != -1)
unlink(LibGUI::s_window_server_socket.data()); unlink(LibGUI::s_window_server_socket.data());
int server_fd = socket(AF_UNIX, SOCK_SEQPACKET, 0); int server_fd = socket(AF_UNIX, SOCK_SEQPACKET | SOCK_CLOEXEC, 0);
if (server_fd == -1) if (server_fd == -1)
{ {
perror("socket"); perror("socket");
@ -158,11 +158,11 @@ int main()
MUST(LibInput::KeyboardLayout::initialize()); MUST(LibInput::KeyboardLayout::initialize());
MUST(LibInput::KeyboardLayout::get().load_from_file("/usr/share/keymaps/us.keymap"_sv)); MUST(LibInput::KeyboardLayout::get().load_from_file("/usr/share/keymaps/us.keymap"_sv));
int keyboard_fd = open("/dev/keyboard", O_RDONLY); int keyboard_fd = open("/dev/keyboard", O_RDONLY | O_CLOEXEC);
if (keyboard_fd == -1) if (keyboard_fd == -1)
perror("open"); perror("open");
int mouse_fd = open("/dev/mouse", O_RDONLY); int mouse_fd = open("/dev/mouse", O_RDONLY | O_CLOEXEC);
if (mouse_fd == -1) if (mouse_fd == -1)
perror("open"); perror("open");
@ -228,7 +228,7 @@ int main()
if (FD_ISSET(server_fd, &fds)) if (FD_ISSET(server_fd, &fds))
{ {
int window_fd = accept(server_fd, nullptr, nullptr); int window_fd = accept4(server_fd, nullptr, nullptr, SOCK_CLOEXEC);
if (window_fd == -1) if (window_fd == -1)
{ {
dwarnln("accept: {}", strerror(errno)); dwarnln("accept: {}", strerror(errno));