X-Git-Url: http://bilbo.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/3bf8dd63803f44adc6ef0fd84474b515b5df960c..0d3fb525534744cb1a0f7e0b664dbb3c2791e9cc:/src/mc/mc_api.hpp diff --git a/src/mc/mc_api.hpp b/src/mc/mc_api.hpp index f4aeb89d06..f6a4526155 100644 --- a/src/mc/mc_api.hpp +++ b/src/mc/mc_api.hpp @@ -8,6 +8,7 @@ #include "src/mc/mc_forward.hpp" #include "src/mc/mc_request.hpp" #include "src/mc/mc_state.hpp" +#include "xbt/automaton.hpp" #include "xbt/base.h" namespace simgrid { @@ -45,18 +46,21 @@ public: int get_actors_size() const; // COMMUNICATION APIs - 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; + 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(mc::RemotePtr const& comm_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; - smx_actor_t get_src_actor(mc::RemotePtr const& comm_addr) const; - smx_actor_t get_dst_actor(mc::RemotePtr const& comm_addr) 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 APIs std::size_t get_remote_heap_bytes() const; @@ -69,25 +73,25 @@ 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 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; @@ -99,12 +103,19 @@ public: simgrid::mc::Snapshot* take_snapshot(int num_state) const; // SESSION APIs - void s_initialize() const; + void session_initialize() const; void s_close() const; - void execute(Transition const& transition); + void execute(Transition const& transition) const; + + // AUTOMATION APIs + #if SIMGRID_HAVE_MC + void automaton_load(const char *file) const; + #endif + std::vector automaton_propositional_symbol_evaluate() const; + std::vector get_automaton_state() const; }; } // namespace mc } // namespace simgrid -#endif \ No newline at end of file +#endif