diff --git a/DevTools/Inspector/RemoteProcess.cpp b/DevTools/Inspector/RemoteProcess.cpp index 4c642ee45e..d1ceb61c3d 100644 --- a/DevTools/Inspector/RemoteProcess.cpp +++ b/DevTools/Inspector/RemoteProcess.cpp @@ -188,7 +188,7 @@ void RemoteProcess::update() } }; - auto success = m_socket->connect(Core::SocketAddress::local(String::format("/tmp/rpc.%d", m_pid))); + auto success = m_socket->connect(Core::SocketAddress::local(String::format("/tmp/rpc/%d", m_pid))); if (!success) { fprintf(stderr, "Couldn't connect to PID %d\n", m_pid); exit(1); diff --git a/Libraries/LibCore/EventLoop.cpp b/Libraries/LibCore/EventLoop.cpp index fdd82b8064..36e178f3d6 100644 --- a/Libraries/LibCore/EventLoop.cpp +++ b/Libraries/LibCore/EventLoop.cpp @@ -45,6 +45,7 @@ #include #include #include +#include #include #include #include @@ -250,8 +251,22 @@ EventLoop::~EventLoop() bool EventLoop::start_rpc_server() { - auto rpc_path = String::format("/tmp/rpc.%d", getpid()); - int rc = unlink(rpc_path.characters()); + // Create /tmp/rpc if it doesn't exist. + int rc = mkdir("/tmp/rpc", 0777); + if (rc == 0) { + // Ensure it gets created as 0777 despite our umask. + rc = chmod("/tmp/rpc", 0777); + if (rc < 0) { + perror("chmod /tmp/rpc"); + // Continue further. + } + } else if (errno != EEXIST) { + perror("mkdir /tmp/rpc"); + return false; + } + + auto rpc_path = String::format("/tmp/rpc/%d", getpid()); + rc = unlink(rpc_path.characters()); if (rc < 0 && errno != ENOENT) { perror("unlink"); return false;