00001
00002
00003
00004
00005
00006
00007
00008
00009 #include "mpio.h"
00010 #include "adio.h"
00011
00012
00013 #if defined(MPIO_BUILD_PROFILING) || defined(HAVE_WEAK_SYMBOLS)
00014 #ifdef FORTRANCAPS
00015 #define mpi_type_create_darray_ PMPI_TYPE_CREATE_DARRAY
00016 #elif defined(FORTRANDOUBLEUNDERSCORE)
00017 #define mpi_type_create_darray_ pmpi_type_create_darray__
00018 #elif !defined(FORTRANUNDERSCORE)
00019 #if defined(HPUX) || defined(SPPUX)
00020 #pragma _HP_SECONDARY_DEF pmpi_type_create_darray pmpi_type_create_darray_
00021 #endif
00022 #define mpi_type_create_darray_ pmpi_type_create_darray
00023 #else
00024 #if defined(HPUX) || defined(SPPUX)
00025 #pragma _HP_SECONDARY_DEF pmpi_type_create_darray_ pmpi_type_create_darray
00026 #endif
00027 #define mpi_type_create_darray_ pmpi_type_create_darray_
00028 #endif
00029
00030 #if defined(HAVE_WEAK_SYMBOLS)
00031 #if defined(HAVE_PRAGMA_WEAK)
00032 #if defined(FORTRANCAPS)
00033 #pragma weak MPI_TYPE_CREATE_DARRAY = PMPI_TYPE_CREATE_DARRAY
00034 #elif defined(FORTRANDOUBLEUNDERSCORE)
00035 #pragma weak mpi_type_create_darray__ = pmpi_type_create_darray__
00036 #elif !defined(FORTRANUNDERSCORE)
00037 #pragma weak mpi_type_create_darray = pmpi_type_create_darray
00038 #else
00039 #pragma weak mpi_type_create_darray_ = pmpi_type_create_darray_
00040 #endif
00041
00042 #elif defined(HAVE_PRAGMA_HP_SEC_DEF)
00043 #if defined(FORTRANCAPS)
00044 #pragma _HP_SECONDARY_DEF PMPI_TYPE_CREATE_DARRAY MPI_TYPE_CREATE_DARRAY
00045 #elif defined(FORTRANDOUBLEUNDERSCORE)
00046 #pragma _HP_SECONDARY_DEF pmpi_type_create_darray__ mpi_type_create_darray__
00047 #elif !defined(FORTRANUNDERSCORE)
00048 #pragma _HP_SECONDARY_DEF pmpi_type_create_darray mpi_type_create_darray
00049 #else
00050 #pragma _HP_SECONDARY_DEF pmpi_type_create_darray_ mpi_type_create_darray_
00051 #endif
00052
00053 #elif defined(HAVE_PRAGMA_CRI_DUP)
00054 #if defined(FORTRANCAPS)
00055 #pragma _CRI duplicate MPI_TYPE_CREATE_DARRAY as PMPI_TYPE_CREATE_DARRAY
00056 #elif defined(FORTRANDOUBLEUNDERSCORE)
00057 #pragma _CRI duplicate mpi_type_create_darray__ as pmpi_type_create_darray__
00058 #elif !defined(FORTRANUNDERSCORE)
00059 #pragma _CRI duplicate mpi_type_create_darray as pmpi_type_create_darray
00060 #else
00061 #pragma _CRI duplicate mpi_type_create_darray_ as pmpi_type_create_darray_
00062 #endif
00063
00064
00065 #endif
00066
00067 #include "mpioprof.h"
00068 #endif
00069
00070 #else
00071
00072 #ifdef FORTRANCAPS
00073 #define mpi_type_create_darray_ MPI_TYPE_CREATE_DARRAY
00074 #elif defined(FORTRANDOUBLEUNDERSCORE)
00075 #define mpi_type_create_darray_ mpi_type_create_darray__
00076 #elif !defined(FORTRANUNDERSCORE)
00077 #if defined(HPUX) || defined(SPPUX)
00078 #pragma _HP_SECONDARY_DEF mpi_type_create_darray mpi_type_create_darray_
00079 #endif
00080 #define mpi_type_create_darray_ mpi_type_create_darray
00081 #else
00082 #if defined(HPUX) || defined(SPPUX)
00083 #pragma _HP_SECONDARY_DEF mpi_type_create_darray_ mpi_type_create_darray
00084 #endif
00085 #endif
00086 #endif
00087
00088 #ifdef MPIHP
00089 void mpi_type_create_darray_(int *size,int *rank,int *ndims,
00090 int *array_of_gsizes,int *array_of_distribs,
00091 int *array_of_dargs,int *array_of_psizes,
00092 int *order, MPI_Fint *oldtype,
00093 MPI_Fint *newtype, int *ierr )
00094 {
00095 MPI_Datatype oldtype_c, newtype_c;
00096
00097 oldtype_c = MPI_Type_f2c(*oldtype);
00098
00099 *ierr = MPI_Type_create_darray(*size,*rank,*ndims,array_of_gsizes,array_of_distribs,array_of_dargs,array_of_psizes,*order,oldtype_c,&newtype_c);
00100
00101 *newtype = MPI_Type_c2f(newtype_c);
00102 }
00103
00104 #else
00105
00106 void mpi_type_create_darray_(int *size,int *rank,int *ndims,
00107 int *array_of_gsizes,int *array_of_distribs,
00108 int *array_of_dargs,int *array_of_psizes,
00109 int *order,MPI_Datatype *oldtype,
00110 MPI_Datatype *newtype, int *ierr )
00111 {
00112 *ierr = MPI_Type_create_darray(*size,*rank,*ndims,array_of_gsizes,array_of_distribs,array_of_dargs,array_of_psizes,*order,*oldtype,newtype);
00113 }
00114 #endif