1*67e74705SXin Li // Message Passing Interface mock header. Mocks MPI constants and functions, in 2*67e74705SXin Li // order to make them available in distinct integration test files. 3*67e74705SXin Li 4*67e74705SXin Li #define NULL 0 5*67e74705SXin Li 6*67e74705SXin Li // mock types 7*67e74705SXin Li typedef int MPI_Datatype; 8*67e74705SXin Li typedef int MPI_Comm; 9*67e74705SXin Li typedef int MPI_Request; 10*67e74705SXin Li typedef int MPI_Status; 11*67e74705SXin Li typedef int MPI_Op; 12*67e74705SXin Li typedef int int8_t; 13*67e74705SXin Li typedef int uint8_t; 14*67e74705SXin Li typedef int uint16_t; 15*67e74705SXin Li typedef int int64_t; 16*67e74705SXin Li namespace std { template<class T> struct complex { T real; T imag; }; } 17*67e74705SXin Li 18*67e74705SXin Li // mock constants 19*67e74705SXin Li #define MPI_DATATYPE_NULL 0 20*67e74705SXin Li #define MPI_CHAR 0 21*67e74705SXin Li #define MPI_BYTE 0 22*67e74705SXin Li #define MPI_INT 0 23*67e74705SXin Li #define MPI_LONG 0 24*67e74705SXin Li #define MPI_LONG_DOUBLE 0 25*67e74705SXin Li #define MPI_UNSIGNED 0 26*67e74705SXin Li #define MPI_INT8_T 0 27*67e74705SXin Li #define MPI_UINT8_T 0 28*67e74705SXin Li #define MPI_UINT16_T 0 29*67e74705SXin Li #define MPI_C_LONG_DOUBLE_COMPLEX 0 30*67e74705SXin Li #define MPI_FLOAT 0 31*67e74705SXin Li #define MPI_DOUBLE 0 32*67e74705SXin Li #define MPI_CXX_BOOL 0 33*67e74705SXin Li #define MPI_CXX_FLOAT_COMPLEX 0 34*67e74705SXin Li #define MPI_CXX_DOUBLE_COMPLEX 0 35*67e74705SXin Li #define MPI_CXX_LONG_DOUBLE_COMPLEX 0 36*67e74705SXin Li #define MPI_IN_PLACE 0 37*67e74705SXin Li #define MPI_COMM_WORLD 0 38*67e74705SXin Li #define MPI_STATUS_IGNORE 0 39*67e74705SXin Li #define MPI_STATUSES_IGNORE 0 40*67e74705SXin Li #define MPI_SUM 0 41*67e74705SXin Li 42*67e74705SXin Li // mock functions 43*67e74705SXin Li int MPI_Comm_size(MPI_Comm, int *); 44*67e74705SXin Li int MPI_Comm_rank(MPI_Comm, int *); 45*67e74705SXin Li int MPI_Send(const void *, int, MPI_Datatype, int, int, MPI_Comm); 46*67e74705SXin Li int MPI_Recv(void *, int, MPI_Datatype, int, int, MPI_Comm, MPI_Status *); 47*67e74705SXin Li int MPI_Isend(const void *, int, MPI_Datatype, int, int, MPI_Comm, 48*67e74705SXin Li MPI_Request *); 49*67e74705SXin Li int MPI_Irecv(void *, int, MPI_Datatype, int, int, MPI_Comm, MPI_Request *); 50*67e74705SXin Li int MPI_Wait(MPI_Request *, MPI_Status *); 51*67e74705SXin Li int MPI_Waitall(int, MPI_Request[], MPI_Status[]); 52*67e74705SXin Li int MPI_Reduce(const void *, void *, int, MPI_Datatype, MPI_Op, int, MPI_Comm); 53*67e74705SXin Li int MPI_Ireduce(const void *, void *, int, MPI_Datatype, MPI_Op, int, MPI_Comm, 54*67e74705SXin Li MPI_Request *); 55*67e74705SXin Li int MPI_Bcast(void *, int count, MPI_Datatype, int, MPI_Comm); 56