⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 allreducef.c

📁 fortran并行计算包
💻 C
字号:
/* -*- Mode: C; c-basic-offset:4 ; -*- *//*   *  (C) 2001 by Argonne National Laboratory. *      See COPYRIGHT in top-level directory. * * This file is automatically generated by buildiface  * DO NOT EDIT */#include "mpi_fortimpl.h"/* Begin MPI profiling block */#if defined(USE_WEAK_SYMBOLS) && !defined(USE_ONLY_MPI_NAMES) #if defined(HAVE_MULTIPLE_PRAGMA_WEAK) && defined(F77_NAME_LOWER_2USCORE)extern FORT_DLL_SPEC void FORT_CALL MPI_ALLREDUCE( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );extern FORT_DLL_SPEC void FORT_CALL mpi_allreduce__( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );extern FORT_DLL_SPEC void FORT_CALL mpi_allreduce( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );extern FORT_DLL_SPEC void FORT_CALL mpi_allreduce_( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );extern FORT_DLL_SPEC void FORT_CALL pmpi_allreduce_( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );#pragma weak MPI_ALLREDUCE = pmpi_allreduce__#pragma weak mpi_allreduce__ = pmpi_allreduce__#pragma weak mpi_allreduce_ = pmpi_allreduce__#pragma weak mpi_allreduce = pmpi_allreduce__#pragma weak pmpi_allreduce_ = pmpi_allreduce__#elif defined(HAVE_PRAGMA_WEAK)#if defined(F77_NAME_UPPER)extern FORT_DLL_SPEC void FORT_CALL MPI_ALLREDUCE( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );#pragma weak MPI_ALLREDUCE = PMPI_ALLREDUCE#elif defined(F77_NAME_LOWER_2USCORE)extern FORT_DLL_SPEC void FORT_CALL mpi_allreduce__( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );#pragma weak mpi_allreduce__ = pmpi_allreduce__#elif !defined(F77_NAME_LOWER_USCORE)extern FORT_DLL_SPEC void FORT_CALL mpi_allreduce( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );#pragma weak mpi_allreduce = pmpi_allreduce#elseextern FORT_DLL_SPEC void FORT_CALL mpi_allreduce_( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );#pragma weak mpi_allreduce_ = pmpi_allreduce_#endif#elif defined(HAVE_PRAGMA_HP_SEC_DEF)#if defined(F77_NAME_UPPER)#pragma _HP_SECONDARY_DEF PMPI_ALLREDUCE  MPI_ALLREDUCE#elif defined(F77_NAME_LOWER_2USCORE)#pragma _HP_SECONDARY_DEF pmpi_allreduce__  mpi_allreduce__#elif !defined(F77_NAME_LOWER_USCORE)#pragma _HP_SECONDARY_DEF pmpi_allreduce  mpi_allreduce#else#pragma _HP_SECONDARY_DEF pmpi_allreduce_  mpi_allreduce_#endif#elif defined(HAVE_PRAGMA_CRI_DUP)#if defined(F77_NAME_UPPER)#pragma _CRI duplicate MPI_ALLREDUCE as PMPI_ALLREDUCE#elif defined(F77_NAME_LOWER_2USCORE)#pragma _CRI duplicate mpi_allreduce__ as pmpi_allreduce__#elif !defined(F77_NAME_LOWER_USCORE)#pragma _CRI duplicate mpi_allreduce as pmpi_allreduce#else#pragma _CRI duplicate mpi_allreduce_ as pmpi_allreduce_#endif#endif /* HAVE_PRAGMA_WEAK */#endif /* USE_WEAK_SYMBOLS *//* End MPI profiling block *//* These definitions are used only for generating the Fortran wrappers */#if defined(USE_WEAK_SYBMOLS) && defined(HAVE_MULTIPLE_PRAGMA_WEAK) && \    defined(USE_ONLY_MPI_NAMES)extern FORT_DLL_SPEC void FORT_CALL MPI_ALLREDUCE( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );extern FORT_DLL_SPEC void FORT_CALL mpi_allreduce__( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );extern FORT_DLL_SPEC void FORT_CALL mpi_allreduce( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );extern FORT_DLL_SPEC void FORT_CALL mpi_allreduce_( void*, void*, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint *, MPI_Fint * );#pragma weak MPI_ALLREDUCE = mpi_allreduce__#pragma weak mpi_allreduce_ = mpi_allreduce__#pragma weak mpi_allreduce = mpi_allreduce__#endif/* Map the name to the correct form */#ifndef MPICH_MPI_FROM_PMPI#ifdef F77_NAME_UPPER#define mpi_allreduce_ PMPI_ALLREDUCE#elif defined(F77_NAME_LOWER_2USCORE)#define mpi_allreduce_ pmpi_allreduce__#elif !defined(F77_NAME_LOWER_USCORE)#define mpi_allreduce_ pmpi_allreduce#else#define mpi_allreduce_ pmpi_allreduce_#endif/* This defines the routine that we call, which must be the PMPI version   since we're renaming the Fortran entry as the pmpi version.  The MPI name   must be undefined first to prevent any conflicts with previous renamings,   such as those put in place by the globus device when it is building on   top of a vendor MPI. */#undef MPI_Allreduce#define MPI_Allreduce PMPI_Allreduce #else#ifdef F77_NAME_UPPER#define mpi_allreduce_ MPI_ALLREDUCE#elif defined(F77_NAME_LOWER_2USCORE)#define mpi_allreduce_ mpi_allreduce__#elif !defined(F77_NAME_LOWER_USCORE)#define mpi_allreduce_ mpi_allreduce/* Else leave name alone */#endif#endif /* MPICH_MPI_FROM_PMPI *//* Prototypes for the Fortran interfaces */#include "fproto.h"FORT_DLL_SPEC void FORT_CALL mpi_allreduce_ ( void*v1, void*v2, MPI_Fint *v3, MPI_Fint *v4, MPI_Fint *v5, MPI_Fint *v6, MPI_Fint *ierr ){    if (MPIR_F_NeedInit){ mpirinitf_(); MPIR_F_NeedInit = 0; }    if (v1 == MPIR_F_MPI_IN_PLACE) v1 = MPI_IN_PLACE;    *ierr = MPI_Allreduce( v1, v2, *v3, (MPI_Datatype)(*v4), *v5, (MPI_Comm)(*v6) );}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -