X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/42e47242b26a374aa63a9a29b1ac79c443213220..301109703c933c28285e0223836a570eaeb8875a:/src/mc/mc_config.cpp diff --git a/src/mc/mc_config.cpp b/src/mc/mc_config.cpp index 63a083e4f8..b4900fe947 100644 --- a/src/mc/mc_config.cpp +++ b/src/mc/mc_config.cpp @@ -1,12 +1,12 @@ -/* Copyright (c) 2008-2022. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2008-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 "src/mc/mc_config.hpp" #include "src/mc/mc_replay.hpp" +#include "src/simgrid/sg_config.hpp" #include -#include #if SIMGRID_HAVE_MC #include @@ -14,13 +14,15 @@ XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(xbt_cfg); -bool simgrid::mc::cfg_do_model_check = 0; +bool simgrid::mc::cfg_do_model_check = false; static void _mc_cfg_cb_check(const char* spec, bool more_check = true) { #if SIMGRID_HAVE_MC - xbt_assert(_sg_cfg_init_status == 0 || MC_is_active() || not more_check, - "Specifying a %s is only allowed within the model-checker. Please use simgrid-mc.", spec); + xbt_assert(_sg_cfg_init_status == 0 || MC_is_active() || MC_record_replay_is_active() || not more_check, + "Specifying a %s is only allowed within the model-checker. Please use simgrid-mc, or specify this option " + "after the replay path.", + spec); #else xbt_die("Specifying a %s is only allowed within the model-checker. Please enable it before the compilation.", spec); #endif @@ -46,6 +48,10 @@ static simgrid::config::Flag cfg_mc_reduction{ xbt_die("configuration option 'model-check/reduction' can only take 'none' or 'dpor' as a value"); }}; +simgrid::config::Flag _sg_mc_sleep_set{ + "model-check/sleep-set", "Whether to enable the use of sleep-set in the reduction algorithm", false, + [](bool) { _mc_cfg_cb_check("value to enable/disable the use of sleep-set in the reduction algorithm"); }}; + simgrid::config::Flag _sg_mc_checkpoint{ "model-check/checkpoint", "Specify the amount of steps between checkpoints during stateful model-checking " "(default: 0 => stateless verification). If value=1, one checkpoint is saved for each "