X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b4fac99a74d360e3935d71e499c59eb296fbcfb4..5666ba4cb7aa68ae1a1640d3e3c57aeba91f4b02:/src/smpi/smpi_replay.c diff --git a/src/smpi/smpi_replay.c b/src/smpi/smpi_replay.c index e0969babb0..d92975d608 100644 --- a/src/smpi/smpi_replay.c +++ b/src/smpi/smpi_replay.c @@ -644,19 +644,15 @@ static void action_allToAll(const char *const *action) { int recv_size = parse_double(action[3]); MPI_Datatype MPI_CURRENT_TYPE2; - if(action[4]) { + if(action[4] && action[5]) { MPI_CURRENT_TYPE=decode_datatype(action[4]); + MPI_CURRENT_TYPE2=decode_datatype(action[5]); } else{ MPI_CURRENT_TYPE=MPI_DEFAULT_TYPE; - } - - if (action[5]){ - MPI_CURRENT_TYPE2=decode_datatype(action[5]); - } - else { MPI_CURRENT_TYPE2=MPI_DEFAULT_TYPE; } + void *send = smpi_get_tmp_sendbuffer(send_size*comm_size* smpi_datatype_size(MPI_CURRENT_TYPE)); void *recv = smpi_get_tmp_recvbuffer(recv_size*comm_size* smpi_datatype_size(MPI_CURRENT_TYPE2)); @@ -756,7 +752,7 @@ static void action_gatherv(const char *const *action) { int i=0,recv_sum=0; MPI_Datatype MPI_CURRENT_TYPE2; - if(action[4+comm_size]) { + if(action[4+comm_size] && action[5+comm_size]) { MPI_CURRENT_TYPE=decode_datatype(action[4+comm_size]); MPI_CURRENT_TYPE2=decode_datatype(action[5+comm_size]); } else { @@ -884,9 +880,9 @@ static void action_allgather(const char *const *action) { MPI_Datatype MPI_CURRENT_TYPE2; - if(action[4]) { - MPI_CURRENT_TYPE = decode_datatype(action[3]); - MPI_CURRENT_TYPE2 = decode_datatype(action[4]); + if(action[4] && action[5]) { + MPI_CURRENT_TYPE = decode_datatype(action[4]); + MPI_CURRENT_TYPE2 = decode_datatype(action[5]); } else { MPI_CURRENT_TYPE = MPI_DEFAULT_TYPE; MPI_CURRENT_TYPE2 = MPI_DEFAULT_TYPE; @@ -937,7 +933,7 @@ static void action_allgatherv(const char *const *action) { int recv_sum=0; MPI_Datatype MPI_CURRENT_TYPE2; - if(action[3+comm_size]) { + if(action[3+comm_size] && action[4+comm_size]) { MPI_CURRENT_TYPE = decode_datatype(action[3+comm_size]); MPI_CURRENT_TYPE2 = decode_datatype(action[4+comm_size]); } else {