-/* Copyright (c) 2010-2017. The SimGrid Team. All rights reserved. */
+/* Copyright (c) 2010-2018. 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 "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
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) {
*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);
+ *attr_value = *value;
}
void mpi_error_string_(int* errorcode, char* string, int* resultlen, int* ierr){
}
}
-void mpi_win_get_attr_(int* win, int* type_keyval, void* attribute_val, int* flag, int* ierr){
- *ierr = MPI_Win_get_attr(simgrid::smpi::Win::f2c(*win), *type_keyval, attribute_val, flag);
+void mpi_win_get_attr_(int* win, int* type_keyval, int* attribute_val, int* flag, int* ierr){
+ int* value = nullptr;
+ *ierr = MPI_Win_get_attr(simgrid::smpi::Win::f2c(*win), *type_keyval, &value, flag);
+ *attribute_val=*value;
}
void mpi_win_set_attr_(int* win, int* type_keyval, void* att, int* ierr){