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
Этот коммит содержится в:
Коммит
4b8967f532
@ -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 \
|
||||
|
65
ompi/mpi/fortran/use-mpi-f08/buffer_detach.c
Обычный файл
65
ompi/mpi/fortran/use-mpi-f08/buffer_detach.c
Обычный файл
@ -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;
|
||||
}
|
||||
}
|
Загрузка…
x
Ссылка в новой задаче
Block a user