1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
|
/* -*- c-file-style: "GNU" -*- */
/*
* Copyright (C) CNRS, INRIA, Université Bordeaux 1, Télécom SudParis
* See COPYING in top-level directory.
*/
#include "mpi.h"
#include <stdio.h>
int main(int argc, char *argv[]) {
int rank, size;
int i, index;
int buffer[400];
MPI_Request request[4];
MPI_Status status[4];
MPI_Init(&argc, &argv);
MPI_Comm_size(MPI_COMM_WORLD, &size);
if (size != 4) {
printf("Please run with 4 processes.\n");
fflush(stdout);
MPI_Finalize();
return 1;
}
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
if (rank == 0) {
for (i = 0; i < size * 100; i++)
buffer[i] = i / 100;
for(int round = 0; round < 2; round++) {
for (i = 0; i < size - 1; i++) {
if(round == 0) {
MPI_Isend(&buffer[i * 100], 100, MPI_INT, i + 1, 123, MPI_COMM_WORLD,
&request[i]);
} else
MPI_Irecv(&buffer[i * 100], 100, MPI_INT, i + 1, 123, MPI_COMM_WORLD,
&request[i]);
}
while (1) {
/* just for testing if eztrace works when some of the requests are already successful when calling mpi_waitall */
int flag;
MPI_Status status;
MPI_Test(&request[0], &flag, &status);
if (flag) {
break;
}
}
MPI_Waitall(size - 1, request, status);
MPI_Waitall(size - 1, request, status);
}
} else {
MPI_Recv(buffer, 100, MPI_INT, 0, 123, MPI_COMM_WORLD, &status[0]);
printf("%d: buffer[0] = %d\n", rank, buffer[0]);
MPI_Send(buffer, 100, MPI_INT, 0, 123, MPI_COMM_WORLD);
fflush(stdout);
}
MPI_Finalize();
return 0;
}
|