X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/f0e56bf82001574ff1b593f79b84c6330b751261..872d65264714799b25eb231609c3f05bae3d03dc:/src/mc/CommunicationDeterminismChecker.hpp diff --git a/src/mc/CommunicationDeterminismChecker.hpp b/src/mc/CommunicationDeterminismChecker.hpp index 4c00ce6273..6235b80d10 100644 --- a/src/mc/CommunicationDeterminismChecker.hpp +++ b/src/mc/CommunicationDeterminismChecker.hpp @@ -19,7 +19,7 @@ namespace simgrid { namespace mc { -class CommunicationDeterminismChecker : public Checker { +class XBT_PRIVATE CommunicationDeterminismChecker : public Checker { public: CommunicationDeterminismChecker(Session& session); ~CommunicationDeterminismChecker(); @@ -29,10 +29,26 @@ public: private: void prepare(); int main(); + void logState() override; + void deterministic_comm_pattern(int process, simgrid::mc::PatternCommunication* comm, int backtracking); + void restoreState(); +public: + // These are used by functions which should be moved in CommunicationDeterminismChecker: + void get_comm_pattern(xbt_dynar_t list, smx_simcall_t request, e_mc_call_type_t call_type, int backtracking); + void complete_comm_pattern( + xbt_dynar_t list, simgrid::mc::RemotePtr comm_addr, + unsigned int issuer, int backtracking); private: /** Stack representing the position in the exploration graph */ std::list> stack_; simgrid::mc::VisitedStates visitedStates_; + unsigned long expandedStatesCount_ = 0; + + int initial_communications_pattern_done = 0; + int recv_deterministic = 0; + int send_deterministic = 0; + char *send_diff = nullptr; + char *recv_diff = nullptr; }; #endif