X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/18a9a43996a548884a3042ed99e60f3218a3259a..b9de37e23ac70fadc9fe1c55a6bd1d892ba5ba53:/src/smpi/bindings/smpi_f77.cpp diff --git a/src/smpi/bindings/smpi_f77.cpp b/src/smpi/bindings/smpi_f77.cpp index 5b629f308f..f28922c280 100644 --- a/src/smpi/bindings/smpi_f77.cpp +++ b/src/smpi/bindings/smpi_f77.cpp @@ -115,9 +115,10 @@ void mpi_get_count_(MPI_Status * status, int* datatype, int *count, int* ierr){ } void mpi_attr_get_(int* comm, int* keyval, int* attr_value, int* flag, int* ierr ){ - size_t value = 0; + int* value = nullptr; *ierr = MPI_Attr_get(simgrid::smpi::Comm::f2c(*comm), *keyval, &value, flag); - *attr_value = *(int*)value; + if(*flag == 1) + *attr_value=*value; } void mpi_error_string_(int* errorcode, char* string, int* resultlen, int* ierr){ @@ -226,13 +227,16 @@ 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){ - size_t value = 0; + int* value = nullptr; *ierr = MPI_Win_get_attr(simgrid::smpi::Win::f2c(*win), *type_keyval, &value, flag); - *attribute_val=*(int*)value; + if (*flag == 1) + *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){ @@ -707,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) {