2004-07-14 18:11:03 +04:00
|
|
|
// -*- c++ -*-
|
|
|
|
//
|
2005-11-05 22:57:48 +03:00
|
|
|
// Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
// University Research and Technology
|
|
|
|
// Corporation. All rights reserved.
|
|
|
|
// Copyright (c) 2004-2005 The University of Tennessee and The University
|
|
|
|
// of Tennessee Research Foundation. All rights
|
|
|
|
// reserved.
|
2004-11-28 23:09:25 +03:00
|
|
|
// Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
// University of Stuttgart. All rights reserved.
|
2005-03-24 15:43:37 +03:00
|
|
|
// Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
// All rights reserved.
|
2004-11-22 04:38:40 +03:00
|
|
|
// $COPYRIGHT$
|
|
|
|
//
|
|
|
|
// Additional copyrights may follow
|
|
|
|
//
|
2004-07-14 18:11:03 +04:00
|
|
|
// $HEADER$
|
|
|
|
//
|
|
|
|
|
|
|
|
//
|
|
|
|
// Point-to-Point Communication
|
|
|
|
//
|
|
|
|
|
|
|
|
inline void
|
|
|
|
MPI::Request::Wait(MPI::Status &status)
|
|
|
|
{
|
|
|
|
(void)MPI_Wait(&mpi_request, &status.mpi_status);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void
|
|
|
|
MPI::Request::Wait()
|
|
|
|
{
|
|
|
|
(void)MPI_Wait(&mpi_request, MPI_STATUS_IGNORE);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void
|
|
|
|
MPI::Request::Free()
|
|
|
|
{
|
|
|
|
(void)MPI_Request_free(&mpi_request);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
MPI::Request::Test(MPI::Status &status)
|
|
|
|
{
|
|
|
|
int t;
|
|
|
|
(void)MPI_Test(&mpi_request, &t, &status.mpi_status);
|
|
|
|
return (bool) t;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
MPI::Request::Test()
|
|
|
|
{
|
|
|
|
int t;
|
|
|
|
(void)MPI_Test(&mpi_request, &t, MPI_STATUS_IGNORE);
|
|
|
|
return (bool) t;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int
|
|
|
|
MPI::Request::Waitany(int count, MPI::Request array[],
|
|
|
|
MPI::Status& status)
|
|
|
|
{
|
|
|
|
int index, i;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[count];
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Waitany(count, array_of_requests, &index, &status.mpi_status);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array[i] = array_of_requests[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
return index;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int
|
|
|
|
MPI::Request::Waitany(int count, MPI::Request array[])
|
|
|
|
{
|
|
|
|
int index, i;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[count];
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Waitany(count, array_of_requests, &index, MPI_STATUS_IGNORE);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array[i] = array_of_requests[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
return index; //JGS, Waitany return value
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
MPI::Request::Testany(int count, MPI::Request array[],
|
|
|
|
int& index, MPI::Status& status)
|
|
|
|
{
|
|
|
|
int i, flag;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[count];
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Testany(count, array_of_requests, &index, &flag, &status.mpi_status);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array[i] = array_of_requests[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
return (bool)flag;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
MPI::Request::Testany(int count, MPI::Request array[], int& index)
|
|
|
|
{
|
|
|
|
int i, flag;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[count];
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Testany(count, array_of_requests, &index, &flag,
|
|
|
|
MPI_STATUS_IGNORE);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array[i] = array_of_requests[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
return (bool)flag;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void
|
|
|
|
MPI::Request::Waitall(int count, MPI::Request req_array[],
|
|
|
|
MPI::Status stat_array[])
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[count];
|
|
|
|
MPI_Status* array_of_statuses = new MPI_Status[count];
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = req_array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Waitall(count, array_of_requests, array_of_statuses);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
req_array[i] = array_of_requests[i];
|
|
|
|
stat_array[i] = array_of_statuses[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
delete [] array_of_statuses;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void
|
|
|
|
MPI::Request::Waitall(int count, MPI::Request req_array[])
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[count];
|
|
|
|
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = req_array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Waitall(count, array_of_requests, MPI_STATUSES_IGNORE);
|
|
|
|
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
req_array[i] = array_of_requests[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
|
|
|
|
delete [] array_of_requests;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
MPI::Request::Testall(int count, MPI::Request req_array[],
|
|
|
|
MPI::Status stat_array[])
|
|
|
|
{
|
|
|
|
int i, flag;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[count];
|
|
|
|
MPI_Status* array_of_statuses = new MPI_Status[count];
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = req_array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Testall(count, array_of_requests, &flag, array_of_statuses);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
req_array[i] = array_of_requests[i];
|
|
|
|
stat_array[i] = array_of_statuses[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
delete [] array_of_statuses;
|
|
|
|
return (bool) flag;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline bool
|
|
|
|
MPI::Request::Testall(int count, MPI::Request req_array[])
|
|
|
|
{
|
|
|
|
int i, flag;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[count];
|
|
|
|
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = req_array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Testall(count, array_of_requests, &flag, MPI_STATUSES_IGNORE);
|
|
|
|
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
req_array[i] = array_of_requests[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
|
|
|
|
return (bool) flag;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int
|
|
|
|
MPI::Request::Waitsome(int incount, MPI::Request req_array[],
|
|
|
|
int array_of_indices[], MPI::Status stat_array[])
|
|
|
|
{
|
|
|
|
int i, outcount;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[incount];
|
|
|
|
MPI_Status* array_of_statuses = new MPI_Status[incount];
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < incount; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = req_array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Waitsome(incount, array_of_requests, &outcount,
|
|
|
|
array_of_indices, array_of_statuses);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < incount; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
req_array[i] = array_of_requests[i];
|
|
|
|
stat_array[i] = array_of_statuses[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
delete [] array_of_statuses;
|
|
|
|
return outcount;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int
|
|
|
|
MPI::Request::Waitsome(int incount, MPI::Request req_array[],
|
|
|
|
int array_of_indices[])
|
|
|
|
{
|
|
|
|
int i, outcount;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[incount];
|
|
|
|
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < incount; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = req_array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Waitsome(incount, array_of_requests, &outcount,
|
|
|
|
array_of_indices, MPI_STATUSES_IGNORE);
|
|
|
|
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < incount; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
req_array[i] = array_of_requests[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
|
|
|
|
return outcount;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int
|
|
|
|
MPI::Request::Testsome(int incount, MPI::Request req_array[],
|
|
|
|
int array_of_indices[], MPI::Status stat_array[])
|
|
|
|
{
|
|
|
|
int i, outcount;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[incount];
|
|
|
|
MPI_Status* array_of_statuses = new MPI_Status[incount];
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < incount; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = req_array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Testsome(incount, array_of_requests, &outcount,
|
|
|
|
array_of_indices, array_of_statuses);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < incount; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
req_array[i] = array_of_requests[i];
|
|
|
|
stat_array[i] = array_of_statuses[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
delete [] array_of_statuses;
|
|
|
|
return outcount;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int
|
|
|
|
MPI::Request::Testsome(int incount, MPI::Request req_array[],
|
|
|
|
int array_of_indices[])
|
|
|
|
{
|
|
|
|
int i, outcount;
|
|
|
|
MPI_Request* array_of_requests = new MPI_Request[incount];
|
|
|
|
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < incount; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i] = req_array[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
(void)MPI_Testsome(incount, array_of_requests, &outcount,
|
|
|
|
array_of_indices, MPI_STATUSES_IGNORE);
|
|
|
|
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < incount; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
req_array[i] = array_of_requests[i];
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] array_of_requests;
|
|
|
|
|
|
|
|
return outcount;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void
|
|
|
|
MPI::Request::Cancel(void) const
|
|
|
|
{
|
2005-11-30 06:22:27 +03:00
|
|
|
(void)MPI_Cancel(const_cast<MPI_Request *>(&mpi_request));
|
2004-07-14 18:11:03 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
inline void
|
|
|
|
MPI::Prequest::Start()
|
|
|
|
{
|
|
|
|
(void)MPI_Start(&mpi_request);
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void
|
|
|
|
MPI::Prequest::Startall(int count, MPI:: Prequest array_of_requests[])
|
|
|
|
{
|
|
|
|
//convert the array of Prequests to an array of MPI_requests
|
|
|
|
MPI_Request* mpi_requests = new MPI_Request[count];
|
|
|
|
int i;
|
|
|
|
for (i=0; i < count; i++) {
|
|
|
|
mpi_requests[i] = array_of_requests[i];
|
|
|
|
}
|
|
|
|
(void)MPI_Startall(count, mpi_requests);
|
2005-12-16 00:52:40 +03:00
|
|
|
for (i=0; i < count; i++) {
|
2004-07-14 18:11:03 +04:00
|
|
|
array_of_requests[i].mpi_request = mpi_requests[i] ;
|
2005-12-16 00:52:40 +03:00
|
|
|
}
|
2004-07-14 18:11:03 +04:00
|
|
|
delete [] mpi_requests;
|
|
|
|
}
|
|
|
|
|