X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/b5722ab23a4292eeaffc735aa511e36b47670d00..0f52d78508cefd46f2bfb4f22f3b1f2925988d1e:/src/smpi/bindings/smpi_f77.cpp diff --git a/src/smpi/bindings/smpi_f77.cpp b/src/smpi/bindings/smpi_f77.cpp index c917e2a124..7af30396b6 100644 --- a/src/smpi/bindings/smpi_f77.cpp +++ b/src/smpi/bindings/smpi_f77.cpp @@ -1,19 +1,19 @@ -/* Copyright (c) 2010-2017. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2010-2019. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ -#include "private.h" +#include "private.hpp" #include "smpi_comm.hpp" #include "smpi_datatype.hpp" #include "smpi_op.hpp" -#include "smpi_process.hpp" #include "smpi_request.hpp" #include "smpi_win.hpp" +#include "src/smpi/include/smpi_actor.hpp" static int running_processes = 0; -static void smpi_init_fortran_types(){ +void smpi_init_fortran_types(){ if(simgrid::smpi::F2C::lookup() == nullptr){ MPI_COMM_WORLD->add_f(); MPI_BYTE->add_f();//MPI_BYTE @@ -79,9 +79,6 @@ void mpi_init_(int* ierr) { void mpi_finalize_(int* ierr) { *ierr = MPI_Finalize(); running_processes--; - if(running_processes==0){ - simgrid::smpi::F2C::delete_lookup(); - } } void mpi_abort_(int* comm, int* errorcode, int* ierr) { @@ -101,7 +98,7 @@ void mpi_group_incl_(int* group, int* n, int* ranks, int* group_out, int* ierr) *ierr = MPI_Group_incl(simgrid::smpi::Group::f2c(*group), *n, ranks, &tmp); if(*ierr == MPI_SUCCESS) { - *group_out = tmp->add_f(); + *group_out = tmp->c2f(); } } @@ -110,6 +107,8 @@ void mpi_initialized_(int* flag, int* ierr){ } void mpi_get_processor_name_(char *name, int *resultlen, int* ierr){ + //fortran does not handle string endings cleanly, so initialize everything before + memset(name, 0, MPI_MAX_PROCESSOR_NAME); *ierr = MPI_Get_processor_name(name, resultlen); } @@ -117,8 +116,11 @@ void mpi_get_count_(MPI_Status * status, int* datatype, int *count, int* ierr){ *ierr = MPI_Get_count(FORT_STATUS_IGNORE(status), simgrid::smpi::Datatype::f2c(*datatype), count); } -void mpi_attr_get_(int* comm, int* keyval, void* attr_value, int* flag, int* ierr ){ - *ierr = MPI_Attr_get(simgrid::smpi::Comm::f2c(*comm), *keyval, attr_value, flag); +void mpi_attr_get_(int* comm, int* keyval, int* attr_value, int* flag, int* ierr ){ + int* value = nullptr; + *ierr = MPI_Attr_get(simgrid::smpi::Comm::f2c(*comm), *keyval, &value, flag); + if(*flag == 1) + *attr_value=*value; } void mpi_error_string_(int* errorcode, char* string, int* resultlen, int* ierr){ @@ -182,6 +184,123 @@ void mpi_win_get_name_ (int* win, char * name, int* len, int* ierr){ name[*len]=' ';//blank padding, not \0 } +void mpi_win_allocate_( MPI_Aint* size, int* disp_unit, int* info, int* comm, void* base, int* win, int* ierr){ + MPI_Win tmp; + *ierr = MPI_Win_allocate( *size, *disp_unit, simgrid::smpi::Info::f2c(*info), simgrid::smpi::Comm::f2c(*comm),static_cast(base),&tmp); + if(*ierr == MPI_SUCCESS) { + *win = tmp->add_f(); + } +} + +void mpi_win_attach_(int* win, int* base, MPI_Aint* size, int* ierr){ + *ierr = MPI_Win_attach(simgrid::smpi::Win::f2c(*win), static_cast(base), *size); +} + +void mpi_win_create_dynamic_( int* info, int* comm, int *win, int* ierr){ + MPI_Win tmp; + *ierr = MPI_Win_create_dynamic( simgrid::smpi::Info::f2c(*info), simgrid::smpi::Comm::f2c(*comm),&tmp); + if(*ierr == MPI_SUCCESS) { + *win = tmp->add_f(); + } +} + +void mpi_win_detach_(int* win, int* base, int* ierr){ + *ierr = MPI_Win_detach(simgrid::smpi::Win::f2c(*win), static_cast(base)); +} + +void mpi_win_set_info_(int* win, int* info, int* ierr){ + *ierr = MPI_Win_set_info(simgrid::smpi::Win::f2c(*win), simgrid::smpi::Info::f2c(*info)); +} + +void mpi_win_get_info_(int* win, int* info, int* ierr){ + MPI_Info tmp; + *ierr = MPI_Win_get_info(simgrid::smpi::Win::f2c(*win), &tmp); + if(*ierr == MPI_SUCCESS) { + *info = tmp->add_f(); + } +} + +void mpi_win_get_group_(int* win, int* group, int* ierr){ + MPI_Group tmp; + *ierr = MPI_Win_get_group(simgrid::smpi::Win::f2c(*win), &tmp); + if(*ierr == MPI_SUCCESS) { + *group = tmp->add_f(); + } +} + +void mpi_win_get_attr_(int* win, int* type_keyval, MPI_Aint* attribute_val, int* flag, int* ierr){ + MPI_Aint* value = nullptr; + *ierr = MPI_Win_get_attr(simgrid::smpi::Win::f2c(*win), *type_keyval, &value, flag); + if (*flag == 1) + *attribute_val = *value; +} + +void mpi_win_set_attr_(int* win, int* type_keyval, MPI_Aint* att, int* ierr){ + MPI_Aint* val = (MPI_Aint*)xbt_malloc(sizeof(MPI_Aint)); + *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){ + *ierr = MPI_Win_delete_attr (simgrid::smpi::Win::f2c(*win), *comm_keyval); +} + +void mpi_win_create_keyval_(void* copy_fn, void* delete_fn, int* keyval, void* extra_state, int* ierr){ + smpi_copy_fn _copy_fn={nullptr,nullptr,nullptr,nullptr,nullptr,(*(int*)copy_fn) == 0 ? nullptr : reinterpret_cast(copy_fn)}; + smpi_delete_fn _delete_fn={nullptr,nullptr,nullptr,nullptr,nullptr,(*(int*)delete_fn) == 0 ? nullptr : reinterpret_cast(delete_fn)}; + *ierr = simgrid::smpi::Keyval::keyval_create(_copy_fn, _delete_fn, keyval, extra_state); +} + +void mpi_win_free_keyval_(int* keyval, int* ierr){ + *ierr = MPI_Win_free_keyval( keyval); +} + +void mpi_win_lock_(int* lock_type, int* rank, int* assert, int* win, int* ierr){ + *ierr = MPI_Win_lock(*lock_type, *rank, *assert, simgrid::smpi::Win::f2c(*win)); +} + +void mpi_win_lock_all_(int* assert, int* win, int* ierr){ + *ierr = MPI_Win_lock_all(*assert, simgrid::smpi::Win::f2c(*win)); +} + +void mpi_win_unlock_(int* rank, int* win, int* ierr){ + *ierr = MPI_Win_unlock(*rank, simgrid::smpi::Win::f2c(*win)); +} + +void mpi_win_unlock_all_(int* win, int* ierr){ + *ierr = MPI_Win_unlock_all(simgrid::smpi::Win::f2c(*win)); +} + +void mpi_win_flush_(int* rank, int* win, int* ierr){ + *ierr = MPI_Win_flush(*rank, simgrid::smpi::Win::f2c(*win)); +} + +void mpi_win_flush_local_(int* rank, int* win, int* ierr){ + *ierr = MPI_Win_flush_local(*rank, simgrid::smpi::Win::f2c(*win)); +} +void mpi_win_flush_all_(int* win, int* ierr){ + *ierr = MPI_Win_flush_all(simgrid::smpi::Win::f2c(*win)); +} + +void mpi_win_flush_local_all_(int* win, int* ierr){ + *ierr = MPI_Win_flush_local_all(simgrid::smpi::Win::f2c(*win)); +} + +void mpi_win_null_copy_fn_(int* /*win*/, int* /*keyval*/, int* /*extrastate*/, MPI_Aint* /*valin*/, + MPI_Aint* /*valout*/, int* flag, int* ierr) +{ + *flag=0; + *ierr=MPI_SUCCESS; +} + +void mpi_win_dup_fn_(int* /*win*/, int* /*keyval*/, int* /*extrastate*/, MPI_Aint* valin, MPI_Aint* valout, int* flag, + int* ierr) +{ + *flag=1; + *valout=*valin; + *ierr=MPI_SUCCESS; +} + void mpi_info_create_( int *info, int* ierr){ MPI_Info tmp; *ierr = MPI_Info_create(&tmp); @@ -255,21 +374,88 @@ void mpi_get_( int *origin_addr, int* origin_count, int* origin_datatype, int *t *target_disp, *target_count, simgrid::smpi::Datatype::f2c(*tarsmpi_type_f2c), simgrid::smpi::Win::f2c(*win)); } +void mpi_rget_( int *origin_addr, int* origin_count, int* origin_datatype, int *target_rank, + MPI_Aint* target_disp, int *target_count, int* tarsmpi_type_f2c, int* win, int* request, int* ierr){ + MPI_Request req; + *ierr = MPI_Rget( static_cast(origin_addr),*origin_count, simgrid::smpi::Datatype::f2c(*origin_datatype),*target_rank, + *target_disp, *target_count, simgrid::smpi::Datatype::f2c(*tarsmpi_type_f2c), simgrid::smpi::Win::f2c(*win), &req); + if(*ierr == MPI_SUCCESS) { + *request = req->add_f(); + } +} + void mpi_accumulate_( int *origin_addr, int* origin_count, int* origin_datatype, int *target_rank, MPI_Aint* target_disp, int *target_count, int* tarsmpi_type_f2c, int* op, int* win, int* ierr){ *ierr = MPI_Accumulate( static_cast(origin_addr),*origin_count, simgrid::smpi::Datatype::f2c(*origin_datatype),*target_rank, *target_disp, *target_count, simgrid::smpi::Datatype::f2c(*tarsmpi_type_f2c), simgrid::smpi::Op::f2c(*op), simgrid::smpi::Win::f2c(*win)); } +void mpi_raccumulate_( int *origin_addr, int* origin_count, int* origin_datatype, int *target_rank, + MPI_Aint* target_disp, int *target_count, int* tarsmpi_type_f2c, int* op, int* win, int* request, int* ierr){ + MPI_Request req; + *ierr = MPI_Raccumulate( static_cast(origin_addr),*origin_count, simgrid::smpi::Datatype::f2c(*origin_datatype),*target_rank, + *target_disp, *target_count, simgrid::smpi::Datatype::f2c(*tarsmpi_type_f2c), simgrid::smpi::Op::f2c(*op), simgrid::smpi::Win::f2c(*win),&req); + if(*ierr == MPI_SUCCESS) { + *request = req->add_f(); + } +} + void mpi_put_( int *origin_addr, int* origin_count, int* origin_datatype, int *target_rank, MPI_Aint* target_disp, int *target_count, int* tarsmpi_type_f2c, int* win, int* ierr){ *ierr = MPI_Put( static_cast(origin_addr),*origin_count, simgrid::smpi::Datatype::f2c(*origin_datatype),*target_rank, *target_disp, *target_count, simgrid::smpi::Datatype::f2c(*tarsmpi_type_f2c), simgrid::smpi::Win::f2c(*win)); } +void mpi_rput_( int *origin_addr, int* origin_count, int* origin_datatype, int *target_rank, + MPI_Aint* target_disp, int *target_count, int* tarsmpi_type_f2c, int* win, int* request, int* ierr){ + MPI_Request req; + *ierr = MPI_Rput( static_cast(origin_addr),*origin_count, simgrid::smpi::Datatype::f2c(*origin_datatype),*target_rank, + *target_disp, *target_count, simgrid::smpi::Datatype::f2c(*tarsmpi_type_f2c), simgrid::smpi::Win::f2c(*win),&req); + if(*ierr == MPI_SUCCESS) { + *request = req->add_f(); + } +} + +void mpi_fetch_and_op_( int *origin_addr, int* result_addr, int* datatype, int* target_rank, MPI_Aint* target_disp, int* op, int* win, int* ierr){ + *ierr = MPI_Fetch_and_op( static_cast(origin_addr), + static_cast(result_addr), simgrid::smpi::Datatype::f2c(*datatype),*target_rank, + *target_disp, simgrid::smpi::Op::f2c(*op), simgrid::smpi::Win::f2c(*win)); +} + +void mpi_compare_and_swap_(int* origin_addr, int* compare_addr, int* result_addr, int* datatype, int* target_rank, + MPI_Aint* target_disp, int* win, int* ierr) +{ + *ierr = MPI_Compare_and_swap( static_cast(origin_addr),static_cast(compare_addr), + static_cast(result_addr), simgrid::smpi::Datatype::f2c(*datatype),*target_rank, + *target_disp, simgrid::smpi::Win::f2c(*win)); +} + +void mpi_get_accumulate_(int *origin_addr, int* origin_count, int* origin_datatype, int* result_addr, + int* result_count, int* result_datatype, int* target_rank, MPI_Aint* target_disp, int* target_count, + int* target_datatype, int* op, int* win, int* ierr){ + *ierr = + MPI_Get_accumulate(static_cast(origin_addr), *origin_count, simgrid::smpi::Datatype::f2c(*origin_datatype), + static_cast(result_addr), *result_count, simgrid::smpi::Datatype::f2c(*result_datatype), + *target_rank, *target_disp, *target_count, simgrid::smpi::Datatype::f2c(*target_datatype), + simgrid::smpi::Op::f2c(*op), simgrid::smpi::Win::f2c(*win)); +} + +void mpi_rget_accumulate_(int *origin_addr, int* origin_count, int* origin_datatype, int* result_addr, + int* result_count, int* result_datatype, int* target_rank, MPI_Aint* target_disp, int* target_count, + int* target_datatype, int* op, int* win, int* request, int* ierr){ + MPI_Request req; + *ierr = MPI_Rget_accumulate(static_cast(origin_addr), *origin_count, + simgrid::smpi::Datatype::f2c(*origin_datatype), static_cast(result_addr), + *result_count, simgrid::smpi::Datatype::f2c(*result_datatype), *target_rank, *target_disp, + *target_count, simgrid::smpi::Datatype::f2c(*target_datatype), + simgrid::smpi::Op::f2c(*op), simgrid::smpi::Win::f2c(*win), &req); + if(*ierr == MPI_SUCCESS) { + *request = req->add_f(); + } +} + //following are automatically generated, and have to be checked void mpi_finalized_ (int * flag, int* ierr){ - *ierr = MPI_Finalized(flag); } @@ -280,7 +466,6 @@ void mpi_init_thread_ (int* required, int *provided, int* ierr){ } void mpi_query_thread_ (int *provided, int* ierr){ - *ierr = MPI_Query_thread(provided); } @@ -320,12 +505,17 @@ void mpi_op_free_ (int* op, int* ierr){ } } +void mpi_op_commutative_ (int* op, int* commute, int* ierr){ + *ierr = MPI_Op_commutative(simgrid::smpi::Op::f2c(*op), commute); +} + void mpi_group_free_ (int* group, int* ierr){ - MPI_Group tmp = simgrid::smpi::Group::f2c(*group); - *ierr = MPI_Group_free(&tmp); - if(*ierr == MPI_SUCCESS) { - simgrid::smpi::F2C::free_f(*group); - } + MPI_Group tmp = simgrid::smpi::Group::f2c(*group); + if(tmp != MPI_COMM_WORLD->group() && tmp != MPI_GROUP_EMPTY){ + simgrid::smpi::Group::unref(tmp); + simgrid::smpi::F2C::free_f(*group); + } + *ierr = MPI_SUCCESS; } void mpi_group_size_ (int* group, int *size, int* ierr){ @@ -540,12 +730,16 @@ 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) { - *ierr = MPI_Keyval_create(reinterpret_cast(copy_fn),reinterpret_cast(delete_fn), keyval, extra_state); + smpi_copy_fn _copy_fn={nullptr,nullptr,nullptr,(*(int*)copy_fn) == 0 ? nullptr : reinterpret_cast(copy_fn),nullptr,nullptr}; + smpi_delete_fn _delete_fn={nullptr,nullptr,nullptr,(*(int*)delete_fn) == 0 ? nullptr : reinterpret_cast(delete_fn),nullptr,nullptr}; + *ierr = simgrid::smpi::Keyval::keyval_create(_copy_fn, _delete_fn, keyval, extra_state); } void mpi_keyval_free_ (int* keyval, int* ierr) { @@ -657,19 +851,19 @@ void mpi_status_set_elements_ ( MPI_Status* status, int* datatype, int* count, i } void mpi_publish_name_ ( char *service_name, int* info, char *port_name, int* ierr){ - *ierr = MPI_Publish_name( service_name, *reinterpret_cast(info), port_name); + *ierr = MPI_Publish_name( service_name, simgrid::smpi::Info::f2c(*info), port_name); } void mpi_unpublish_name_ ( char *service_name, int* info, char *port_name, int* ierr){ - *ierr = MPI_Unpublish_name( service_name, *reinterpret_cast(info), port_name); + *ierr = MPI_Unpublish_name( service_name, simgrid::smpi::Info::f2c(*info), port_name); } void mpi_lookup_name_ ( char *service_name, int* info, char *port_name, int* ierr){ - *ierr = MPI_Lookup_name( service_name, *reinterpret_cast(info), port_name); + *ierr = MPI_Lookup_name( service_name, simgrid::smpi::Info::f2c(*info), port_name); } void mpi_open_port_ ( int* info, char *port_name, int* ierr){ - *ierr = MPI_Open_port( *reinterpret_cast(info),port_name); + *ierr = MPI_Open_port( simgrid::smpi::Info::f2c(*info),port_name); } void mpi_close_port_ ( char *port_name, int* ierr){