X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/50102ec1c30562e20d450afa7015374387bf1904..5824e3e084f8021554e73ba26124bd5ed2933b59:/src/mc/checker/simgrid_mc.cpp diff --git a/src/mc/checker/simgrid_mc.cpp b/src/mc/checker/simgrid_mc.cpp index e382e9ff9f..0cc4ffe173 100644 --- a/src/mc/checker/simgrid_mc.cpp +++ b/src/mc/checker/simgrid_mc.cpp @@ -1,16 +1,14 @@ -/* Copyright (c) 2015-2020. The SimGrid Team. +/* Copyright (c) 2015-2022. The SimGrid Team. * All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ #include "simgrid/sg_config.hpp" -#include "src/mc/Session.hpp" #include "src/mc/checker/Checker.hpp" #include "src/mc/mc_config.hpp" #include "src/mc/mc_exit.hpp" #include "src/internal_config.h" -#include "src/mc/mc_api.hpp" #if HAVE_SMPI #include "smpi/smpi.h" @@ -20,7 +18,7 @@ #include #include -using mcapi = simgrid::mc::mc_api; +using api = simgrid::mc::Api; static inline char** argvdup(int argc, char** argv) @@ -31,20 +29,9 @@ char** argvdup(int argc, char** argv) return argv_copy; } -static std::unique_ptr create_checker(simgrid::mc::Session& session) -{ - if (_sg_mc_comms_determinism || _sg_mc_send_determinism) - return std::unique_ptr(simgrid::mc::createCommunicationDeterminismChecker(session)); - else if (_sg_mc_property_file.get().empty()) - return std::unique_ptr(simgrid::mc::createSafetyChecker(session)); - else - return std::unique_ptr(simgrid::mc::createLivenessChecker(session)); -} - int main(int argc, char** argv) { - if (argc < 2) - xbt_die("Missing arguments.\n"); + xbt_assert(argc >= 2, "Missing arguments"); // Currently, we need this before sg_config_init: _sg_do_model_check = 1; @@ -52,16 +39,25 @@ int main(int argc, char** argv) // The initialization function can touch argv. // We make a copy of argv before modifying it in order to pass the original value to the model-checked application: char** argv_copy = argvdup(argc, argv); + xbt_log_init(&argc, argv); #if HAVE_SMPI smpi_init_options(); // only performed once #endif sg_config_init(&argc, argv); - mcapi::get().initialize(argv_copy); - delete[] argv_copy; - auto checker = create_checker(*simgrid::mc::session); + simgrid::mc::CheckerAlgorithm algo; + if (_sg_mc_comms_determinism || _sg_mc_send_determinism) + algo = simgrid::mc::CheckerAlgorithm::CommDeterminism; + else if (_sg_mc_unfolding_checker) + algo = simgrid::mc::CheckerAlgorithm::UDPOR; + else if (_sg_mc_property_file.get().empty()) + algo = simgrid::mc::CheckerAlgorithm::Safety; + else + algo = simgrid::mc::CheckerAlgorithm::Liveness; + int res = SIMGRID_MC_EXIT_SUCCESS; + auto checker = api::get().initialize(argv_copy, algo); try { checker->run(); } catch (const simgrid::mc::DeadlockError&) { @@ -71,7 +67,8 @@ int main(int argc, char** argv) } catch (const simgrid::mc::LivenessError&) { res = SIMGRID_MC_EXIT_LIVENESS; } - checker = nullptr; - mcapi::get().s_close(); + api::get().s_close(); + delete[] argv_copy; + delete checker; return res; }