X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/ebadbf7894190d4c66238842db5f8931adb7df5b..29e064e4f1fd538a612d04c7430179e65ec82dfa:/src/mc/explo/simgrid_mc.cpp diff --git a/src/mc/explo/simgrid_mc.cpp b/src/mc/explo/simgrid_mc.cpp index 8da00022da..5d973689af 100644 --- a/src/mc/explo/simgrid_mc.cpp +++ b/src/mc/explo/simgrid_mc.cpp @@ -1,72 +1,59 @@ -/* Copyright (c) 2015-2022. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2015-2023. 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/internal_config.h" #include "src/mc/explo/Exploration.hpp" #include "src/mc/mc_config.hpp" #include "src/mc/mc_exit.hpp" +#include "src/simgrid/sg_config.hpp" #if HAVE_SMPI #include "smpi/smpi.h" #endif -#include -#include -#include +XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(mc); -using api = simgrid::mc::Api; - -static inline char** argvdup(int argc, char** argv) -{ - auto* argv_copy = new char*[argc + 1]; - std::memcpy(argv_copy, argv, sizeof(char*) * argc); - argv_copy[argc] = nullptr; - return argv_copy; -} +using namespace simgrid::mc; int main(int argc, char** argv) { xbt_assert(argc >= 2, "Missing arguments"); // Currently, we need this before sg_config_init: - _sg_do_model_check = 1; + simgrid::mc::set_model_checking_mode(simgrid::mc::ModelCheckingMode::CHECKER_SIDE); // 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); + std::vector argv_copy{argv, argv + argc + 1}; xbt_log_init(&argc, argv); #if HAVE_SMPI - smpi_init_options(); // only performed once + smpi_init_options(); // that's OK to call it twice, and we need it ASAP #endif sg_config_init(&argc, argv); - simgrid::mc::CheckerAlgorithm algo; + std::unique_ptr explo; + +#if SIMGRID_HAVE_STATEFUL_MC if (_sg_mc_comms_determinism || _sg_mc_send_determinism) - algo = simgrid::mc::CheckerAlgorithm::CommDeterminism; + explo = std::unique_ptr(create_communication_determinism_checker(argv_copy, cfg_use_DPOR())); else if (_sg_mc_unfolding_checker) - algo = simgrid::mc::CheckerAlgorithm::UDPOR; - else if (_sg_mc_property_file.get().empty()) - algo = simgrid::mc::CheckerAlgorithm::Safety; + explo = std::unique_ptr(create_udpor_checker(argv_copy)); + else if (not _sg_mc_property_file.get().empty()) + explo = std::unique_ptr(create_liveness_checker(argv_copy)); else - algo = simgrid::mc::CheckerAlgorithm::Liveness; +#endif + explo = std::unique_ptr(create_dfs_exploration(argv_copy, cfg_use_DPOR())); - int res = SIMGRID_MC_EXIT_SUCCESS; - auto checker = api::get().initialize(argv_copy, algo); try { - checker->run(); - } catch (const simgrid::mc::DeadlockError&) { - res = SIMGRID_MC_EXIT_DEADLOCK; - } catch (const simgrid::mc::TerminationError&) { - res = SIMGRID_MC_EXIT_NON_TERMINATION; - } catch (const simgrid::mc::LivenessError&) { - res = SIMGRID_MC_EXIT_LIVENESS; + explo->run(); + } catch (const DeadlockError&) { + return SIMGRID_MC_EXIT_DEADLOCK; + } catch (const TerminationError&) { + return SIMGRID_MC_EXIT_NON_TERMINATION; + } catch (const LivenessError&) { + return SIMGRID_MC_EXIT_LIVENESS; } - api::get().s_close(); - delete[] argv_copy; - // delete checker; SEGFAULT in liveness - return res; + return SIMGRID_MC_EXIT_SUCCESS; }