X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/3586592c9ea0c8b4e934a29126c75de611bbc61c..7792ce44dc2744211836680af4775a35a823b242:/src/mc/mc_api.hpp diff --git a/src/mc/mc_api.hpp b/src/mc/mc_api.hpp index b551b33c87..8446162e61 100644 --- a/src/mc/mc_api.hpp +++ b/src/mc/mc_api.hpp @@ -38,26 +38,33 @@ public: void initialize(char** argv); - // ACTOR FUNCTIONS + // ACTOR APIs std::vector& get_actors() const; bool actor_is_enabled(aid_t pid) const; unsigned long get_maxpid() const; + int get_actors_size() const; - // COMM FUNCTIONS - void copy_incomplete_comm_pattern(const simgrid::mc::State* state) const; - void copy_index_comm_pattern(const simgrid::mc::State* state) const; - kernel::activity::CommImpl* get_pattern_comm_addr(smx_simcall_t request) const; + // COMMUNICATION APIs + bool comm_addr_equal(const kernel::activity::CommImpl* comm_addr1, const kernel::activity::CommImpl* comm_addr2) const; + kernel::activity::CommImpl* get_comm_isend_raw_addr(smx_simcall_t request) const; + kernel::activity::CommImpl* get_comm_wait_raw_addr(smx_simcall_t request) const; + kernel::activity::CommImpl* get_comm_waitany_raw_addr(smx_simcall_t request, int value) const; std::string get_pattern_comm_rdv(void* addr) const; unsigned long get_pattern_comm_src_proc(void* addr) const; unsigned long get_pattern_comm_dst_proc(void* addr) const; std::vector get_pattern_comm_data(void* addr) const; + std::vector get_pattern_comm_data(const kernel::activity::CommImpl* comm_addr) const; const char* get_actor_host_name(smx_actor_t actor) const; +#if HAVE_SMPI bool check_send_request_detached(smx_simcall_t const& simcall) const; +#endif + smx_actor_t get_src_actor(const kernel::activity::CommImpl* comm_addr) const; + smx_actor_t get_dst_actor(const kernel::activity::CommImpl* comm_addr) const; - // REMOTE + // REMOTE APIs std::size_t get_remote_heap_bytes() const; - // MODEL_CHECKER FUNCTIONS + // MODEL CHECKER APIs ModelChecker* get_model_checker() const; void mc_inc_visited_states() const; void mc_inc_executed_trans() const; @@ -65,39 +72,47 @@ public: unsigned long mc_get_executed_trans() const; bool mc_check_deadlock() const; void mc_show_deadlock() const; - smx_actor_t mc_smx_simcall_get_issuer(s_smx_simcall const* req) const; bool mc_is_null() const; Checker* mc_get_checker() const; RemoteSimulation& mc_get_remote_simulation() const; void handle_simcall(Transition const& transition) const; void mc_wait_for_requests() const; - void mc_exit(int status) const; + XBT_ATTRIB_NORETURN void mc_exit(int status) const; std::string const& mc_get_host_name(std::string const& hostname) const; - void mc_dump_record_path() const; + void dump_record_path() const; smx_simcall_t mc_state_choose_request(simgrid::mc::State* state) const; - // SIMCALL FUNCTIONS + // SIMCALL APIs bool request_depend(smx_simcall_t req1, smx_simcall_t req2) const; std::string request_to_string(smx_simcall_t req, int value, RequestType request_type) const; std::string request_get_dot_output(smx_simcall_t req, int value) const; - const char *simix_simcall_name(simgrid::simix::Simcall kind) const; - #if HAVE_SMPI + const char *simcall_get_name(simgrid::simix::Simcall kind) const; + smx_actor_t simcall_get_issuer(s_smx_simcall const* req) const; +#if HAVE_SMPI int get_smpi_request_tag(smx_simcall_t const& simcall, simgrid::simix::Simcall type) const; - #endif +#endif + + // STATE APIs + void restore_state(std::shared_ptr system_state) const; + void log_state() const; + void restore_initial_state() const; - // SNAPSHOT FUNCTIONS + // SNAPSHOT APIs bool snapshot_equal(const Snapshot* s1, const Snapshot* s2) const; simgrid::mc::Snapshot* take_snapshot(int num_state) const; - // SESSION FUNCTIONS - void s_initialize() const; + // SESSION APIs + void session_initialize() const; void s_close() const; - void s_restore_initial_state() const; - void execute(Transition const& transition); - void s_log_state() const; + void execute(Transition const& transition) const; + + // Global APIs + #if SIMGRID_HAVE_MC + void automaton_load(const char *file) const; + #endif }; } // namespace mc } // namespace simgrid -#endif \ No newline at end of file +#endif