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

📄 unpackextf.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_UNPACK_EXTERNAL( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );extern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external__( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );extern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );extern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external_( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );extern FORT_DLL_SPEC void FORT_CALL pmpi_unpack_external_( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );#pragma weak MPI_UNPACK_EXTERNAL = pmpi_unpack_external__#pragma weak mpi_unpack_external__ = pmpi_unpack_external__#pragma weak mpi_unpack_external_ = pmpi_unpack_external__#pragma weak mpi_unpack_external = pmpi_unpack_external__#pragma weak pmpi_unpack_external_ = pmpi_unpack_external__#elif defined(HAVE_PRAGMA_WEAK)#if defined(F77_NAME_UPPER)extern FORT_DLL_SPEC void FORT_CALL MPI_UNPACK_EXTERNAL( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );#pragma weak MPI_UNPACK_EXTERNAL = PMPI_UNPACK_EXTERNAL#elif defined(F77_NAME_LOWER_2USCORE)extern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external__( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );#pragma weak mpi_unpack_external__ = pmpi_unpack_external__#elif !defined(F77_NAME_LOWER_USCORE)extern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );#pragma weak mpi_unpack_external = pmpi_unpack_external#elseextern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external_( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );#pragma weak mpi_unpack_external_ = pmpi_unpack_external_#endif#elif defined(HAVE_PRAGMA_HP_SEC_DEF)#if defined(F77_NAME_UPPER)#pragma _HP_SECONDARY_DEF PMPI_UNPACK_EXTERNAL  MPI_UNPACK_EXTERNAL#elif defined(F77_NAME_LOWER_2USCORE)#pragma _HP_SECONDARY_DEF pmpi_unpack_external__  mpi_unpack_external__#elif !defined(F77_NAME_LOWER_USCORE)#pragma _HP_SECONDARY_DEF pmpi_unpack_external  mpi_unpack_external#else#pragma _HP_SECONDARY_DEF pmpi_unpack_external_  mpi_unpack_external_#endif#elif defined(HAVE_PRAGMA_CRI_DUP)#if defined(F77_NAME_UPPER)#pragma _CRI duplicate MPI_UNPACK_EXTERNAL as PMPI_UNPACK_EXTERNAL#elif defined(F77_NAME_LOWER_2USCORE)#pragma _CRI duplicate mpi_unpack_external__ as pmpi_unpack_external__#elif !defined(F77_NAME_LOWER_USCORE)#pragma _CRI duplicate mpi_unpack_external as pmpi_unpack_external#else#pragma _CRI duplicate mpi_unpack_external_ as pmpi_unpack_external_#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_UNPACK_EXTERNAL( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );extern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external__( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );extern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );extern FORT_DLL_SPEC void FORT_CALL mpi_unpack_external_( char * FORT_MIXED_LEN_DECL, void*, MPI_Aint *, MPI_Aint *, void*, MPI_Fint *, MPI_Fint *, MPI_Fint * FORT_END_LEN_DECL );#pragma weak MPI_UNPACK_EXTERNAL = mpi_unpack_external__#pragma weak mpi_unpack_external_ = mpi_unpack_external__#pragma weak mpi_unpack_external = mpi_unpack_external__#endif/* Map the name to the correct form */#ifndef MPICH_MPI_FROM_PMPI#ifdef F77_NAME_UPPER#define mpi_unpack_external_ PMPI_UNPACK_EXTERNAL#elif defined(F77_NAME_LOWER_2USCORE)#define mpi_unpack_external_ pmpi_unpack_external__#elif !defined(F77_NAME_LOWER_USCORE)#define mpi_unpack_external_ pmpi_unpack_external#else#define mpi_unpack_external_ pmpi_unpack_external_#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_Unpack_external#define MPI_Unpack_external PMPI_Unpack_external #else#ifdef F77_NAME_UPPER#define mpi_unpack_external_ MPI_UNPACK_EXTERNAL#elif defined(F77_NAME_LOWER_2USCORE)#define mpi_unpack_external_ mpi_unpack_external__#elif !defined(F77_NAME_LOWER_USCORE)#define mpi_unpack_external_ mpi_unpack_external/* 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_unpack_external_ ( char *v1 FORT_MIXED_LEN(d1), void*v2, MPI_Aint * v3, MPI_Aint * v4, void*v5, MPI_Fint *v6, MPI_Fint *v7, MPI_Fint *ierr FORT_END_LEN(d1) ){    char *p1;    {char *p = v1 + d1 - 1;     int  li;        while (*p == ' ' && p > v1) p--;        p++;        p1 = (char *)MPIU_Malloc( p-v1 + 1 );        for (li=0; li<(p-v1); li++) { p1[li] = v1[li]; }        p1[li] = 0;     }    *ierr = MPI_Unpack_external( p1, v2, *v3, v4, v5, *v6, (MPI_Datatype)(*v7) );    MPIU_Free( p1 );}

⌨️ 快捷键说明

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