#if !defined(COMM_PHY_MPI_HH) && defined(MPI) #define COMM_PHY_MPI_HH // Copyright (c) 1994-1996 Ohio Board of Regents and the University of // Cincinnati. All Rights Reserved. // BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY // FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT // PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, // EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR // PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE // PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME // THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. // IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING // WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR // REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR // DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL // DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM // (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED // INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF // THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER // OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. // // $Id: CommPhyMPI.hh,v 1.1.1.1 2007/03/15 15:45:05 rmadhoun Exp $ // //--------------------------------------------------------------------------- #include "CommPhyInterface.hh" #include "../../../JackyDebugStream.h" //for MPI_Barrier [2006-01-24] class CommPhyMPI : public CommPhyInterface { public: CommPhyMPI() {} virtual void physicalInit(int *argc, char ***argv); virtual ~CommPhyMPI() {} virtual int physicalGetId() const; virtual void physicalSend(char *buffer, int size, int id); virtual char * physicalProbeRecv(); virtual bool physicalProbeRecvBuffer(char *buffer, int size, bool& sizeStatus); virtual void physicalFinalize(); virtual int physicalGetSize() const ; #ifdef JACKY_SYNC_TIME0 //[2006-01-24]----------------------------------------- //this function is to hold LPs until all of them arrive at this function //using the MPI_Barrier() call into MPI virtual void physicalBarrier(); #endif //end JACKY_SYNC_TIME0 ------------------------------------------------- protected: char *mpi_buffer; private: }; #endif //#if !defined(COMM_PHY_MPI_HH) && defined(MPI)