#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <mpi.h>
#include <yaxt.h>
#include "tests.h"
#include "ctest_common.h"
#include "test_redist_common.h"
#include "../src/xt_mpi_ddt_wrap.h"
int main(int argc, char **argv) {
test_init_mpi(&argc, &argv, comm);
Xt_config config = redist_exchanger_option(&argc, &argv);
{
static const struct Xt_redist_msg send_msgs[] = { {.
rank = 0, .datatype = MPI_DOUBLE} },
recv_msgs[] = { {.rank = 0, .datatype = MPI_DOUBLE} };
enum { nsend = sizeof(send_msgs) / sizeof(send_msgs[0]) };
enum { nrecv = sizeof(recv_msgs) / sizeof(recv_msgs[0]) };
static const double src_data[] = {-5};
static const double ref_dst_data[] = {-5};
enum { num_ref_values = sizeof(ref_dst_data) / sizeof(ref_dst_data[0]) };
double dst_data[num_ref_values];
test_redist_single_array_base(nsend, send_msgs, nrecv, recv_msgs,
src_data, num_ref_values, dst_data,
fill_array_double, NULL, ref_dst_data,
MPI_DOUBLE, MPI_DOUBLE, comm, config);
}
{
MPI_Datatype send_type, recv_type;
static const int recv_displs[] = {9, 8, 7, 6, 5, 4, 3, 2, 1, 0};
enum { nelem = sizeof(recv_displs) / sizeof(recv_displs[0]) };
nelem, 1, recv_displs, MPI_FLOAT, &recv_type, comm);
enum { nsend = sizeof(send_msgs) / sizeof(send_msgs[0]) };
enum { nrecv = sizeof(recv_msgs) / sizeof(recv_msgs[0]) };
static const float src_data[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
static const float ref_dst_data[] = {9, 8, 7, 6, 5, 4, 3, 2, 1, 0};
enum { num_ref_values = sizeof(ref_dst_data) / sizeof(ref_dst_data[0]) };
float dst_data[num_ref_values];
test_redist_single_array_base(nsend, send_msgs, nrecv, recv_msgs,
src_data, num_ref_values, dst_data,
fill_array_float, NULL, ref_dst_data,
MPI_FLOAT, MPI_FLOAT, comm, config);
}
return TEST_EXIT_CODE;
}
add versions of standard API functions not returning on error
int MPI_Type_contiguous(int count, MPI_Datatype oldtype, MPI_Datatype *newtype)
int MPI_Type_free(MPI_Datatype *datatype)
int MPI_Type_commit(MPI_Datatype *datatype)
void xt_config_delete(Xt_config config)
void xt_initialize(MPI_Comm default_comm)
#define xt_mpi_call(call, comm)
#define Xt_Type_create_indexed_block(count, blocklength, disp, oldtype, newtype, comm)