Changeset 2265


Ignore:
Timestamp:
11/25/21 18:25:19 (3 years ago)
Author:
ymipsl
Message:

tracking memory leak : remove context and all related object from object factory when context is finalized.
YM

Location:
XIOS/dev/dev_ym/XIOS_COUPLING/src
Files:
11 edited

Legend:

Unmodified
Added
Removed
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/client.cpp

    r2260 r2265  
    487487      CTimer::get("XIOS init/finalize",false).suspend() ; 
    488488      CTimer::get("XIOS").suspend() ; 
    489        
     489      CContext::removeAllContexts() ; // free memory for related context  
    490490      CXios::finalizeDaemonsManager() ; 
    491491 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/interface/c/icdata.cpp

    r2243 r2265  
    135135     CContext* context = CContext::getCurrent(); 
    136136     context->finalize(); 
     137     CContext::removeContext(context->getId()) ; 
    137138     CTimer::get("XIOS context finalize").suspend(); 
    138139     CTimer::get("XIOS").suspend(); 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/manager/server_context.cpp

    r2260 r2265  
    252252      if (context_->eventLoop()) 
    253253      { 
     254        info(100)<<"Remove context server with id "<<context_->getId()<<endl ; 
     255        CContext::removeContext(context_->getId()) ; 
    254256        context_=nullptr ; 
    255257        // destroy context ??? --> later 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/node/calendar_wrapper.hpp

    r1542 r2265  
    8282  }; // class CCalendarWrapper 
    8383 
     84  typedef CCalendarWrapper CCalendarWrapperGroup; 
    8485  typedef CCalendarWrapper CCalendarWrapperDefinition; 
    8586} // namespace xios 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/node/context.cpp

    r2258 r2265  
    289289   CATCH 
    290290 
     291void CContext::removeContext(const string& contextId) 
     292{ 
     293  #define DECLARE_NODE(Name_, name_)     CObjectFactory::deleteContext< C##Name_ >(contextId); 
     294  #define DECLARE_NODE_PAR(Name_, name_) CObjectFactory::deleteContext< C##Name_ >(contextId); 
     295  #include "node_type.conf" 
     296  #define DECLARE_NODE(Name_, name_)     CObjectFactory::deleteContext< C##Name_##Group >(contextId); 
     297  #define DECLARE_NODE_PAR(Name_, name_)  
     298  #include "node_type.conf" 
     299 
     300/* 
     301  #define DECLARE_NODE(Name_, name_)     CObjectFactory::dumpObjects< C##Name_##Group >(); 
     302  #define DECLARE_NODE_PAR(Name_, name_)  
     303  #include "node_type.conf" 
     304 
     305  #define DECLARE_NODE(Name_, name_)     CObjectFactory::dumpObjects< C##Name_>(); 
     306  #define DECLARE_NODE_PAR(Name_, name_)  
     307  #include "node_type.conf" 
     308*/ 
     309} 
     310 
     311void CContext::removeAllContexts(void) 
     312{ 
     313  #define DECLARE_NODE(Name_, name_)     CObjectFactory::deleteAllContexts< C##Name_ >(); 
     314  #define DECLARE_NODE_PAR(Name_, name_) CObjectFactory::deleteAllContexts< C##Name_ >(); 
     315  #include "node_type.conf" 
     316  #define DECLARE_NODE(Name_, name_)     CObjectFactory::deleteAllContexts< C##Name_##Group >(); 
     317  #define DECLARE_NODE_PAR(Name_, name_)  
     318  #include "node_type.conf" 
     319/* 
     320  #define DECLARE_NODE(Name_, name_)     CObjectFactory::dumpObjects< C##Name_##Group >(); 
     321  #define DECLARE_NODE_PAR(Name_, name_)  
     322  #include "node_type.conf" 
     323 
     324  #define DECLARE_NODE(Name_, name_)     CObjectFactory::dumpObjects< C##Name_>(); 
     325  #define DECLARE_NODE_PAR(Name_, name_)  
     326  #include "node_type.conf" 
     327*/ 
     328} 
    291329   ///--------------------------------------------------------------- 
    292330 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/node/context.hpp

    r2209 r2265  
    246246        static void ShowTree(StdOStream & out = std::clog); 
    247247        static void CleanTree(void); 
     248        static void removeContext(const std::string& contextId); 
     249        static void removeAllContexts(void) ; 
    248250        int getServiceType(void) {return serviceType_;} 
    249251 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/object_factory.hpp

    r1869 r2265  
    5454             static std::shared_ptr<U> CreateAlias(const StdString& id, const StdString& alias) ; 
    5555          
    56          template <typename U> static const StdString& GetUIdBase(void); 
     56         template <typename U> static const StdString GetUIdBase(void); 
    5757         template <typename U> static StdString GenUId(void); 
    5858         template <typename U> static bool IsGenUId(const StdString& id); 
    59  
     59         template <typename U> static void deleteContext(const StdString & context) ; 
     60         template <typename U> static void deleteAllContexts(void) ; 
     61         template <typename U> static void dumpObjects(void) ; 
    6062      private : 
    6163 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/object_factory_decl_macro.hpp

    r2130 r2265  
    1414  template std::shared_ptr<U> CObjectFactory::CreateObject<U>(const StdString& id ); \ 
    1515  template std::shared_ptr<U> CObjectFactory::CreateAlias<U>(const StdString& id, const StdString& alias ); \ 
    16   template const StdString& CObjectFactory::GetUIdBase<U>(void); \ 
     16  template const StdString CObjectFactory::GetUIdBase<U>(void); \ 
    1717  template StdString CObjectFactory::GenUId<U>(void); \ 
    18   template bool CObjectFactory::IsGenUId<U>(const StdString& id); 
     18  template bool CObjectFactory::IsGenUId<U>(const StdString& id);\ 
     19  template void CObjectFactory::deleteContext<U>(const StdString & context) ;\ 
     20  template void CObjectFactory::deleteAllContexts<U>() ;\ 
     21  template void CObjectFactory::dumpObjects<U>(void) ; 
    1922 
    2023 
    2124 
     25 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/object_factory_impl.hpp

    r2183 r2265  
    147147 
    148148   template <typename U> 
    149    const StdString& CObjectFactory::GetUIdBase(void) 
    150    { 
    151       static StdString base ;  
     149   const StdString CObjectFactory::GetUIdBase(void) 
     150   { 
     151      StdString base ;  
    152152//      base = "__"+CObjectFactory::CurrContext + "::" + U::GetName() + "_undef_id_"; 
    153153      base = CObjectFactory::CurrContext + "__" + U::GetName() + "_undef_id_"; 
     
    166166   bool CObjectFactory::IsGenUId(const StdString& id) 
    167167   { 
    168       const StdString& base = GetUIdBase<U>(); 
     168      const StdString base = GetUIdBase<U>(); 
    169169      return (id.size() > base.size() && id.compare(0, base.size(), base) == 0); 
    170170   } 
    171171 
     172   template <typename U>  
     173   void CObjectFactory::deleteContext(const StdString & context) 
     174   { 
     175     for (auto& v : U::AllVectObj[context]) v.reset() ; 
     176     U::AllVectObj[context].clear() ; 
     177     U::AllVectObj.erase(context) ;  
     178     for (auto& m : U::AllMapObj[context])  m.second.reset() ; 
     179     U::AllMapObj[context].clear() ; 
     180     U::AllMapObj.erase(context) ; 
     181 
     182     U::GenId.erase(context) ; 
     183   } 
     184 
     185   template <typename U>  
     186   void CObjectFactory::deleteAllContexts(void) 
     187   { 
     188     list<StdString> contextList ; 
     189     for(auto& context : U::AllMapObj) contextList.push_back(context.first) ; 
     190     for(auto& context : contextList) deleteContext<U>(context) ; 
     191   } 
     192 
     193    
     194   template <typename U>  
     195   void CObjectFactory::dumpObjects(void) 
     196   { 
     197     for (auto& context : U::AllMapObj)  
     198      for(auto& m : context.second) 
     199      { 
     200        info(100)<<"Dump All Object"<<endl ; 
     201        info(100)<<"Object from context "<<context.first<<" with id "<<m.first<<endl ;  
     202      } 
     203   } 
    172204} // namespace xios 
    173205 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/object_template.hpp

    r2243 r2265  
    124124         CObjectTemplate(void); 
    125125         explicit CObjectTemplate(const StdString & id); 
    126          CObjectTemplate(const CObjectTemplate<T> & object, 
    127                          bool withAttrList = true, bool withId = true); 
     126         CObjectTemplate(const CObjectTemplate<T> & object, bool withAttrList = true, bool withId = true); 
    128127         CObjectTemplate(const CObjectTemplate<T> * const object); // Not implemented. 
    129128 
     
    131130 
    132131         /// Propriétés statiques /// 
    133          static xios_map<StdString, 
    134                 xios_map<StdString, 
    135                 std::shared_ptr<DerivedType> > > AllMapObj; 
    136          static xios_map<StdString, 
    137                 std::vector<std::shared_ptr<DerivedType> > > AllVectObj; 
     132         static xios_map<StdString, xios_map<StdString, std::shared_ptr<DerivedType> > > AllMapObj; 
     133         static xios_map<StdString, std::vector<std::shared_ptr<DerivedType> > > AllVectObj; 
    138134 
    139135         static xios_map< StdString, long int > GenId ; 
  • XIOS/dev/dev_ym/XIOS_COUPLING/src/server.cpp

    r2243 r2265  
    313313 
    314314//      MPI_Comm_free(&intraComm); 
    315  
     315      CContext::removeAllContexts() ; // free memory for related context  
    316316      CXios::finalizeDaemonsManager(); 
    317317       
Note: See TracChangeset for help on using the changeset viewer.