X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/d4f9d0cf42605d96b91088c02ddfbf2411f89de1..8e9294e3388ad80f5c39c6489cd0f49a5b3bd9eb:/include/simgrid/modelchecker.h?ds=sidebyside diff --git a/include/simgrid/modelchecker.h b/include/simgrid/modelchecker.h index 0579ca6e2a..69217b7e43 100644 --- a/include/simgrid/modelchecker.h +++ b/include/simgrid/modelchecker.h @@ -1,52 +1,44 @@ /* simgrid/modelchecker.h - Formal Verification made possible in SimGrid */ -/* Copyright (c) 2008-2015. The SimGrid Team. - * All rights reserved. */ +/* Copyright (c) 2008-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. */ -/** \file modelchecker.h - * - * This is the API used by the user simulated program to communicate - * with the MC. - */ - #ifndef SIMGRID_MODELCHECKER_H #define SIMGRID_MODELCHECKER_H -#include - -#include /* HAVE_MC ? */ - +#include /* SIMGRID_HAVE_MC ? */ #include -SG_BEGIN_DECL() +#include /* size_t */ -XBT_PUBLIC(int) MC_random(int min, int max); +SG_BEGIN_DECL -#if HAVE_MC +/** Explore every branches where that function returns a value between min and max (inclusive) */ +XBT_PUBLIC int MC_random(int min, int max); -/* Internal variable used to check if we're running under the MC - * - * Please don't use directly: you should use MC_is_active. */ -extern XBT_PUBLIC(int) _sg_do_model_check; -extern XBT_PUBLIC(int) _sg_mc_visited; +#if SIMGRID_HAVE_MC + +/* Internal variable used to check if we're running under the MC. Please use MC_is_active instead. */ +extern XBT_PUBLIC int _sg_do_model_check; +extern XBT_PUBLIC int _sg_mc_max_visited_states; -#define MC_is_active() _sg_do_model_check -#define MC_visited_reduction() _sg_mc_visited +#define MC_is_active() _sg_do_model_check +#define MC_visited_reduction() _sg_mc_max_visited_states /** Assertion for the model-checker * * This function is used to define safety properties to verify. */ -XBT_PUBLIC(void) MC_assert(int); +XBT_PUBLIC void MC_assert(int); -XBT_PUBLIC(void) MC_automaton_new_propositional_symbol(const char* id, int(*fct)(void)); -XBT_PUBLIC(void) MC_automaton_new_propositional_symbol_pointer(const char *id, int* value); +XBT_PUBLIC void MC_automaton_new_propositional_symbol(const char* id, int (*fct)(void)); +XBT_PUBLIC void MC_automaton_new_propositional_symbol_pointer(const char* id, int* value); -XBT_PUBLIC(void) MC_cut(void); -XBT_PUBLIC(void) MC_ignore(void *addr, size_t size); +XBT_PUBLIC void MC_ignore(void* addr, size_t size); +XBT_PUBLIC void MC_ignore_heap(void* address, size_t size); +XBT_PUBLIC void MC_unignore_heap(void* address, size_t size); #else @@ -54,13 +46,16 @@ XBT_PUBLIC(void) MC_ignore(void *addr, size_t size); #define MC_visited_reduction() 0 #define MC_assert(a) xbt_assert(a) + #define MC_automaton_new_propositional_symbol(a, b) ((void)0) #define MC_automaton_new_propositional_symbol_pointer(a, b) ((void)0) -#define MC_cut() ((void)0) -#define MC_ignore(a, b) ((void)0) + +#define MC_ignore(a, b) ((void)0) +#define MC_ignore_heap(a, s) ((void)0) +#define MC_unignore_heap(a, s) ((void)0) #endif -SG_END_DECL() +SG_END_DECL #endif /* SIMGRID_MODELCHECKER_H */