1
1

Merge pull request #690 from jsquyres/pr/really-fix-f08-buffer-detatch-really-really-really

mpi_f08: move the f08 version of buffer_detach to use-mpi-f08
Этот коммит содержится в:
Jeff Squyres 2015-07-07 11:17:27 -04:00
родитель 478120ecb4 8ff60c47cc
Коммит 4b8967f532
4 изменённых файлов: 73 добавлений и 35 удалений

Просмотреть файл

@ -63,14 +63,18 @@ OMPI_GENERATE_F77_BINDINGS (MPI_BUFFER_DETACH,
#include "ompi/mpi/fortran/mpif-h/profile/defines.h"
#endif
/*
/* (this comment is repeated in ompi/mpi/fortran/use-mpi-f08/buffer_detach.c)
*
* MPI-3.1 section 3.6, page 45, states that the mpif.h and mpi module
* interfaces for MPI_BUFFER_DETACH ignore the buffer argument.
* Therefore, for the mpif.h and mpi module interfaces, we use a dummy
* variable and leave the value handed in alone.
*
* The mpi_f08 implementation for MPI_BUFFER_DETACH is a separate
* routine -- see below.
* The mpi_f08 implementation for MPI_BUFFER_DETACH therefore is a
* separate routine in the use-mpi-f08 directory (it's not built in
* the mpif-h directory because of all the different combinations of
* supporting weak symbols (or not), building the profiling layer (or
* not), etc.).
*/
void ompi_buffer_detach_f(char *buffer, MPI_Fint *size, MPI_Fint *ierr)
{
@ -85,29 +89,3 @@ void ompi_buffer_detach_f(char *buffer, MPI_Fint *size, MPI_Fint *ierr)
OMPI_SINGLE_INT_2_FINT(size);
}
}
/*
* Per above, this is the mpi_f08 module implementation of
* MPI_BUFFER_DETACH. It handles the buffer arugment just like the C
* binding.
*
* Note that we only need to build this function once -- not for both
* profiling and non-profiling. So protect it with an appropriate
* #if.
*/
#if !OMPI_PROFILE_LAYER
void ompi_buffer_detach_f08(char *buffer, MPI_Fint *size, MPI_Fint *ierr)
{
int c_ierr;
void *dummy;
OMPI_SINGLE_NAME_DECL(size);
c_ierr = MPI_Buffer_detach(&dummy, OMPI_SINGLE_NAME_CONVERT(size));
if (NULL != ierr) *ierr = OMPI_INT_2_FINT(c_ierr);
if (MPI_SUCCESS == c_ierr) {
*(void **)buffer = dummy;
OMPI_SINGLE_INT_2_FINT(size);
}
}
#endif // !OMPI_PROFILE_LAYER

Просмотреть файл

@ -459,12 +459,6 @@ PN2(void, MPI_Comm_null_delete_fn, mpi_comm_null_delete_fn, MPI_COMM_NULL_DELETE
PN2(void, MPI_Comm_null_copy_fn, mpi_comm_null_copy_fn, MPI_COMM_NULL_COPY_FN, (MPI_Fint* comm, MPI_Fint* comm_keyval, MPI_Aint* extra_state, MPI_Aint* attribute_val_in, MPI_Aint* attribute_val_out, ompi_fortran_logical_t * flag, MPI_Fint* ierr));
PN2(void, MPI_Comm_dup_fn, mpi_comm_dup_fn, MPI_COMM_DUP_FN, (MPI_Fint* comm, MPI_Fint* comm_keyval, MPI_Aint* extra_state, MPI_Aint* attribute_val_in, MPI_Aint* attribute_val_out, ompi_fortran_logical_t * flag, MPI_Fint* ierr));
/*
* The following is an mpi_f08-module-specific function that does not
* fit in to the normal/templated prototypes, above.
*/
void ompi_buffer_detach_f08(char *buffer, MPI_Fint *size, MPI_Fint *ierr);
END_C_DECLS
#endif

Просмотреть файл

@ -105,6 +105,7 @@ mpi_api_files = \
bcast_f08.F90 \
bsend_f08.F90 \
bsend_init_f08.F90 \
buffer_detach.c \
buffer_attach_f08.F90 \
buffer_detach_f08.F90 \
cancel_f08.F90 \

Просмотреть файл

@ -0,0 +1,65 @@
/*
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
* University Research and Technology
* Corporation. All rights reserved.
* Copyright (c) 2004-2005 The University of Tennessee and The University
* of Tennessee Research Foundation. All rights
* reserved.
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
* University of Stuttgart. All rights reserved.
* Copyright (c) 2004-2005 The Regents of the University of California.
* All rights reserved.
* Copyright (c) 2007 Sun Microsystems, Inc. All rights reserved.
* Copyright (c) 2011-2015 Cisco Systems, Inc. All rights reserved.
* $COPYRIGHT$
*
* Additional copyrights may follow
*
* $HEADER$
*/
#include "ompi_config.h"
#include "mpi.h"
#include "ompi/mpi/fortran/base/fint_2_int.h"
/*
* This function implemented in this file is only called from Fortran,
* so we never bothered to put a prototype for it in any C header
* file. To avoid compiler warnings about no protoype, we prototype
* it here.
*/
OMPI_DECLSPEC void ompi_buffer_detach_f08(char *buffer, MPI_Fint *size,
MPI_Fint *ierr);
/* (this comment is repeated in ompi/mpi/fortran/mpif-h/buffer_detach_f.c)
*
* MPI-3.1 section 3.6, page 45, states that the mpif.h and mpi module
* interfaces for MPI_BUFFER_DETACH ignore the buffer argument.
* Therefore, for the mpif.h and mpi module interfaces, we use a dummy
* variable and leave the value handed in alone.
*
* The mpi_f08 implementation for MPI_BUFFER_DETACH therefore is a
* separate routine in the use-mpi-f08 directory (it's not built in
* the mpif-h directory because of all the different combinations of
* supporting weak symbols (or not), building the profiling layer (or
* not), etc.).
*
* Note that we only need to build this function once -- the F08
* interfaces for MPI_BUFFER_ATTACH and PMPI_BUFFER_ATTACH both
* bind(C) to the name ompi_buffer_detach_f08.
*/
void ompi_buffer_detach_f08(char *buffer, MPI_Fint *size, MPI_Fint *ierr)
{
int c_ierr;
void *dummy;
c_ierr = MPI_Buffer_detach(&dummy, size);
if (NULL != ierr) {
*ierr = OMPI_INT_2_FINT(c_ierr);
}
if (MPI_SUCCESS == c_ierr) {
*(void **)buffer = dummy;
}
}