X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/98a167fa2243c248259017276314ff93c8e841fe..8d000a773b5ebcd411b28c31de68eeddf804e66b:/src/mc/ModelChecker.cpp?ds=sidebyside diff --git a/src/mc/ModelChecker.cpp b/src/mc/ModelChecker.cpp index 9ceba066cc..5c947d25a6 100644 --- a/src/mc/ModelChecker.cpp +++ b/src/mc/ModelChecker.cpp @@ -22,14 +22,13 @@ #include "simgrid/sg_config.h" -#include "ModelChecker.hpp" -#include "PageStore.hpp" -#include "ModelChecker.hpp" -#include "mc_protocol.h" -#include "mc_private.h" -#include "mc_ignore.h" -#include "mcer_ignore.h" -#include "mc_exit.h" +#include "src/mc/ModelChecker.hpp" +#include "src/mc/PageStore.hpp" +#include "src/mc/ModelChecker.hpp" +#include "src/mc/mc_protocol.h" +#include "src/mc/mc_private.h" +#include "src/mc/mc_ignore.h" +#include "src/mc/mc_exit.h" #include "src/mc/mc_liveness.h" extern "C" { @@ -131,31 +130,36 @@ void ModelChecker::start() ptrace(PTRACE_CONT, pid_, 0, 0); } -void ModelChecker::setup_ignore() -{ - /* Ignore some variables from xbt/ex.h used by exception e for stacks comparison */ - MC_ignore_local_variable("e", "*"); - MC_ignore_local_variable("__ex_cleanup", "*"); - MC_ignore_local_variable("__ex_mctx_en", "*"); - MC_ignore_local_variable("__ex_mctx_me", "*"); - MC_ignore_local_variable("__xbt_ex_ctx_ptr", "*"); - MC_ignore_local_variable("_log_ev", "*"); - MC_ignore_local_variable("_throw_ctx", "*"); - MC_ignore_local_variable("ctx", "*"); - - MC_ignore_local_variable("self", "simcall_BODY_mc_snapshot"); - MC_ignore_local_variable("next_cont" - "ext", "smx_ctx_sysv_suspend_serial"); - MC_ignore_local_variable("i", "smx_ctx_sysv_suspend_serial"); +static const std::pair ignored_local_variables[] = { + std::pair{ "e", "*" }, + std::pair{ "__ex_cleanup", "*" }, + std::pair{ "__ex_mctx_en", "*" }, + std::pair{ "__ex_mctx_me", "*" }, + std::pair{ "__xbt_ex_ctx_ptr", "*" }, + std::pair{ "_log_ev", "*" }, + std::pair{ "_throw_ctx", "*" }, + std::pair{ "ctx", "*" }, + + std::pair{ "self", "simcall_BODY_mc_snapshot" }, + std::pair{ "next_context", "smx_ctx_sysv_suspend_serial" }, + std::pair{ "i", "smx_ctx_sysv_suspend_serial" }, /* Ignore local variable about time used for tracing */ - MC_ignore_local_variable("start_time", "*"); + std::pair{ "start_time", "*" }, +}; + +void ModelChecker::setup_ignore() +{ + Process& process = this->process(); + for (std::pair const& var : + ignored_local_variables) + process.ignore_local_variable(var.first, var.second); /* Static variable used for tracing */ - MCer_ignore_global_variable("counter"); + process.ignore_global_variable("counter"); /* SIMIX */ - MCer_ignore_global_variable("smx_total_comms"); + process.ignore_global_variable("smx_total_comms"); } void ModelChecker::shutdown() @@ -203,9 +207,13 @@ bool ModelChecker::handle_message(char* buffer, ssize_t size) if (size != sizeof(message)) xbt_die("Broken messsage"); memcpy(&message, buffer, sizeof(message)); - mc_heap_ignore_region_t region = xbt_new(s_mc_heap_ignore_region_t, 1); - *region = message.region; - MC_heap_region_ignore_insert(region); + + IgnoredHeapRegion region; + region.block = message.block; + region.fragment = message.fragment; + region.address = message.address; + region.size = message.size; + process().ignore_heap(region); break; } @@ -215,7 +223,7 @@ bool ModelChecker::handle_message(char* buffer, ssize_t size) if (size != sizeof(message)) xbt_die("Broken messsage"); memcpy(&message, buffer, sizeof(message)); - MC_heap_region_ignore_remove( + process().unignore_heap( (void *)(std::uintptr_t) message.addr, message.size); break; } @@ -236,9 +244,7 @@ bool ModelChecker::handle_message(char* buffer, ssize_t size) if (size != sizeof(message)) xbt_die("Broken messsage"); memcpy(&message, buffer, sizeof(message)); - stack_region_t stack_region = xbt_new(s_stack_region_t, 1); - *stack_region = message.stack_region; - MC_stack_area_add(stack_region); + this->process().stack_areas().push_back(message.stack_region); } break;