[300] | 1 | #ifndef __XIOS_HPP__ |
---|
| 2 | #define __XIOS_HPP__ |
---|
| 3 | |
---|
[591] | 4 | #include "xios_spl.hpp" |
---|
[382] | 5 | #include "mpi.hpp" |
---|
[697] | 6 | #include "registry.hpp" |
---|
[300] | 7 | |
---|
[335] | 8 | namespace xios |
---|
[300] | 9 | { |
---|
[512] | 10 | /*! |
---|
| 11 | \class CXios |
---|
| 12 | */ |
---|
[300] | 13 | class CXios |
---|
| 14 | { |
---|
[512] | 15 | public: |
---|
[1331] | 16 | static void initialize(void) ; |
---|
| 17 | static void initClientSide(const string & codeId, ep_lib::MPI_Comm& localComm, ep_lib::MPI_Comm& returnComm) ; |
---|
| 18 | static void initServerSide(void) ; |
---|
| 19 | static void clientFinalize(void) ; |
---|
| 20 | static void parseFile(const string& filename) ; |
---|
[490] | 21 | |
---|
[1331] | 22 | template <typename T> |
---|
| 23 | static T getin(const string& id,const T& defaultValue) ; |
---|
[490] | 24 | |
---|
[1331] | 25 | template <typename T> |
---|
| 26 | static T getin(const string& id) ; |
---|
[300] | 27 | |
---|
[512] | 28 | public: |
---|
[1460] | 29 | static const string rootFile ; //!< Configuration filename |
---|
| 30 | static const string xiosCodeId ; //!< Identity for XIOS |
---|
| 31 | static const string clientFile; //!< Filename template for client |
---|
| 32 | static const string serverFile; //!< Filename template for server |
---|
| 33 | static const string serverPrmFile; //!< Filename template for primary server in case of two server levels |
---|
| 34 | static const string serverSndFile; //!< Filename template for secondary server in case of two server levels |
---|
[300] | 35 | |
---|
[1460] | 36 | static bool isClient ; //!< Check if xios is client |
---|
| 37 | #pragma omp threadprivate(isClient) |
---|
| 38 | static bool isServer ; //!< Check if xios is server |
---|
| 39 | #pragma omp threadprivate(isServer) |
---|
[490] | 40 | |
---|
[1460] | 41 | static ep_lib::MPI_Comm globalComm ; //!< Global communicator |
---|
| 42 | #pragma omp threadprivate(globalComm) |
---|
[490] | 43 | |
---|
[1460] | 44 | static bool printLogs2Files; //!< Printing out logs into files |
---|
| 45 | #pragma omp threadprivate(printLogs2Files) |
---|
| 46 | static bool usingOasis ; //!< Using Oasis |
---|
| 47 | #pragma omp threadprivate(usingOasis) |
---|
| 48 | static bool usingServer ; //!< Using server (server mode) |
---|
| 49 | #pragma omp threadprivate(usingServer) |
---|
| 50 | static bool usingServer2 ; //!< Using secondary server (server mode). IMPORTANT: Use this variable ONLY in CServer::initialize(). |
---|
| 51 | #pragma omp threadprivate(usingServer2) |
---|
| 52 | static int ratioServer2 ; //!< Percentage of server processors dedicated to secondary server |
---|
| 53 | #pragma omp threadprivate(ratioServer2) |
---|
| 54 | static int nbPoolsServer2 ; //!< Number of pools created on the secondary server |
---|
| 55 | #pragma omp threadprivate(nbPoolsServer2) |
---|
| 56 | static double bufferSizeFactor; //!< Factor used to tune the buffer size |
---|
| 57 | #pragma omp threadprivate(bufferSizeFactor) |
---|
| 58 | static const double defaultBufferSizeFactor; //!< Default factor value |
---|
| 59 | static StdSize minBufferSize; //!< Minimum buffer size |
---|
| 60 | #pragma omp threadprivate(minBufferSize) |
---|
| 61 | static StdSize maxBufferSize; //!< Maximum buffer size |
---|
| 62 | #pragma omp threadprivate(minBufferSize) |
---|
| 63 | static bool isOptPerformance; //!< Check if buffer size is for performance (as large as possible) |
---|
| 64 | #pragma omp threadprivate(isOptPerformance) |
---|
| 65 | static CRegistry* globalRegistry ; //!< global registry which is wrote by the root process of the servers |
---|
| 66 | #pragma omp threadprivate(globalRegistry) |
---|
| 67 | static double recvFieldTimeout; //!< Time to wait for data before issuing an error when receiving a field |
---|
| 68 | #pragma omp threadprivate(recvFieldTimeout) |
---|
| 69 | static bool checkEventSync; //!< For debuuging, check if event are coherent and synchrone on client side |
---|
[1328] | 70 | |
---|
[512] | 71 | public: |
---|
[1460] | 72 | //! Setting xios to use server mode |
---|
| 73 | static void setUsingServer(); |
---|
[490] | 74 | |
---|
[1460] | 75 | //! Setting xios NOT to use server mode |
---|
| 76 | static void setNotUsingServer(); |
---|
[491] | 77 | |
---|
[1460] | 78 | //! Initialize server (if any) |
---|
| 79 | static void initServer(); |
---|
[509] | 80 | |
---|
[512] | 81 | private: |
---|
| 82 | //! Parse only Xios part of configuration file |
---|
[511] | 83 | static void parseXiosConfig(); |
---|
[300] | 84 | } ; |
---|
| 85 | } |
---|
| 86 | |
---|
[352] | 87 | //#include "cxios_impl.hpp" |
---|
[512] | 88 | #endif // __XIOS_HPP__ |
---|