X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/9104957deccc59e0e804215d5db498fabfd40d29..4b90ce2abff77ca7898fd9292a122440df739916:/src/mc/mc_request.cpp diff --git a/src/mc/mc_request.cpp b/src/mc/mc_request.cpp index 3c663e4d2b..53428fdc89 100644 --- a/src/mc/mc_request.cpp +++ b/src/mc/mc_request.cpp @@ -22,9 +22,9 @@ static inline simgrid::kernel::activity::CommImpl* MC_get_comm(smx_simcall_t r) { switch (r->call_) { case SIMCALL_COMM_WAIT: - return static_cast(simcall_comm_wait__getraw__comm(r)); + return simcall_comm_wait__getraw__comm(r); case SIMCALL_COMM_TEST: - return static_cast(simcall_comm_test__getraw__comm(r)); + return simcall_comm_test__getraw__comm(r); default: return nullptr; } @@ -209,7 +209,7 @@ std::string simgrid::mc::request_to_string(smx_simcall_t req, int value, simgrid size_t* remote_size = simcall_comm_irecv__get__dst_buff_size(req); size_t size = 0; if (remote_size) - mc_model_checker->process().read_bytes(&size, sizeof(size), remote(remote_size)); + mc_model_checker->get_remote_simulation().read_bytes(&size, sizeof(size), remote(remote_size)); type = "iRecv"; char* p = pointer_to_string(simcall_comm_irecv__get__dst_buff(req)); @@ -225,8 +225,7 @@ std::string simgrid::mc::request_to_string(smx_simcall_t req, int value, simgrid } case SIMCALL_COMM_WAIT: { - simgrid::kernel::activity::CommImpl* remote_act = - static_cast(simcall_comm_wait__getraw__comm(req)); + simgrid::kernel::activity::CommImpl* remote_act = simcall_comm_wait__getraw__comm(req); char* p; if (value == -1) { type = "WaitTimeout"; @@ -239,14 +238,15 @@ std::string simgrid::mc::request_to_string(smx_simcall_t req, int value, simgrid simgrid::mc::Remote temp_synchro; const simgrid::kernel::activity::CommImpl* act; if (use_remote_comm) { - mc_model_checker->process().read(temp_synchro, - remote(static_cast(remote_act))); + mc_model_checker->get_remote_simulation().read(temp_synchro, remote(remote_act)); act = temp_synchro.get_buffer(); } else act = remote_act; - smx_actor_t src_proc = mc_model_checker->process().resolve_actor(simgrid::mc::remote(act->src_actor_.get())); - smx_actor_t dst_proc = mc_model_checker->process().resolve_actor(simgrid::mc::remote(act->dst_actor_.get())); + smx_actor_t src_proc = + mc_model_checker->get_remote_simulation().resolve_actor(simgrid::mc::remote(act->src_actor_.get())); + smx_actor_t dst_proc = + mc_model_checker->get_remote_simulation().resolve_actor(simgrid::mc::remote(act->dst_actor_.get())); args = bprintf("comm=%s [(%ld)%s (%s)-> (%ld)%s (%s)]", p, src_proc ? src_proc->get_pid() : 0, src_proc ? MC_smx_actor_get_host_name(src_proc) : "", src_proc ? MC_smx_actor_get_name(src_proc) : "", dst_proc ? dst_proc->get_pid() : 0, @@ -258,13 +258,11 @@ std::string simgrid::mc::request_to_string(smx_simcall_t req, int value, simgrid } case SIMCALL_COMM_TEST: { - simgrid::kernel::activity::CommImpl* remote_act = - static_cast(simcall_comm_test__getraw__comm(req)); + simgrid::kernel::activity::CommImpl* remote_act = simcall_comm_test__getraw__comm(req); simgrid::mc::Remote temp_synchro; const simgrid::kernel::activity::CommImpl* act; if (use_remote_comm) { - mc_model_checker->process().read(temp_synchro, - remote(static_cast(remote_act))); + mc_model_checker->get_remote_simulation().read(temp_synchro, remote(remote_act)); act = temp_synchro.get_buffer(); } else act = remote_act; @@ -278,8 +276,10 @@ std::string simgrid::mc::request_to_string(smx_simcall_t req, int value, simgrid type = "Test TRUE"; p = pointer_to_string(remote_act); - smx_actor_t src_proc = mc_model_checker->process().resolve_actor(simgrid::mc::remote(act->src_actor_.get())); - smx_actor_t dst_proc = mc_model_checker->process().resolve_actor(simgrid::mc::remote(act->dst_actor_.get())); + smx_actor_t src_proc = + mc_model_checker->get_remote_simulation().resolve_actor(simgrid::mc::remote(act->src_actor_.get())); + smx_actor_t dst_proc = + mc_model_checker->get_remote_simulation().resolve_actor(simgrid::mc::remote(act->dst_actor_.get())); args = bprintf("comm=%s [(%ld)%s (%s) -> (%ld)%s (%s)]", p, src_proc->get_pid(), MC_smx_actor_get_name(src_proc), MC_smx_actor_get_host_name(src_proc), dst_proc->get_pid(), MC_smx_actor_get_name(dst_proc), MC_smx_actor_get_host_name(dst_proc)); @@ -293,7 +293,8 @@ std::string simgrid::mc::request_to_string(smx_simcall_t req, int value, simgrid size_t count = simcall_comm_waitany__get__count(req); if (count > 0) { simgrid::kernel::activity::CommImpl* remote_sync; - remote_sync = mc_model_checker->process().read(remote(simcall_comm_waitany__get__comms(req) + value)); + remote_sync = + mc_model_checker->get_remote_simulation().read(remote(simcall_comm_waitany__get__comms(req) + value)); char* p = pointer_to_string(remote_sync); args = bprintf("comm=%s (%d of %zu)", p, value + 1, count); xbt_free(p); @@ -320,13 +321,13 @@ std::string simgrid::mc::request_to_string(smx_simcall_t req, int value, simgrid type = "Mutex TRYLOCK"; simgrid::mc::Remote mutex; - mc_model_checker->process().read_bytes(mutex.get_buffer(), sizeof(mutex), - remote(req->call_ == SIMCALL_MUTEX_LOCK - ? simcall_mutex_lock__get__mutex(req) - : simcall_mutex_trylock__get__mutex(req))); + mc_model_checker->get_remote_simulation().read_bytes(mutex.get_buffer(), sizeof(mutex), + remote(req->call_ == SIMCALL_MUTEX_LOCK + ? simcall_mutex_lock__get__mutex(req) + : simcall_mutex_trylock__get__mutex(req))); args = bprintf("locked = %d, owner = %d, sleeping = n/a", mutex.get_buffer()->is_locked(), mutex.get_buffer()->get_owner() != nullptr - ? (int)mc_model_checker->process() + ? (int)mc_model_checker->get_remote_simulation() .resolve_actor(simgrid::mc::remote(mutex.get_buffer()->get_owner())) ->get_pid() : -1); @@ -368,11 +369,11 @@ bool request_is_enabled_by_idx(smx_simcall_t req, unsigned int idx) break; case SIMCALL_COMM_WAITANY: - remote_act = mc_model_checker->process().read(remote(simcall_comm_testany__get__comms(req) + idx)); + remote_act = mc_model_checker->get_remote_simulation().read(remote(simcall_comm_testany__get__comms(req) + idx)); break; case SIMCALL_COMM_TESTANY: - remote_act = mc_model_checker->process().read(remote(simcall_comm_testany__get__comms(req) + idx)); + remote_act = mc_model_checker->get_remote_simulation().read(remote(simcall_comm_testany__get__comms(req) + idx)); break; default: @@ -380,7 +381,7 @@ bool request_is_enabled_by_idx(smx_simcall_t req, unsigned int idx) } Remote temp_comm; - mc_model_checker->process().read(temp_comm, remote(remote_act)); + mc_model_checker->get_remote_simulation().read(temp_comm, remote(remote_act)); const kernel::activity::CommImpl* comm = temp_comm.get_buffer(); return comm->src_actor_.get() && comm->dst_actor_.get(); } @@ -430,13 +431,14 @@ std::string request_get_dot_output(smx_simcall_t req, int value) } else { kernel::activity::ActivityImpl* remote_act = simcall_comm_wait__getraw__comm(req); Remote temp_comm; - mc_model_checker->process().read(temp_comm, remote(static_cast(remote_act))); + mc_model_checker->get_remote_simulation().read(temp_comm, + remote(static_cast(remote_act))); const kernel::activity::CommImpl* comm = temp_comm.get_buffer(); const kernel::actor::ActorImpl* src_proc = - mc_model_checker->process().resolve_actor(mc::remote(comm->src_actor_.get())); + mc_model_checker->get_remote_simulation().resolve_actor(mc::remote(comm->src_actor_.get())); const kernel::actor::ActorImpl* dst_proc = - mc_model_checker->process().resolve_actor(mc::remote(comm->dst_actor_.get())); + mc_model_checker->get_remote_simulation().resolve_actor(mc::remote(comm->dst_actor_.get())); if (issuer->get_host()) label = xbt::string_printf("[(%ld)%s] Wait [(%ld)->(%ld)]", issuer->get_pid(), MC_smx_actor_get_host_name(issuer), @@ -450,7 +452,8 @@ std::string request_get_dot_output(smx_simcall_t req, int value) case SIMCALL_COMM_TEST: { kernel::activity::ActivityImpl* remote_act = simcall_comm_test__getraw__comm(req); Remote temp_comm; - mc_model_checker->process().read(temp_comm, remote(static_cast(remote_act))); + mc_model_checker->get_remote_simulation().read(temp_comm, + remote(static_cast(remote_act))); const kernel::activity::CommImpl* comm = temp_comm.get_buffer(); if (comm->src_actor_.get() == nullptr || comm->dst_actor_.get() == nullptr) { if (issuer->get_host())