X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9932a0c0d2c44e34633c97a827b2b04d615cb4e9..ab1a5770e72e90720fb1f2dc0901cda2573b208b:/include/simgrid/modelchecker.h diff --git a/include/simgrid/modelchecker.h b/include/simgrid/modelchecker.h index 3cc7e2d583..53e1214533 100644 --- a/include/simgrid/modelchecker.h +++ b/include/simgrid/modelchecker.h @@ -6,44 +6,45 @@ /* 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 #include "xbt/automaton.h" -#ifndef SIMGRID_MODELCHECKER_H -#define SIMGRID_MODELCHECKER_H - SG_BEGIN_DECL() -/** Replay path (if any) in string representation - * - * This is a path as generated by `MC_record_stack_to_string()`. - */ -XBT_PUBLIC_DATA(char*) MC_record_path; - -/** Whether the replay mode is enabled */ -static inline bool MC_record_replay_is_active(void) { - return MC_record_path; -} - XBT_PUBLIC(int) MC_random(int min, int max); #ifdef HAVE_MC -extern int _sg_do_model_check; /* please don't use directly: we inline MC_is_active, but that's what you should use */ +/* Internal variable used to check if we're running under the MC + * + * Please don't use directly: you should use MC_is_active. */ +extern int _sg_do_model_check; extern int _sg_mc_visited; #define MC_is_active() _sg_do_model_check #define MC_visited_reduction() _sg_mc_visited +/** 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_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_callback(const char* id, - xbt_automaton_propositional_symbol_callback_type callback, - void* data, xbt_automaton_propositional_symbol_free_function_type free_function); + XBT_PUBLIC(void *) MC_snapshot(void); XBT_PUBLIC(int) MC_compare_snapshots(void *s1, void *s2); XBT_PUBLIC(void) MC_cut(void); @@ -57,8 +58,6 @@ XBT_PUBLIC(void) MC_ignore(void *addr, size_t size); #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_automaton_new_propositional_symbol_callback(id,callback,data,free_function) \ - if(free_function) free_function(data); #define MC_snapshot() ((void*)0) #define MC_compare_snapshots(a, b) 0 #define MC_cut() ((void)0)