Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042 #include "PlayaMPISession.hpp"
00043 #include "PlayaMPIDataType.hpp"
00044 #include "PlayaMPIOp.hpp"
00045 #include "Teuchos_Assert.hpp"
00046
00047 namespace Playa
00048 {
00049 using namespace Teuchos;
00050
00051 int MPISession::rank_ = 0 ;
00052 int MPISession::nProc_ = 1 ;
00053
00054 MPISession::MPISession(int* argc, char*** argv)
00055 {
00056 #ifdef HAVE_MPI
00057
00058 int mpiHasBeenStarted = 0;
00059 MPI_Initialized(& mpiHasBeenStarted);
00060 int mpierr = 0 ;
00061 if (!mpiHasBeenStarted)
00062 {
00063 mpierr = ::MPI_Init (argc, (char ***) argv);
00064 TEUCHOS_TEST_FOR_EXCEPTION(mpierr != 0, std::runtime_error,
00065 "Error code=" << mpierr
00066 << " detected in MPI_Init()");
00067 }
00068
00069
00070 mpierr = ::MPI_Comm_rank (MPI_COMM_WORLD, &rank_);
00071 TEUCHOS_TEST_FOR_EXCEPTION(mpierr != 0, std::runtime_error,
00072 "Error code=" << mpierr
00073 << " detected in MPI_Comm_rank()");
00074
00075
00076 mpierr = ::MPI_Comm_size (MPI_COMM_WORLD, &nProc_);
00077
00078 TEUCHOS_TEST_FOR_EXCEPTION(mpierr != 0, std::runtime_error,
00079 "Error code=" << mpierr
00080 << " detected in MPI_Comm_size()");
00081
00082
00083 int nameLen;
00084 char procName[MPI_MAX_PROCESSOR_NAME];
00085 mpierr = ::MPI_Get_processor_name(procName,&nameLen);
00086
00087 TEUCHOS_TEST_FOR_EXCEPTION(mpierr != 0, std::runtime_error,
00088 "Error code=" << mpierr
00089 << " detected in MPI_Get_processor_name()");
00090
00091 if (showStartupMessage())
00092 {
00093 std::cerr << "Playa::MPISession::init() started processor "
00094 << procName << std::endl;
00095 }
00096 else
00097 {
00098 #else
00099 std::cerr << "Playa::MPISession::init() started serial run" << std::endl;
00100 #endif
00101 #ifdef HAVE_MPI
00102 }
00103 #endif
00104 }
00105
00106
00107 void MPISession::init(int* argc, char*** argv)
00108 {
00109 static RCP<MPISession> session = rcp(new MPISession(argc, argv));
00110 }
00111
00112 void MPISession::init(int* argc, void*** argv)
00113 {
00114 MPISession::init(argc, (char***)argv);
00115 }
00116
00117 void MPISession::finalize()
00118 {
00119
00120 }
00121
00122
00123 MPISession::~MPISession()
00124 {
00125 #ifdef HAVE_MPI
00126 int mpiHasBeenFinalized = 0;
00127 MPI_Finalized(& mpiHasBeenFinalized);
00128
00129 if (!mpiHasBeenFinalized)
00130 {
00131 #define BROKEN_MPI_REGISTRIES
00132 #ifndef BROKEN_MPI_REGISTRIES
00133 MPIDataType::clearTypeRegistry();
00134 MPIOp::clearOpRegistry();
00135 #endif
00136 int mpierr = ::MPI_Finalize();
00137
00138 TEUCHOS_TEST_FOR_EXCEPTION(mpierr != 0, std::runtime_error,
00139 "Error code=" << mpierr << " detected in MPI_Finalize()");
00140 }
00141 #endif
00142 }
00143
00144 }