source: XIOS3/branches/xios-3.0-beta/src/cxios.hpp @ 2505

Last change on this file since 2505 was 2505, checked in by jderouillat, 11 months ago

Backport 2500, 2502 (convex cells) and 2503 (memory_report option) from XIOS2

  • Property copyright set to
    Software name : XIOS (Xml I/O Server)
    http://forge.ipsl.jussieu.fr/ioserver
    Creation date : January 2009
    Licence : CeCCIL version2
    see license file in root directory : Licence_CeCILL_V2-en.txt
    or http://www.cecill.info/licences/Licence_CeCILL_V2-en.html
    Holder : CEA/LSCE (Laboratoire des Sciences du CLimat et de l'Environnement)
    CNRS/IPSL (Institut Pierre Simon Laplace)
    Project Manager : Yann Meurdesoif
    yann.meurdesoif@cea.fr
File size: 6.0 KB
Line 
1#ifndef __XIOS_HPP__
2#define __XIOS_HPP__
3
4#include "xios_spl.hpp"
5#include "mpi.hpp"
6#include "registry.hpp"
7#include "ressources_manager.hpp"
8#include "services_manager.hpp"
9#include "contexts_manager.hpp"
10#include "daemons_manager.hpp"
11#include "coupler_manager.hpp"
12#include "registry_manager.hpp"
13#include "mpi_garbage_collector.hpp"
14
15namespace xios
16{
17  /*!
18  \class CXios
19  */
20  class CXios
21  {
22    public:
23     static void initialize(void) ;
24     static void initClientSide(const string & codeId, MPI_Comm& localComm, MPI_Comm& returnComm) ;
25     static void initServerSide(void) ;
26     static void clientFinalize(void) ;
27     static void parseFile(const string& filename) ;
28
29     template <typename T>
30     static T getin(const string& id,const T& defaultValue) ;
31
32     template <typename T>
33     static T getin(const string& id) ;
34
35    public:
36     static string rootFile ; //!< Configuration filename
37     static string xiosCodeId ; //!< Identity for XIOS
38     static string clientFile;        //!< Filename template for client
39     static string serverFile;        //!< Filename template for server
40     static string serverPrmFile;  //!< Filename template for primary server in case of two server levels
41     static string serverSndFile;  //!< Filename template for secondary server in case of two server levels
42
43     static bool xiosStack;    //!< Exception handling
44     static bool systemStack;  //!< Exception handling
45
46     static bool isClient ; //!< Check if xios is client
47     static bool isServer ; //!< Check if xios is server
48
49     static MPI_Comm globalComm ; //!< Global communicator
50     static MPI_Comm xiosComm ; //!< Global communicator
51
52     static bool printLogs2Files; //!< Printing out logs into files
53     static bool usingOasis ;     //!< Using Oasis
54     static bool usingServer ;    //!< Using server (server mode)
55     static bool usingServer2 ;   //!< Using secondary server (server mode). IMPORTANT: Use this variable ONLY in CServer::initialize().
56     static int ratioServer2 ;    //!< Percentage of server processors dedicated to secondary server
57     static int nbPoolsServer2 ;  //!< Number of pools created on the secondary server
58     static double bufferSizeFactor; //!< Factor used to tune the buffer size
59     static const double defaultBufferSizeFactor; //!< Default factor value
60     static StdSize minBufferSize; //!< Minimum buffer size
61     static StdSize maxBufferSize; //!< Maximum buffer size
62     static bool isOptPerformance; //!< Check if buffer size is for performance (as large as possible)
63     static CRegistry* globalRegistry ; //!< global registry which is wrote by the root process of the servers
64     static double recvFieldTimeout; //!< Time to wait for data before issuing an error when receiving a field
65     static bool checkEventSync; //!< For debuuging, check if event are coherent and synchrone on client side
66
67     static bool checkSumSend; //!< For debugging, compute a checksum of fields sent by the model to the XIOS client (very expensive !)
68     static bool checkSumRecv; //!< For debugging, compute a checksum of fields received by the model through the XIOS client
69
70     static bool logMemory; //!< Activate memory monitoring for all XIOS process (generate CSV file for https://forge.ipsl.jussieu.fr/ioserver/chrome/site/XIOS_TOOLS/xios_memory.html)
71     static bool reportMemory; //!< Activate memory reporting for all XIOS process (report in log files)
72
73     static const string defaultPoolId ;
74     static const string defaultServerId ;
75     static const string defaultGathererId ;
76     static const string defaultServicesId ;
77
78     static CRegistryManager* registryManager_ ;
79     static CRessourcesManager* ressourcesManager_ ;
80     static CCouplerManager* couplerManager_ ;
81     static CServicesManager* servicesManager_ ;
82     static CContextsManager* contextsManager_ ;
83     static CDaemonsManager* daemonsManager_ ;
84     static CMpiGarbageCollector MpiGarbageCollector_  ;
85    public:
86     static CMpiGarbageCollector& getMpiGarbageCollector(void) { return MpiGarbageCollector_ ; }
87    public:
88     //! Setting xios to use server mode
89     static void setUsingServer();
90
91     //! Setting xios NOT to use server mode
92     static void setNotUsingServer();
93     
94     //! is using server mode
95     static bool isUsingServer() {return usingServer;}
96
97     //! Initialize server (if any)
98     static  void initServer();
99
100     static void launchServicesManager( bool isXiosServer) ;
101     static void launchContextsManager(bool isXiosServer) ;
102     static void launchDaemonsManager(bool isXiosServer) ;
103     static void launchRessourcesManager(bool isXiosServer) ;
104     static void launchCouplerManager(bool isXiosServer) ;
105     static void launchRegistryManager(bool isXiosServer) ;
106   
107     static void finalizeServicesManager() ;
108     static void finalizeContextsManager() ;
109     static void finalizeDaemonsManager() ;
110     static void finalizeRessourcesManager() ;
111     static void finalizeCouplerManager() ;
112     static void finalizeRegistryManager() ;
113
114     static CRegistryManager*   getRegistryManager(void) { return registryManager_ ;}
115     static CRessourcesManager* getRessourcesManager(void) { return ressourcesManager_ ;}
116     static CCouplerManager*    getCouplerManager(void) { return couplerManager_ ;}
117     static CServicesManager*   getServicesManager(void) { return servicesManager_ ;}
118     static CContextsManager*   getContextsManager(void) { return contextsManager_ ;}
119     static CDaemonsManager*    getDaemonsManager(void) { return daemonsManager_ ;}
120     static CPoolRessource*     getPoolRessource(void) ;
121     
122     static MPI_Comm getGlobalComm(void) { return globalComm ;}
123     static MPI_Comm getXiosComm(void) { return xiosComm ;}
124     static void setXiosComm(MPI_Comm comm) { xiosComm=comm ;}
125     static CRegistry* getGlobalRegistry(void) { return globalRegistry ;}
126     static void setGlobalRegistry(CRegistry* registry) { globalRegistry=registry ;}
127
128    private:
129      //! Parse only Xios part of configuration file
130      static void parseXiosConfig();
131  } ;
132}
133
134//#include "cxios_impl.hpp"
135#endif // __XIOS_HPP__
Note: See TracBrowser for help on using the repository browser.