From: Augustin Degomme Date: Tue, 25 Sep 2018 09:27:42 +0000 (+0200) Subject: get was done, now fix set X-Git-Tag: v3_21~41 X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/commitdiff_plain/b9de37e23ac70fadc9fe1c55a6bd1d892ba5ba53?ds=sidebyside get was done, now fix set --- diff --git a/src/smpi/bindings/smpi_f77.cpp b/src/smpi/bindings/smpi_f77.cpp index 597453744e..f28922c280 100644 --- a/src/smpi/bindings/smpi_f77.cpp +++ b/src/smpi/bindings/smpi_f77.cpp @@ -233,8 +233,10 @@ void mpi_win_get_attr_(int* win, int* type_keyval, int* attribute_val, int* flag *attribute_val = *value; } -void mpi_win_set_attr_(int* win, int* type_keyval, void* att, int* ierr){ - *ierr = MPI_Win_set_attr(simgrid::smpi::Win::f2c(*win), *type_keyval, att); +void mpi_win_set_attr_(int* win, int* type_keyval, int* att, int* ierr){ + int* val = (int*)xbt_malloc(sizeof(int)); + *val=*att; + *ierr = MPI_Win_set_attr(simgrid::smpi::Win::f2c(*win), *type_keyval, val); } void mpi_win_delete_attr_(int* win, int* comm_keyval, int* ierr){ @@ -709,8 +711,10 @@ void mpi_attr_delete_ (int* comm, int* keyval, int* ierr) { *ierr = MPI_Attr_delete(simgrid::smpi::Comm::f2c(*comm), *keyval); } -void mpi_attr_put_ (int* comm, int* keyval, void* attr_value, int* ierr) { - *ierr = MPI_Attr_put(simgrid::smpi::Comm::f2c(*comm), *keyval, attr_value); +void mpi_attr_put_ (int* comm, int* keyval, int* attr_value, int* ierr) { + int* val = (int*)xbt_malloc(sizeof(int)); + *val=*attr_value; + *ierr = MPI_Attr_put(simgrid::smpi::Comm::f2c(*comm), *keyval, val); } void mpi_keyval_create_ (void* copy_fn, void* delete_fn, int* keyval, void* extra_state, int* ierr) { diff --git a/src/smpi/bindings/smpi_f77_comm.cpp b/src/smpi/bindings/smpi_f77_comm.cpp index cfa7eaa7d2..02893b993e 100644 --- a/src/smpi/bindings/smpi_f77_comm.cpp +++ b/src/smpi/bindings/smpi_f77_comm.cpp @@ -78,9 +78,10 @@ void mpi_comm_get_attr_ (int* comm, int* comm_keyval, int *attribute_val, int *f *attribute_val = *value; } -void mpi_comm_set_attr_ (int* comm, int* comm_keyval, void *attribute_val, int* ierr){ - - *ierr = MPI_Comm_set_attr ( simgrid::smpi::Comm::f2c(*comm), *comm_keyval, attribute_val); +void mpi_comm_set_attr_ (int* comm, int* comm_keyval, int *attribute_val, int* ierr){ + int* val = (int*)xbt_malloc(sizeof(int)); + *val=*attribute_val; + *ierr = MPI_Comm_set_attr ( simgrid::smpi::Comm::f2c(*comm), *comm_keyval, val); } void mpi_comm_delete_attr_ (int* comm, int* comm_keyval, int* ierr){ diff --git a/src/smpi/bindings/smpi_f77_type.cpp b/src/smpi/bindings/smpi_f77_type.cpp index 9a28137385..94773b8f33 100644 --- a/src/smpi/bindings/smpi_f77_type.cpp +++ b/src/smpi/bindings/smpi_f77_type.cpp @@ -63,9 +63,10 @@ void mpi_type_get_attr_ (int* type, int* type_keyval, int *attribute_val, int* f *attribute_val = *value; } -void mpi_type_set_attr_ (int* type, int* type_keyval, void *attribute_val, int* ierr){ - - *ierr = MPI_Type_set_attr ( simgrid::smpi::Datatype::f2c(*type), *type_keyval, attribute_val); +void mpi_type_set_attr_ (int* type, int* type_keyval, int *attribute_val, int* ierr){ + int* val = (int*)xbt_malloc(sizeof(int)); + *val=*attribute_val; + *ierr = MPI_Type_set_attr ( simgrid::smpi::Datatype::f2c(*type), *type_keyval, val); } void mpi_type_delete_attr_ (int* type, int* type_keyval, int* ierr){ diff --git a/src/smpi/include/private.hpp b/src/smpi/include/private.hpp index e31f526b93..4b96a330ad 100644 --- a/src/smpi/include/private.hpp +++ b/src/smpi/include/private.hpp @@ -191,7 +191,7 @@ void mpi_win_set_info_(int* win, int* info, int* ierr); void mpi_win_get_info_(int* win, int* info, int* ierr); void mpi_win_get_group_(int* win, int* group, int* ierr); void mpi_win_get_attr_(int* win, int* type_keyval, int* attribute_val, int* flag, int* ierr); -void mpi_win_set_attr_(int* win, int* type_keyval, void* att, int* ierr); +void mpi_win_set_attr_(int* win, int* type_keyval, int* att, int* ierr); void mpi_win_delete_attr_(int* win, int* comm_keyval, int* ierr); void mpi_win_create_keyval_(void* copy_fn, void* delete_fn, int* keyval, void* extra_state, int* ierr); void mpi_win_free_keyval_(int* keyval, int* ierr); @@ -243,7 +243,7 @@ void mpi_type_dup_(int* datatype, int* newdatatype, int* ierr); void mpi_type_set_name_(int* datatype, char* name, int* ierr, int size); void mpi_type_get_name_(int* datatype, char* name, int* len, int* ierr); void mpi_type_get_attr_(int* type, int* type_keyval, int* attribute_val, int* flag, int* ierr); -void mpi_type_set_attr_(int* type, int* type_keyval, void* attribute_val, int* ierr); +void mpi_type_set_attr_(int* type, int* type_keyval, int* attribute_val, int* ierr); void mpi_type_delete_attr_(int* type, int* type_keyval, int* ierr); void mpi_type_create_keyval_(void* copy_fn, void* delete_fn, int* keyval, void* extra_state, int* ierr); void mpi_type_free_keyval_(int* keyval, int* ierr); @@ -265,7 +265,7 @@ void mpi_group_excl_(int* group, int* n, int* ranks, int* newgroup, int* ierr); void mpi_group_range_incl_(int* group, int* n, int ranges[][3], int* newgroup, int* ierr); void mpi_group_range_excl_(int* group, int* n, int ranges[][3], int* newgroup, int* ierr); void mpi_comm_get_attr_(int* comm, int* comm_keyval, int* attribute_val, int* flag, int* ierr); -void mpi_comm_set_attr_(int* comm, int* comm_keyval, void* attribute_val, int* ierr); +void mpi_comm_set_attr_(int* comm, int* comm_keyval, int* attribute_val, int* ierr); void mpi_comm_delete_attr_(int* comm, int* comm_keyval, int* ierr); void mpi_comm_create_keyval_(void* copy_fn, void* delete_fn, int* keyval, void* extra_state, int* ierr); void mpi_comm_free_keyval_(int* keyval, int* ierr); @@ -337,7 +337,7 @@ void mpi_comm_remote_size_(int* comm, int* size, int* ierr); void mpi_issend_(void* buf, int* count, int* datatype, int* dest, int* tag, int* comm, int* request, int* ierr); void mpi_probe_(int* source, int* tag, int* comm, MPI_Status* status, int* ierr); void mpi_attr_delete_(int* comm, int* keyval, int* ierr); -void mpi_attr_put_(int* comm, int* keyval, void* attr_value, int* ierr); +void mpi_attr_put_(int* comm, int* keyval, int* attr_value, int* ierr); void mpi_rsend_init_(void* buf, int* count, int* datatype, int* dest, int* tag, int* comm, int* request, int* ierr); void mpi_keyval_create_(void* copy_fn, void* delete_fn, int* keyval, void* extra_state, int* ierr); void mpi_keyval_free_(int* keyval, int* ierr);