{
e_adress_space_read_flags_t flags = MC_PROCESS_NO_FLAG;
int index = MC_PROCESS_INDEX_ANY;
- return MC_process_read(process, flags, local, remote, len, index);
+ MC_process_read(process, flags, local, remote, len, index);
+ return local;
+}
+
+const void* MC_process_read_dynar_element(mc_process_t process,
+ void* local, const void* remote_dynar, size_t i)
+{
+ s_xbt_dynar_t d;
+ MC_process_read_simple(process, &d, remote_dynar, sizeof(d));
+ MC_process_read_simple(process, local, xbt_dynar_get_ptr(&d, i), i);
+ return local;
}
void MC_process_write(mc_process_t process, const void* local, void* remote, size_t len)
const void* MC_process_read_simple(mc_process_t process,
void* local, const void* remote, size_t len);
+const void* MC_process_read_dynar_element(mc_process_t process,
+ void* local, const void* remote_dynar, size_t i);
+
/** Write data to a process memory
*
* @param process the process
case SIMCALL_COMM_WAITANY:
state->internal_req.call = SIMCALL_COMM_WAIT;
state->internal_req.issuer = req->issuer;
- // FIXME, read from remote process
- state->internal_comm =
- *xbt_dynar_get_as(simcall_comm_waitany__get__comms(req), value,
- smx_synchro_t);
+ MC_process_read_dynar_element(&mc_model_checker->process,
+ &state->internal_comm, simcall_comm_waitany__get__comms(req),
+ sizeof(state->internal_comm));
simcall_comm_wait__set__comm(&state->internal_req, &state->internal_comm);
simcall_comm_wait__set__timeout(&state->internal_req, 0);
break;
if (value > 0)
// FIXME, read from remote process
- state->internal_comm =
- *xbt_dynar_get_as(simcall_comm_testany__get__comms(req), value,
- smx_synchro_t);
+ MC_process_read_dynar_element(&mc_model_checker->process,
+ &state->internal_comm, simcall_comm_testany__get__comms(req),
+ sizeof(state->internal_comm));
simcall_comm_test__set__comm(&state->internal_req, &state->internal_comm);
simcall_comm_test__set__result(&state->internal_req, value);
case SIMCALL_COMM_WAIT:
state->internal_req = *req;
- // FIXME, read from remote process
- state->internal_comm = *(simcall_comm_wait__get__comm(req));
+ MC_process_read_simple(&mc_model_checker->process, &state->internal_comm ,
+ simcall_comm_wait__get__comm(req), sizeof(state->internal_comm));
simcall_comm_wait__set__comm(&state->executed_req, &state->internal_comm);
simcall_comm_wait__set__comm(&state->internal_req, &state->internal_comm);
break;
case SIMCALL_COMM_TEST:
state->internal_req = *req;
- // FIXME, read from remote process
- state->internal_comm = *simcall_comm_test__get__comm(req);
+ MC_process_read_simple(&mc_model_checker->process, &state->internal_comm,
+ simcall_comm_test__get__comm(req), sizeof(state->internal_comm));
simcall_comm_test__set__comm(&state->executed_req, &state->internal_comm);
simcall_comm_test__set__comm(&state->internal_req, &state->internal_comm);
break;