X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/07c319ec54d6fc778ee3cc5e75a747242006723e..42cdb08adb14105f0a0398e9ede13ed3148cbcdc:/src/mc/private.h diff --git a/src/mc/private.h b/src/mc/private.h index 48f1ea8381..a21924521c 100644 --- a/src/mc/private.h +++ b/src/mc/private.h @@ -14,7 +14,6 @@ #include "mc/mc.h" #include "mc/datatypes.h" #include "xbt/fifo.h" -#include "xbt/setset.h" #include "xbt/config.h" #include "xbt/function_types.h" #include "xbt/mmalloc.h" @@ -42,20 +41,19 @@ void MC_free_snapshot(mc_snapshot_t); /* Bound of the MC depth-first search algorithm */ #define MAX_DEPTH 1000 -typedef enum{MC_EXPLORE=0, MC_STOP, MC_DEADLOCK, MC_INVPROP} e_mc_exp_ctl_t; - -e_mc_exp_ctl_t *mc_exp_ctl; - -void MC_show_stack(xbt_fifo_t stack); -void MC_dump_stack(xbt_fifo_t stack); +int MC_deadlock_check(void); void MC_replay(xbt_fifo_t stack); void MC_wait_for_requests(void); void MC_get_enabled_processes(); void MC_show_deadlock(smx_req_t req); +void MC_show_stack(xbt_fifo_t stack); +void MC_dump_stack(xbt_fifo_t stack); /********************************* Requests ***********************************/ int MC_request_depend(smx_req_t req1, smx_req_t req2); char* MC_request_to_string(smx_req_t req); +unsigned int MC_request_testany_fail(smx_req_t req); +int MC_waitany_is_enabled_by_comm(smx_req_t req, unsigned int comm); /********************************** DPOR **************************************/ void MC_dpor_init(void); @@ -63,20 +61,42 @@ void MC_dpor(void); void MC_dpor_exit(void); /******************************** States **************************************/ +/* Possible exploration status of a process in a state */ +typedef enum { + MC_NOT_INTERLEAVE=0, /* Do not interleave (do not execute) */ + MC_INTERLEAVE, /* Interleave the process (one or more request) */ + MC_DONE /* Already interleaved */ +} e_mc_process_state_t; + +/* On every state, each process has an entry of the following type */ +typedef struct mc_procstate{ + e_mc_process_state_t state; /* Exploration control information */ + unsigned int interleave_count; /* Number of times that the process was + interleaved */ +} s_mc_procstate_t, *mc_procstate_t; + +/* An exploration state is composed of: */ typedef struct mc_state { - xbt_setset_set_t interleave; /* processes to interleave by the mc */ - xbt_setset_set_t done; /* already executed processes */ - s_smx_req_t executed; + unsigned long max_pid; /* Maximum pid at state's creation time */ + mc_procstate_t proc_status; /* State's exploration status by process */ + s_smx_action_t internal_comm; /* To be referenced by the internal_req */ + s_smx_req_t internal_req; /* Internal translation of request */ + s_smx_req_t executed_req; /* The executed request of the state */ + int req_num; /* The request number (in the case of a + multi-request like waitany ) */ } s_mc_state_t, *mc_state_t; extern xbt_fifo_t mc_stack; -extern xbt_setset_t mc_setset; mc_state_t MC_state_new(void); void MC_state_delete(mc_state_t state); -void MC_state_set_executed_request(mc_state_t state, smx_req_t req); -smx_req_t MC_state_get_executed_request(mc_state_t state); -smx_req_t MC_state_get_request(mc_state_t state); +void MC_state_interleave_process(mc_state_t state, smx_process_t process); +unsigned int MC_state_interleave_size(mc_state_t state); +int MC_state_process_is_done(mc_state_t state, smx_process_t process); +void MC_state_set_executed_request(mc_state_t state, smx_req_t req, int value); +smx_req_t MC_state_get_executed_request(mc_state_t state, int *value); +smx_req_t MC_state_get_internal_request(mc_state_t state); +smx_req_t MC_state_get_request(mc_state_t state, int *value); /****************************** Statistics ************************************/ typedef struct mc_stats {