WindowServer: Open all fds as CLOEXEC
This will allow forking the window server cleanly :D
This commit is contained in:
parent
86dcb5c471
commit
98c011e6a6
|
@ -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");
|
||||||
|
|
|
@ -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));
|
||||||
|
|
Loading…
Reference in New Issue