From 6ae5ae138e9dd397b95d9e7741a5b28f194705d0 Mon Sep 17 00:00:00 2001 From: Arnaud Giersch Date: Tue, 9 Jul 2019 15:07:23 +0200 Subject: [PATCH 1/1] Reduce dependency on ptrace. --- src/mc/ModelChecker.cpp | 46 ++++++---------------------------------- src/mc/remote/Client.cpp | 15 +++---------- 2 files changed, 9 insertions(+), 52 deletions(-) diff --git a/src/mc/ModelChecker.cpp b/src/mc/ModelChecker.cpp index 4250bffe34..d60341e051 100644 --- a/src/mc/ModelChecker.cpp +++ b/src/mc/ModelChecker.cpp @@ -14,7 +14,6 @@ #include "xbt/automaton.hpp" #include "xbt/system_error.hpp" -#include #include XBT_LOG_NEW_DEFAULT_SUBCATEGORY(mc_ModelChecker, mc, "ModelChecker"); @@ -72,7 +71,7 @@ void ModelChecker::start() // The model-checked process SIGSTOP itself to signal it's ready: const pid_t pid = process_->pid(); - pid_t res = waitpid(pid, &status, WAITPID_CHECKED_FLAGS); + pid_t res = waitpid(pid, &status, WUNTRACED | WAITPID_CHECKED_FLAGS); if (res < 0 || not WIFSTOPPED(status) || WSTOPSIG(status) != SIGSTOP) xbt_die("Could not wait model-checked process"); @@ -83,14 +82,8 @@ void ModelChecker::start() setup_ignore(); -#ifdef __linux__ - ptrace(PTRACE_SETOPTIONS, pid, nullptr, PTRACE_O_TRACEEXIT); - ptrace(PTRACE_CONT, pid, 0, 0); -#elif defined BSD - ptrace(PT_CONTINUE, pid, (caddr_t)1, 0); -#else -# error "no ptrace equivalent coded for this platform" -#endif + if (kill(pid, SIGCONT) != 0) + throw simgrid::xbt::errno_error("Could not wake up the model-checked process"); } static const std::pair ignored_local_variables[] = { @@ -310,36 +303,9 @@ void ModelChecker::handle_waitpid() } if (pid == this->process().pid()) { - - // From PTRACE_O_TRACEEXIT: -#ifdef __linux__ - if (status>>8 == (SIGTRAP | (PTRACE_EVENT_EXIT<<8))) { - if (ptrace(PTRACE_GETEVENTMSG, this->process().pid(), 0, &status) == -1) - xbt_die("Could not get exit status"); - if (WIFSIGNALED(status)) { - MC_report_crash(status); - mc_model_checker->exit(SIMGRID_MC_EXIT_PROGRAM_CRASH); - } - } -#endif - - // We don't care about signals, just reinject them: - if (WIFSTOPPED(status)) { - XBT_DEBUG("Stopped with signal %i", (int) WSTOPSIG(status)); - errno = 0; -#ifdef __linux__ - ptrace(PTRACE_CONT, this->process().pid(), 0, WSTOPSIG(status)); -#elif defined BSD - ptrace(PT_CONTINUE, this->process().pid(), (caddr_t)1, WSTOPSIG(status)); -#endif - if (errno != 0) - xbt_die("Could not PTRACE_CONT"); - } - - else if (WIFEXITED(status) || WIFSIGNALED(status)) { - XBT_DEBUG("Child process is over"); - this->process().terminate(); - } + xbt_assert(WIFEXITED(status) || WIFSIGNALED(status)); + XBT_DEBUG("Child process is over"); + this->process().terminate(); } } } diff --git a/src/mc/remote/Client.cpp b/src/mc/remote/Client.cpp index 4e774042b2..4a9f0bf79c 100644 --- a/src/mc/remote/Client.cpp +++ b/src/mc/remote/Client.cpp @@ -6,11 +6,10 @@ #include "src/mc/remote/Client.hpp" #include "src/internal_config.h" #include +#include -#include #include #include -#include #include #include @@ -57,16 +56,8 @@ Client* Client::initialize() instance_.reset(new simgrid::mc::Client(fd)); // Wait for the model-checker: - errno = 0; -#if defined __linux__ - ptrace(PTRACE_TRACEME, 0, nullptr, nullptr); -#elif defined BSD - ptrace(PT_TRACE_ME, 0, nullptr, 0); -#else -#error "no ptrace equivalent coded for this platform" -#endif - if (errno != 0 || raise(SIGSTOP) != 0) - xbt_die("Could not wait for the model-checker (errno = %d: %s)", errno, strerror(errno)); + if (raise(SIGSTOP) != 0) + throw simgrid::xbt::errno_error("Could not wait for the model-checker"); instance_->handle_messages(); return instance_.get(); -- 2.20.1