|
@@ -36,6 +36,7 @@ int burst_nb_requests = NB_REQUESTS;
|
|
|
|
|
|
void burst_init_data(int rank)
|
|
|
{
|
|
|
+ int i;
|
|
|
if (rank == 0 || rank == 1)
|
|
|
{
|
|
|
recv_handles = malloc(burst_nb_requests * sizeof(starpu_data_handle_t));
|
|
@@ -45,7 +46,7 @@ void burst_init_data(int rank)
|
|
|
recv_reqs = malloc(burst_nb_requests * sizeof(starpu_mpi_req));
|
|
|
send_reqs = malloc(burst_nb_requests * sizeof(starpu_mpi_req));
|
|
|
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
send_buffers[i] = malloc(NX_ARRAY * sizeof(float));
|
|
|
memset(send_buffers[i], 0, NX_ARRAY * sizeof(float));
|
|
@@ -60,9 +61,10 @@ void burst_init_data(int rank)
|
|
|
|
|
|
void burst_free_data(int rank)
|
|
|
{
|
|
|
+ int i;
|
|
|
if (rank == 0 || rank == 1)
|
|
|
{
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
starpu_data_unregister(send_handles[i]);
|
|
|
free(send_buffers[i]);
|
|
@@ -84,12 +86,12 @@ void burst_free_data(int rank)
|
|
|
void burst_bidir(int rank)
|
|
|
{
|
|
|
int other_rank = (rank == 0) ? 1 : 0;
|
|
|
-
|
|
|
+ int i;
|
|
|
FPRINTF(stderr, "Simultaneous....start (rank %d)\n", rank);
|
|
|
|
|
|
if (rank == 0 || rank == 1)
|
|
|
{
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
recv_reqs[i] = NULL;
|
|
|
starpu_mpi_irecv(recv_handles[i], &recv_reqs[i], other_rank, i, MPI_COMM_WORLD);
|
|
@@ -100,13 +102,13 @@ void burst_bidir(int rank)
|
|
|
|
|
|
if (rank == 0 || rank == 1)
|
|
|
{
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
send_reqs[i] = NULL;
|
|
|
starpu_mpi_isend_prio(send_handles[i], &send_reqs[i], other_rank, i, i, MPI_COMM_WORLD);
|
|
|
}
|
|
|
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
if (recv_reqs[i]) starpu_mpi_wait(&recv_reqs[i], MPI_STATUS_IGNORE);
|
|
|
if (send_reqs[i]) starpu_mpi_wait(&send_reqs[i], MPI_STATUS_IGNORE);
|
|
@@ -120,10 +122,10 @@ void burst_bidir(int rank)
|
|
|
void burst_unidir(int sender, int receiver, int rank)
|
|
|
{
|
|
|
FPRINTF(stderr, "%d -> %d... start (rank %d)\n", sender, receiver, rank);
|
|
|
-
|
|
|
+ int i;
|
|
|
if (rank == receiver)
|
|
|
{
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
recv_reqs[i] = NULL;
|
|
|
starpu_mpi_irecv(recv_handles[i], &recv_reqs[i], sender, i, MPI_COMM_WORLD);
|
|
@@ -134,7 +136,7 @@ void burst_unidir(int sender, int receiver, int rank)
|
|
|
|
|
|
if (rank == sender)
|
|
|
{
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
send_reqs[i] = NULL;
|
|
|
starpu_mpi_isend_prio(send_handles[i], &send_reqs[i], receiver, i, i, MPI_COMM_WORLD);
|
|
@@ -143,7 +145,7 @@ void burst_unidir(int sender, int receiver, int rank)
|
|
|
|
|
|
if (rank == sender || rank == receiver)
|
|
|
{
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
if (rank != sender && recv_reqs[i]) starpu_mpi_wait(&recv_reqs[i], MPI_STATUS_IGNORE);
|
|
|
if (rank == sender && send_reqs[i]) starpu_mpi_wait(&send_reqs[i], MPI_STATUS_IGNORE);
|
|
@@ -160,12 +162,13 @@ void burst_bidir_half_postponed(int rank)
|
|
|
{
|
|
|
int other_rank = (rank == 0) ? 1 : 0;
|
|
|
int received = 0;
|
|
|
+ int i;
|
|
|
|
|
|
FPRINTF(stderr, "Half/half burst...start (rank %d)\n", rank);
|
|
|
|
|
|
if (rank == 0 || rank == 1)
|
|
|
{
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
recv_reqs[i] = NULL;
|
|
|
starpu_mpi_irecv(recv_handles[i], &recv_reqs[i], other_rank, i, MPI_COMM_WORLD);
|
|
@@ -176,7 +179,7 @@ void burst_bidir_half_postponed(int rank)
|
|
|
|
|
|
if (rank == 0 || rank == 1)
|
|
|
{
|
|
|
- for (int i = 0; i < (burst_nb_requests / 2); i++)
|
|
|
+ for (i = 0; i < (burst_nb_requests / 2); i++)
|
|
|
{
|
|
|
send_reqs[i] = NULL;
|
|
|
starpu_mpi_isend_prio(send_handles[i], &send_reqs[i], other_rank, i, i, MPI_COMM_WORLD);
|
|
@@ -184,13 +187,13 @@ void burst_bidir_half_postponed(int rank)
|
|
|
|
|
|
if (recv_reqs[burst_nb_requests / 4]) starpu_mpi_wait(&recv_reqs[burst_nb_requests / 4], MPI_STATUS_IGNORE);
|
|
|
|
|
|
- for (int i = (burst_nb_requests / 2); i < burst_nb_requests; i++)
|
|
|
+ for (i = (burst_nb_requests / 2); i < burst_nb_requests; i++)
|
|
|
{
|
|
|
send_reqs[i] = NULL;
|
|
|
starpu_mpi_isend_prio(send_handles[i], &send_reqs[i], other_rank, i, i, MPI_COMM_WORLD);
|
|
|
}
|
|
|
|
|
|
- for (int i = 0; i < burst_nb_requests; i++)
|
|
|
+ for (i = 0; i < burst_nb_requests; i++)
|
|
|
{
|
|
|
if (recv_reqs[i]) starpu_mpi_wait(&recv_reqs[i], MPI_STATUS_IGNORE);
|
|
|
if (send_reqs[i]) starpu_mpi_wait(&send_reqs[i], MPI_STATUS_IGNORE);
|