X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/a9919f554fd42fdb9a26defe86adbb1c3cfa59bd..4bd2cbe6c40e96efdbf49550cc66bb9e35df8b94:/src/mc/ModelChecker.cpp diff --git a/src/mc/ModelChecker.cpp b/src/mc/ModelChecker.cpp index af180ca3df..956f5f13d1 100644 --- a/src/mc/ModelChecker.cpp +++ b/src/mc/ModelChecker.cpp @@ -30,6 +30,9 @@ #include "src/mc/mc_private.h" #include "src/mc/mc_ignore.h" #include "src/mc/mc_exit.h" +#include "src/mc/mc_record.h" +#include "src/mc/Transition.hpp" +#include "src/mc/Checker.hpp" XBT_LOG_NEW_DEFAULT_SUBCATEGORY(mc_ModelChecker, mc, "ModelChecker"); @@ -79,7 +82,7 @@ void ModelChecker::start() sigemptyset(&set); sigaddset(&set, SIGCHLD); if (sigprocmask(SIG_BLOCK, &set, nullptr) == -1) - throw simgrid::xbt::errno_error(errno); + throw simgrid::xbt::errno_error(); sigset_t full_set; sigfillset(&full_set); @@ -93,7 +96,7 @@ void ModelChecker::start() int signal_fd = signalfd(-1, &set, 0); if (signal_fd == -1) - throw simgrid::xbt::errno_error(errno); + throw simgrid::xbt::errno_error(); struct pollfd* signalfd_pollfd = &fds_[SIGNAL_FD_INDEX]; signalfd_pollfd->fd = signal_fd; @@ -110,10 +113,6 @@ void ModelChecker::start() process_->init(); - /* Initialize statistics */ - mc_stats = xbt_new0(s_mc_stats_t, 1); - mc_stats->state_size = 1; - if ((_sg_mc_dot_output_file != nullptr) && (_sg_mc_dot_output_file[0] != '\0')) MC_init_dot_output(); @@ -171,7 +170,7 @@ void ModelChecker::resume(simgrid::mc::Process& process) { int res = process.getChannel().send(MC_MESSAGE_CONTINUE); if (res) - throw simgrid::xbt::errno_error(res); + throw simgrid::xbt::errno_error(); process.clear_cache(); } @@ -182,7 +181,41 @@ void throw_socket_error(int fd) socklen_t errlen = sizeof(error); if (getsockopt(fd, SOL_SOCKET, SO_ERROR, (void *)&error, &errlen) == -1) error = errno; - throw simgrid::xbt::errno_error(errno); + throw simgrid::xbt::errno_error(); +} + +static void MC_report_crash(int status) +{ + XBT_INFO("**************************"); + XBT_INFO("** CRASH IN THE PROGRAM **"); + XBT_INFO("**************************"); + if (WIFSIGNALED(status)) + XBT_INFO("From signal: %s", strsignal(WTERMSIG(status))); + else if (WIFEXITED(status)) + XBT_INFO("From exit: %i", WEXITSTATUS(status)); + if (WCOREDUMP(status)) + XBT_INFO("A core dump was generated by the system."); + else + XBT_INFO("No core dump was generated by the system."); + XBT_INFO("Counter-example execution trace:"); + simgrid::mc::dumpRecordPath(); + for (auto& s : mc_model_checker->getChecker()->getTextualTrace()) + XBT_INFO("%s", s.c_str()); + simgrid::mc::session->logState(); + XBT_INFO("Stack trace:"); + mc_model_checker->process().dumpStack(); +} + +static void MC_report_assertion_error(void) +{ + XBT_INFO("**************************"); + XBT_INFO("*** PROPERTY NOT VALID ***"); + XBT_INFO("**************************"); + XBT_INFO("Counter-example execution trace:"); + simgrid::mc::dumpRecordPath(); + for (auto& s : mc_model_checker->getChecker()->getTextualTrace()) + XBT_INFO("%s", s.c_str()); + simgrid::mc::session->logState(); } bool ModelChecker::handle_message(char* buffer, ssize_t size) @@ -300,7 +333,7 @@ bool ModelChecker::handle_events() case EINTR: continue; default: - throw simgrid::xbt::errno_error(errno); + throw simgrid::xbt::errno_error(); } } @@ -308,7 +341,7 @@ bool ModelChecker::handle_events() if (socket_pollfd->revents & POLLIN) { ssize_t size = process_->getChannel().receive(buffer, sizeof(buffer), false); if (size == -1 && errno != EAGAIN) - throw simgrid::xbt::errno_error(errno); + throw simgrid::xbt::errno_error(); return handle_message(buffer, size); } if (socket_pollfd->revents & POLLERR) @@ -347,7 +380,7 @@ void ModelChecker::handle_signals() if (errno == EINTR) continue; else - throw simgrid::xbt::errno_error(errno); + throw simgrid::xbt::errno_error(); } else if (size != sizeof(info)) return throw std::runtime_error( "Bad communication with model-checked application"); @@ -372,7 +405,7 @@ void ModelChecker::handle_waitpid() break; } else { XBT_ERROR("Could not wait for pid"); - throw simgrid::xbt::errno_error(errno); + throw simgrid::xbt::errno_error(); } } @@ -422,16 +455,16 @@ void ModelChecker::wait_client(simgrid::mc::Process& process) return; } -void ModelChecker::simcall_handle(simgrid::mc::Process& process, unsigned long pid, int value) +void ModelChecker::handle_simcall(Transition const& transition) { s_mc_simcall_handle_message m; memset(&m, 0, sizeof(m)); m.type = MC_MESSAGE_SIMCALL_HANDLE; - m.pid = pid; - m.value = value; - process.getChannel().send(m); - process.clear_cache(); - while (process.running()) + m.pid = transition.pid; + m.value = transition.argument; + this->process_->getChannel().send(m); + this->process_->clear_cache(); + while (this->process_->running()) if (!this->handle_events()) return; }