X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/36c68a000e3b0156ac5c92ac479bd3b82f76bfde..75556c3d1492aad51984b9fea657dcde33e44705:/src/smpi/smpi_f77.cpp diff --git a/src/smpi/smpi_f77.cpp b/src/smpi/smpi_f77.cpp index 0ab3b36d02..bc4438da5b 100644 --- a/src/smpi/smpi_f77.cpp +++ b/src/smpi/smpi_f77.cpp @@ -782,6 +782,7 @@ void mpi_info_set_( int *info, char *key, char *value, int* ierr, unsigned int k *ierr = MPI_Info_set( smpi_info_f2c(*info), tkey, tvalue); xbt_free(tkey); + xbt_free(tvalue); } void mpi_info_get_ (int* info,char *key,int* valuelen, char *value, int *flag, int* ierr, unsigned int keylen ){ @@ -810,12 +811,6 @@ void mpi_info_get_ (int* info,char *key,int* valuelen, char *value, int *flag, i void mpi_info_free_(int* info, int* ierr){ MPI_Info tmp = smpi_info_f2c(*info); - const char* key; - char* val; - xbt_dict_cursor_t cursor; - xbt_dict_foreach(tmp->info_dict,cursor,key,val) { - xbt_free(val); - } *ierr = MPI_Info_free(&tmp); if(*ierr == MPI_SUCCESS) { free_info(*info); @@ -1760,3 +1755,28 @@ void mpi_comm_get_parent_ ( int* parent, int* ierr){ *parent = smpi_comm_c2f(tmp); } } + +void mpi_file_close_ ( int* file, int* ierr){ + *ierr= MPI_File_close(reinterpret_cast(*file)); +} + +void mpi_file_delete_ ( char* filename, int* info, int* ierr){ + *ierr= MPI_File_delete(filename, smpi_info_f2c(*info)); +} + +void mpi_file_open_ ( int* comm, char* filename, int* amode, int* info, int* fh, int* ierr){ + *ierr= MPI_File_open(smpi_comm_f2c(*comm), filename, *amode, smpi_info_f2c(*info), reinterpret_cast(*fh)); +} + +void mpi_file_set_view_ ( int* fh, long long int* offset, int* etype, int* filetype, char* datarep, int* info, int* ierr){ + *ierr= MPI_File_set_view(reinterpret_cast(*fh) , reinterpret_cast(*offset), smpi_type_f2c(*etype), smpi_type_f2c(*filetype), datarep, smpi_info_f2c(*info)); +} + +void mpi_file_read_ ( int* fh, void* buf, int* count, int* datatype, MPI_Status* status, int* ierr){ + *ierr= MPI_File_read(reinterpret_cast(*fh), buf, *count, smpi_type_f2c(*datatype), status); +} + +void mpi_file_write_ ( int* fh, void* buf, int* count, int* datatype, MPI_Status* status, int* ierr){ + *ierr= MPI_File_write(reinterpret_cast(*fh), buf, *count, smpi_type_f2c(*datatype), status); +} +