394 lines
11 KiB
C
394 lines
11 KiB
C
#include <sys/time.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include "psb_internals.h"
|
|
|
|
|
|
#ifdef LowerUnderscore
|
|
#define mpi_wtime mpi_wtime_
|
|
#define mpi_send mpi_send_
|
|
#define mpi_isend mpi_isend_
|
|
#define mpi_irecv mpi_irecv_
|
|
#define mpi_wait mpi_wait_
|
|
#define mpi_alltoall mpi_alltoall_
|
|
#define mpi_alltoallv mpi_alltoallv_
|
|
#define mpi_gather mpi_gather_
|
|
#define mpi_gatherv mpi_gatherv_
|
|
#define mpi_allgather mpi_allgather_
|
|
#define mpi_allgatherv mpi_allgatherv_
|
|
#define mpi_scatterv mpi_scatterv_
|
|
#define mpi_scatter mpi_scatter_
|
|
#endif
|
|
#ifdef LowerDoubleUnderscore
|
|
#define mpi_wtime mpi_wtime__
|
|
#define mpi_send mpi_send__
|
|
#define mpi_isend mpi_isend__
|
|
#define mpi_irecv mpi_irecv__
|
|
#define mpi_wait mpi_wait__
|
|
#define mpi_alltoall mpi_alltoall__
|
|
#define mpi_alltoallv mpi_alltoallv__
|
|
#define mpi_gather mpi_gather__
|
|
#define mpi_gatherv mpi_gatherv__
|
|
#define mpi_allgather mpi_allgather__
|
|
#define mpi_allgatherv mpi_allgatherv__
|
|
#define mpi_scatterv mpi_scatterv__
|
|
#define mpi_scatter mpi_scatter__
|
|
#endif
|
|
#ifdef LowerCase
|
|
#define mpi_wtime mpi_wtime
|
|
#define mpi_send mpi_send
|
|
#define mpi_isend mpi_isend
|
|
#define mpi_irecv mpi_irecv
|
|
#define mpi_wait mpi_wait
|
|
#define mpi_alltoall mpi_alltoall
|
|
#define mpi_alltoallv mpi_alltoallv
|
|
#define mpi_gather mpi_gather
|
|
#define mpi_gatherv mpi_gatherv
|
|
#define mpi_allgather mpi_allgather
|
|
#define mpi_allgatherv mpi_allgatherv
|
|
#define mpi_scatterv mpi_scatterv
|
|
#define mpi_scatter mpi_scatter
|
|
#endif
|
|
#ifdef UpperUnderscore
|
|
#define mpi_wtime MPI_WTIME_
|
|
#define mpi_send MPI_SEND_
|
|
#define mpi_isend MPI_ISEND_
|
|
#define mpi_irecv MPI_IRECV_
|
|
#define mpi_wait MPI_WAIT_
|
|
#define mpi_alltoall MPI_ALLTOALL_
|
|
#define mpi_alltoallv MPI_ALLTOALLV_
|
|
#define mpi_gather MPI_GATHER_
|
|
#define mpi_gatherv MPI_GATHERV_
|
|
#define mpi_allgather MPI_ALLGATHER_
|
|
#define mpi_allgatherv MPI_ALLGATHERV_
|
|
#define mpi_scatterv MPI_SCATTERV_
|
|
#define mpi_scatter MPI_SCATTER_
|
|
#endif
|
|
#ifdef UpperDoubleUnderscore
|
|
#define mpi_wtime MPI_WTIME__
|
|
#define mpi_send MPI_SEND__
|
|
#define mpi_isend MPI_ISEND__
|
|
#define mpi_irecv MPI_IRECV__
|
|
#define mpi_wait MPI_WAIT__
|
|
#define mpi_alltoall MPI_ALLTOALL__
|
|
#define mpi_alltoallv MPI_ALLTOALLV__
|
|
#define mpi_gather MPI_GATHER__
|
|
#define mpi_gatherv MPI_GATHERV__
|
|
#define mpi_allgather MPI_ALLGATHER__
|
|
#define mpi_allgatherv MPI_ALLGATHERV__
|
|
#define mpi_scatterv MPI_SCATTERV__
|
|
#define mpi_scatter MPI_SCATTER__
|
|
#endif
|
|
#ifdef UpperCase
|
|
#define mpi_wtime MPI_WTIME
|
|
#define mpi_send MPI_SEND
|
|
#define mpi_isend MPI_ISEND
|
|
#define mpi_irecv MPI_IRECV
|
|
#define mpi_wait MPI_WAIT
|
|
#define mpi_alltoall MPI_ALLTOALL
|
|
#define mpi_alltoallv MPI_ALLTOALLV
|
|
#define mpi_gather MPI_GATHER
|
|
#define mpi_gatherv MPI_GATHERV
|
|
#define mpi_allgather MPI_ALLGATHER
|
|
#define mpi_allgatherv MPI_ALLGATHERV
|
|
#define mpi_scatterv MPI_SCATTERV
|
|
#define mpi_scatter MPI_SCATTER
|
|
#endif
|
|
|
|
#define mpi_integer 1
|
|
#define mpi_integer8 2
|
|
#define mpi_real 3
|
|
#define mpi_double 4
|
|
#define mpi_complex 5
|
|
#define mpi_double_complex 6
|
|
|
|
double mpi_wtime()
|
|
{
|
|
struct timeval tt;
|
|
struct timezone tz;
|
|
double temp;
|
|
if (gettimeofday(&tt,&tz) != 0) {
|
|
fprintf(stderr,"Fatal error for gettimeofday ??? \n");
|
|
temp=0.0;
|
|
} else {
|
|
temp = ((double)tt.tv_sec) + ((double)tt.tv_usec)*1.0e-6;
|
|
}
|
|
return(temp);
|
|
}
|
|
|
|
|
|
void mpi_wait(int *request, int* status, int *ierr)
|
|
|
|
{
|
|
*ierr = 0;
|
|
return;
|
|
}
|
|
void mpi_send(void* buf, int* count, int* datatype,
|
|
int *dest, int *tag, int *comm, int *ierr)
|
|
{
|
|
*ierr = 0;
|
|
return;
|
|
}
|
|
void mpi_isend(void* buf, int* count, int* datatype,
|
|
int *dest, int *tag, int *comm, int *request,
|
|
int *ierr)
|
|
{
|
|
*ierr = 0;
|
|
return;
|
|
}
|
|
void mpi_irecv(void* buf, int* count, int* datatype,
|
|
int *src, int *tag, int *comm, int *request,
|
|
int *ierr)
|
|
{
|
|
*ierr = 0;
|
|
return;
|
|
}
|
|
|
|
|
|
void mpi_alltoall(void* sdb, int* sdc, int* sdt,
|
|
void* rvb, int* rvc, int* rvt, int* comm, int* ierr)
|
|
{
|
|
int i,j,k;
|
|
|
|
if (*sdt == mpi_integer) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(int));
|
|
}
|
|
if (*sdt == mpi_integer8) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(long long));
|
|
}
|
|
if (*sdt == mpi_real) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(double));
|
|
}
|
|
if (*sdt == mpi_complex) {
|
|
memcpy(rvb,sdb, (*sdc)*2*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double_complex) {
|
|
memcpy(rvb,sdb, (*sdc)*2*sizeof(double));
|
|
}
|
|
*ierr = 0;
|
|
}
|
|
|
|
void mpi_alltoallv(void* sdb, int* sdc, int* sdspl, int* sdt,
|
|
void* rvb, int* rvc, int* rdspl, int* rvt, int* comm, int* ierr)
|
|
{
|
|
int i,j,k;
|
|
|
|
|
|
if (*sdt == mpi_integer) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(int)),
|
|
(void *)((char *)sdb+sdspl[0]*sizeof(int)),(*sdc)*sizeof(int));
|
|
}
|
|
if (*sdt == mpi_integer8) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(long long)),
|
|
(void *)((char *)sdb+sdspl[0]*sizeof(long long)),(*sdc)*sizeof(long long));
|
|
}
|
|
if (*sdt == mpi_real) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(float)),
|
|
(void *)((char *)sdb+sdspl[0]*sizeof(float)),(*sdc)*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(double)),
|
|
(void *)((char *)sdb+sdspl[0]*sizeof(double)),(*sdc)*sizeof(double));
|
|
}
|
|
if (*sdt == mpi_complex) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*2*sizeof(float)),
|
|
(void *)((char *)sdb+sdspl[0]*2*sizeof(float)),(*sdc)*2*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double_complex) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*2*sizeof(double)),
|
|
(void *)((char *)sdb+sdspl[0]*2*sizeof(double)),(*sdc)*2*sizeof(double));
|
|
}
|
|
*ierr = 0;
|
|
}
|
|
|
|
|
|
void mpi_gather(void* sdb, int* sdc, int* sdt,
|
|
void* rvb, int* rvc, int* rvt, int *root, int* comm, int* ierr)
|
|
{
|
|
int i,j,k;
|
|
|
|
if (*sdt == mpi_integer) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(int));
|
|
}
|
|
if (*sdt == mpi_integer8) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(long long));
|
|
}
|
|
if (*sdt == mpi_real) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(double));
|
|
}
|
|
if (*sdt == mpi_complex) {
|
|
memcpy(rvb,sdb, (*sdc)*2*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double_complex) {
|
|
memcpy(rvb,sdb, (*sdc)*2*sizeof(double));
|
|
}
|
|
*ierr = 0;
|
|
}
|
|
|
|
|
|
void mpi_gatherv(void* sdb, int* sdc, int* sdt,
|
|
void* rvb, int* rvc, int* rdspl,
|
|
int* rvt, int* comm, int *root, int* ierr)
|
|
{
|
|
int i,j,k;
|
|
|
|
if (*sdt == mpi_integer) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(int)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(int));
|
|
}
|
|
if (*sdt == mpi_integer8) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(long long)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(long long));
|
|
}
|
|
if (*sdt == mpi_real) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(float)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(double)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(double));
|
|
}
|
|
if (*sdt == mpi_complex) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*2*sizeof(float)),
|
|
(void *)((char *)sdb),(*sdc)*2*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double_complex) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*2*sizeof(double)),
|
|
(void *)((char *)sdb),(*sdc)*2*sizeof(double));
|
|
}
|
|
|
|
|
|
*ierr = 0;
|
|
}
|
|
|
|
|
|
void mpi_scatter(void* sdb, int* sdc, int* sdt,
|
|
void* rvb, int* rvc, int* rvt, int *root, int* comm, int* ierr)
|
|
{
|
|
int i,j,k;
|
|
|
|
if (*sdt == mpi_integer) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(int));
|
|
}
|
|
if (*sdt == mpi_integer8) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(long long));
|
|
}
|
|
if (*sdt == mpi_real) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(double));
|
|
}
|
|
if (*sdt == mpi_complex) {
|
|
memcpy(rvb,sdb, (*sdc)*2*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double_complex) {
|
|
memcpy(rvb,sdb, (*sdc)*2*sizeof(double));
|
|
}
|
|
*ierr = 0;
|
|
}
|
|
|
|
|
|
void mpi_scatterv(void* sdb, int* sdc, int* sdt,
|
|
void* rvb, int* rvc, int* rdspl,
|
|
int* rvt, int* comm, int *root, int* ierr)
|
|
{
|
|
int i,j,k;
|
|
|
|
if (*sdt == mpi_integer) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(int)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(int));
|
|
}
|
|
if (*sdt == mpi_integer8) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(long long)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(long long));
|
|
}
|
|
if (*sdt == mpi_real) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(float)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(double)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(double));
|
|
}
|
|
if (*sdt == mpi_complex) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*2*sizeof(float)),
|
|
(void *)((char *)sdb),(*sdc)*2*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double_complex) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*2*sizeof(double)),
|
|
(void *)((char *)sdb),(*sdc)*2*sizeof(double));
|
|
}
|
|
|
|
|
|
*ierr = 0;
|
|
}
|
|
|
|
|
|
void mpi_allgather(void* sdb, int* sdc, int* sdt,
|
|
void* rvb, int* rvc, int* rvt, int* comm, int* ierr)
|
|
{
|
|
int i,j,k;
|
|
|
|
if (*sdt == mpi_integer) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(int));
|
|
}
|
|
if (*sdt == mpi_integer8) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(long long));
|
|
}
|
|
if (*sdt == mpi_real) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double) {
|
|
memcpy(rvb,sdb, (*sdc)*sizeof(double));
|
|
}
|
|
if (*sdt == mpi_complex) {
|
|
memcpy(rvb,sdb, (*sdc)*2*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double_complex) {
|
|
memcpy(rvb,sdb, (*sdc)*2*sizeof(double));
|
|
}
|
|
*ierr = 0;
|
|
}
|
|
|
|
void mpi_allgatherv(void* sdb, int* sdc, int* sdt,
|
|
void* rvb, int* rvc, int* rdspl,
|
|
int* rvt, int* comm, int* ierr)
|
|
{
|
|
int i,j,k;
|
|
|
|
if (*sdt == mpi_integer) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(int)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(int));
|
|
}
|
|
if (*sdt == mpi_integer8) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(long long)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(long long));
|
|
}
|
|
if (*sdt == mpi_real) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(float)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*sizeof(double)),
|
|
(void *)((char *)sdb),(*sdc)*sizeof(double));
|
|
}
|
|
if (*sdt == mpi_complex) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*2*sizeof(float)),
|
|
(void *)((char *)sdb),(*sdc)*2*sizeof(float));
|
|
}
|
|
if (*sdt == mpi_double_complex) {
|
|
memcpy((void *)((char *)rvb+rdspl[0]*2*sizeof(double)),
|
|
(void *)((char *)sdb),(*sdc)*2*sizeof(double));
|
|
}
|
|
|
|
|
|
*ierr = 0;
|
|
}
|