|
Packit |
0848f5 |
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil ; -*- */
|
|
Packit |
0848f5 |
/*
|
|
Packit |
0848f5 |
* (C) 2001 by Argonne National Laboratory.
|
|
Packit |
0848f5 |
* See COPYRIGHT in top-level directory.
|
|
Packit |
0848f5 |
*/
|
|
Packit |
0848f5 |
#include "mpi.h"
|
|
Packit |
0848f5 |
#include <stdio.h>
|
|
Packit |
0848f5 |
#include <stdlib.h>
|
|
Packit |
0848f5 |
#include "mpitest.h"
|
|
Packit |
0848f5 |
#include "mpitestconf.h"
|
|
Packit |
0848f5 |
#ifdef HAVE_STRING_H
|
|
Packit |
0848f5 |
#include <string.h>
|
|
Packit |
0848f5 |
#endif
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
/*
|
|
Packit |
0848f5 |
* This is a simple program that tests bsend. It may be run as a single
|
|
Packit |
0848f5 |
* process to simplify debugging; in addition, bsend allows send-to-self
|
|
Packit |
0848f5 |
* programs.
|
|
Packit |
0848f5 |
*/
|
|
Packit |
0848f5 |
int main(int argc, char *argv[])
|
|
Packit |
0848f5 |
{
|
|
Packit |
0848f5 |
MPI_Comm comm = MPI_COMM_WORLD;
|
|
Packit |
0848f5 |
int dest = 0, src = 0, tag = 1;
|
|
Packit |
0848f5 |
int s1, s2, s3;
|
|
Packit |
0848f5 |
char *buf, *bbuf;
|
|
Packit |
0848f5 |
char msg1[7], msg3[17];
|
|
Packit |
0848f5 |
double msg2[2];
|
|
Packit |
0848f5 |
char rmsg1[64], rmsg3[64];
|
|
Packit |
0848f5 |
double rmsg2[64];
|
|
Packit |
0848f5 |
int errs = 0, rank;
|
|
Packit |
0848f5 |
int bufsize, bsize;
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
MTest_Init(&argc, &argv);
|
|
Packit |
0848f5 |
MPI_Comm_rank(MPI_COMM_WORLD, &rank;;
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
/* According to the standard, we must use the PACK_SIZE length of each
|
|
Packit |
0848f5 |
* message in the computation of the message buffer size */
|
|
Packit |
0848f5 |
MPI_Pack_size(7, MPI_CHAR, comm, &s1;;
|
|
Packit |
0848f5 |
MPI_Pack_size(2, MPI_DOUBLE, comm, &s2;;
|
|
Packit |
0848f5 |
MPI_Pack_size(17, MPI_CHAR, comm, &s3;;
|
|
Packit |
0848f5 |
bufsize = 3 * MPI_BSEND_OVERHEAD + s1 + s2 + s3;
|
|
Packit |
0848f5 |
buf = (char *) malloc(bufsize);
|
|
Packit |
0848f5 |
MPI_Buffer_attach(buf, bufsize);
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
strncpy(msg1, "012345", 7);
|
|
Packit |
0848f5 |
strncpy(msg3, "0123401234012341", 17);
|
|
Packit |
0848f5 |
msg2[0] = 1.23;
|
|
Packit |
0848f5 |
msg2[1] = 3.21;
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
if (rank == src) {
|
|
Packit |
0848f5 |
/* These message sizes are chosen to expose any alignment problems */
|
|
Packit |
0848f5 |
MPI_Bsend(msg1, 7, MPI_CHAR, dest, tag, comm);
|
|
Packit |
0848f5 |
MPI_Bsend(msg2, 2, MPI_DOUBLE, dest, tag, comm);
|
|
Packit |
0848f5 |
MPI_Bsend(msg3, 17, MPI_CHAR, dest, tag, comm);
|
|
Packit |
0848f5 |
}
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
if (rank == dest) {
|
|
Packit |
0848f5 |
MPI_Recv(rmsg1, 7, MPI_CHAR, src, tag, comm, MPI_STATUS_IGNORE);
|
|
Packit |
0848f5 |
MPI_Recv(rmsg2, 10, MPI_DOUBLE, src, tag, comm, MPI_STATUS_IGNORE);
|
|
Packit |
0848f5 |
MPI_Recv(rmsg3, 17, MPI_CHAR, src, tag, comm, MPI_STATUS_IGNORE);
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
if (strcmp(rmsg1, msg1) != 0) {
|
|
Packit |
0848f5 |
errs++;
|
|
Packit |
0848f5 |
fprintf(stderr, "message 1 (%s) should be %s\n", rmsg1, msg1);
|
|
Packit |
0848f5 |
}
|
|
Packit |
0848f5 |
if (rmsg2[0] != msg2[0] || rmsg2[1] != msg2[1]) {
|
|
Packit |
0848f5 |
errs++;
|
|
Packit |
0848f5 |
fprintf(stderr,
|
|
Packit |
0848f5 |
"message 2 incorrect, values are (%f,%f) but should be (%f,%f)\n",
|
|
Packit |
0848f5 |
rmsg2[0], rmsg2[1], msg2[0], msg2[1]);
|
|
Packit |
0848f5 |
}
|
|
Packit |
0848f5 |
if (strcmp(rmsg3, msg3) != 0) {
|
|
Packit |
0848f5 |
errs++;
|
|
Packit |
0848f5 |
fprintf(stderr, "message 3 (%s) should be %s\n", rmsg3, msg3);
|
|
Packit |
0848f5 |
}
|
|
Packit |
0848f5 |
}
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
/* We can't guarantee that messages arrive until the detach */
|
|
Packit |
0848f5 |
MPI_Buffer_detach(&bbuf, &bsize);
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
free(buf);
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
MTest_Finalize(errs);
|
|
Packit |
0848f5 |
|
|
Packit |
0848f5 |
MPI_Finalize();
|
|
Packit |
0848f5 |
return 0;
|
|
Packit |
0848f5 |
}
|