1 /* Copyright (c) 2015-2023. The SimGrid Team. All rights reserved. */
3 /* This program is free software; you can redistribute it and/or modify it
4 * under the terms of the license (GNU LGPL) which comes with this package. */
6 #ifndef SIMGRID_MC_TRANSITION_HPP
7 #define SIMGRID_MC_TRANSITION_HPP
9 #include "simgrid/forward.h" // aid_t
10 #include "xbt/utility.hpp" // XBT_DECLARE_ENUM_CLASS
15 namespace simgrid::mc {
17 /** An element in the recorded path
19 * At each decision point, we need to record which process transition
20 * is triggered and potentially which value is associated with this
21 * transition. The value is used to find which communication is triggered
22 * in things like waitany and for associating a given value of MC_random()
26 /* Textual representation of the transition, to display backtraces */
27 static unsigned long executed_transitions_;
28 static unsigned long replayed_transitions_;
30 friend State; // FIXME remove this once we have a proper class to handle the statistics
33 /* Ordering is important here. depends() implementations only consider subsequent types in this ordering */
34 XBT_DECLARE_ENUM_CLASS(Type, RANDOM, ACTOR_JOIN, /* First because indep with anybody including themselves */
35 OBJECT_ACCESS, /* high priority because indep with almost everybody */
36 TESTANY, WAITANY, /* high priority because they can rewrite themselves to *_WAIT */
37 BARRIER_ASYNC_LOCK, BARRIER_WAIT, /* BARRIER transitions sorted alphabetically */
38 COMM_ASYNC_RECV, COMM_ASYNC_SEND, COMM_TEST, COMM_WAIT, /* Alphabetical ordering of COMM_* */
39 MUTEX_ASYNC_LOCK, MUTEX_TEST, MUTEX_TRYLOCK, MUTEX_UNLOCK, MUTEX_WAIT, /* alphabetical */
40 SEM_ASYNC_LOCK, SEM_UNLOCK, SEM_WAIT, /* alphabetical ordering of SEM transitions */
41 /* UNKNOWN must be last */ UNKNOWN);
42 Type type_ = Type::UNKNOWN;
46 /** The user function call that caused this transition to exist. Format: >>filename:line:function()<< */
47 std::string call_location_ = "";
49 /* Which transition was executed for this simcall
51 * Some simcalls can lead to different transitions:
53 * * waitany/testany can trigger on different messages;
55 * * random can produce different values.
57 int times_considered_ = 0;
59 Transition() = default;
60 Transition(Type type, aid_t issuer, int times_considered)
61 : type_(type), aid_(issuer), times_considered_(times_considered)
64 virtual ~Transition();
66 /** Returns a textual representation of the transition. Pointer adresses are omitted if verbose=false */
67 virtual std::string to_string(bool verbose = false) const;
68 /** Returns something like >>label = "desc", color = c<< to describe the transition in dot format */
69 virtual std::string dot_string() const;
71 std::string const& get_call_location() const { return call_location_; }
73 /* Moves the application toward a path that was already explored, but don't change the current transition */
74 void replay(RemoteApp& app) const;
76 virtual bool depends(const Transition* other) const { return true; }
78 /* Returns the total amount of transitions executed so far (for statistics) */
79 static unsigned long get_executed_transitions() { return executed_transitions_; }
80 /* Returns the total amount of transitions replayed so far while backtracing (for statistics) */
81 static unsigned long get_replayed_transitions() { return replayed_transitions_; }
84 /** Make a new transition from serialized description */
85 Transition* deserialize_transition(aid_t issuer, int times_considered, std::stringstream& stream);
87 } // namespace simgrid::mc