1
1
openmpi/src/mpi/f77/group_range_excl_f.c

63 строки
2.2 KiB
C
Исходник Обычный вид История

/*
* $HEADER$
*/
#include "lam_config.h"
#include <stdio.h>
#include "mpi.h"
#include "mpi/f77/bindings.h"
#include "group/group.h"
#if LAM_HAVE_WEAK_SYMBOLS && LAM_PROFILE_LAYER
#pragma weak PMPI_GROUP_RANGE_EXCL = mpi_group_range_excl_f
#pragma weak pmpi_group_range_excl = mpi_group_range_excl_f
#pragma weak pmpi_group_range_excl_ = mpi_group_range_excl_f
#pragma weak pmpi_group_range_excl__ = mpi_group_range_excl_f
#elif LAM_PROFILE_LAYER
LAM_GENERATE_F77_BINDINGS (PMPI_GROUP_RANGE_EXCL,
pmpi_group_range_excl,
pmpi_group_range_excl_,
pmpi_group_range_excl__,
pmpi_group_range_excl_f,
(MPI_Fint *group, MPI_Fint *n, MPI_Fint ranges[][3], MPI_Fint *newgroup, MPI_Fint *ierr),
(group, n, ranges3, newgroup, ierr) )
#endif
#if LAM_HAVE_WEAK_SYMBOLS
#pragma weak MPI_GROUP_RANGE_EXCL = mpi_group_range_excl_f
#pragma weak mpi_group_range_excl = mpi_group_range_excl_f
#pragma weak mpi_group_range_excl_ = mpi_group_range_excl_f
#pragma weak mpi_group_range_excl__ = mpi_group_range_excl_f
#endif
#if ! LAM_HAVE_WEAK_SYMBOLS && ! LAM_PROFILE_LAYER
LAM_GENERATE_F77_BINDINGS (MPI_GROUP_RANGE_EXCL,
mpi_group_range_excl,
mpi_group_range_excl_,
mpi_group_range_excl__,
mpi_group_range_excl_f,
(MPI_Fint *group, MPI_Fint *n, MPI_Fint ranges[][3], MPI_Fint *newgroup, MPI_Fint *ierr),
(group, n, ranges3, newgroup, ierr) )
#endif
#if LAM_PROFILE_LAYER && ! LAM_HAVE_WEAK_SYMBOLS
#include "mpi/c/profile/defines.h"
#endif
void mpi_group_range_excl_f(MPI_Fint *group, MPI_Fint *n, MPI_Fint ranges[][3], MPI_Fint *newgroup, MPI_Fint *ierr)
{
lam_group_t *c_group, *c_newgroup;
/* Make the fortran to c representation conversion */
c_group = MPI_Group_f2c(*group);
c_newgroup = MPI_Group_f2c(*newgroup);
*ierr = MPI_Group_range_excl(c_group, *n, ranges, &c_newgroup);
/* translate the results from c to fortran */
*newgroup = c_newgroup->grp_f_to_c_index;
}