X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/fa222c38f9b796be07ab4351ffc810a61a8fd705..ad9d9459261f6f55f69edc333689ad86f2a9f229:/src/mc/mc_base.h diff --git a/src/mc/mc_base.h b/src/mc/mc_base.h index a72fbce3e4..9e74d3976f 100644 --- a/src/mc/mc_base.h +++ b/src/mc/mc_base.h @@ -7,29 +7,27 @@ #ifndef SIMGRID_MC_BASE_H #define SIMGRID_MC_BASE_H -#include -#include -#include "simgrid_config.h" -#include "internal_config.h" -#include "../simix/smx_private.h" +#ifdef __cplusplus +#include +#endif -// Marker for symbols which should be defined as XBT_PRIVATE but are used in -// unit tests: -#define MC_SHOULD_BE_INTERNAL +#include -SG_BEGIN_DECL() +typedef struct s_smx_simcall s_smx_simcall_t, *smx_simcall_t; -/** Check if the given simcall can be resolved - * - * \return `TRUE` or `FALSE` - */ -int MC_request_is_enabled(smx_simcall_t req); +#ifdef __cplusplus -/** Check if the given simcall is visible +namespace simgrid { +namespace mc { + +/** Can this requests can be executed? * - * \return `TRUE` or `FALSE` + * Most requests are always enabled but WAIT and WAITANY + * are not always enabled: a WAIT where the communication does not + * have both a source and a destination yet is not enabled + * (unless timeout is enabled in the wait and enabeld in SimGridMC). */ -int MC_request_is_visible(smx_simcall_t req); +XBT_PRIVATE bool request_is_enabled(smx_simcall_t req); /** Execute everything which is invisible * @@ -37,10 +35,22 @@ int MC_request_is_visible(smx_simcall_t req); * iteratively until there doesn't remain any. At this point, the function * returns to the caller which can handle the visible (and ready) simcalls. */ -void MC_wait_for_requests(void); +XBT_PRIVATE void wait_for_requests(void); + +XBT_PRIVATE extern std::vector processes_time; -XBT_INTERNAL extern double *mc_time; +/** Execute a given simcall */ +XBT_PRIVATE void handle_simcall(smx_simcall_t req, int req_num); -SG_END_DECL() +/** Check if the given simcall is visible + * + * \return `TRUE` or `FALSE` + */ +XBT_PRIVATE bool request_is_visible(smx_simcall_t req); + +} +} + +#endif #endif