diff --git a/extras/Hadrons/Environment.hpp b/extras/Hadrons/Environment.hpp index 5058a820..5177b312 100644 --- a/extras/Hadrons/Environment.hpp +++ b/extras/Hadrons/Environment.hpp @@ -216,14 +216,21 @@ void Environment::createDerivedObject(const std::string name, if (!object_[address].data) { MemoryStats memStats; - - MemoryProfiler::stats = &memStats; + + if (!MemoryProfiler::stats) + { + MemoryProfiler::stats = &memStats; + } + size_t initMem = MemoryProfiler::stats->currentlyAllocated; object_[address].storage = storage; object_[address].Ls = Ls; object_[address].data.reset(new Holder(new T(std::forward(args)...))); - object_[address].size = memStats.maxAllocated; + object_[address].size = MemoryProfiler::stats->maxAllocated - initMem; object_[address].type = &typeid(T); - MemoryProfiler::stats = nullptr; + if (MemoryProfiler::stats == &memStats) + { + MemoryProfiler::stats = nullptr; + } } else { diff --git a/extras/Hadrons/Global.cc b/extras/Hadrons/Global.cc index 7b0b8fb6..130ede96 100644 --- a/extras/Hadrons/Global.cc +++ b/extras/Hadrons/Global.cc @@ -39,33 +39,6 @@ HadronsLogger Hadrons::HadronsLogMessage(1,"Message"); HadronsLogger Hadrons::HadronsLogIterative(1,"Iterative"); HadronsLogger Hadrons::HadronsLogDebug(1,"Debug"); -// pretty size formatting ////////////////////////////////////////////////////// -std::string Hadrons::sizeString(long unsigned int bytes) - -{ - constexpr unsigned int bufSize = 256; - const char *suffixes[7] = {"", "K", "M", "G", "T", "P", "E"}; - char buf[256]; - long unsigned int s = 0; - double count = bytes; - - while (count >= 1024 && s < 7) - { - s++; - count /= 1024; - } - if (count - floor(count) == 0.0) - { - snprintf(buf, bufSize, "%d %sB", (int)count, suffixes[s]); - } - else - { - snprintf(buf, bufSize, "%.1f %sB", count, suffixes[s]); - } - - return std::string(buf); -} - // type utilities ////////////////////////////////////////////////////////////// constexpr unsigned int maxNameSize = 1024u; diff --git a/extras/Hadrons/Global.hpp b/extras/Hadrons/Global.hpp index 1f0ce201..4c37b961 100644 --- a/extras/Hadrons/Global.hpp +++ b/extras/Hadrons/Global.hpp @@ -138,9 +138,6 @@ public:\ private:\ name(void) = default; -// pretty size formating -std::string sizeString(long unsigned int bytes); - // type utilities template const std::type_info * typeIdPt(const T &x) diff --git a/lib/allocator/AlignedAllocator.cc b/lib/allocator/AlignedAllocator.cc index dfdb1050..10b49f4b 100644 --- a/lib/allocator/AlignedAllocator.cc +++ b/lib/allocator/AlignedAllocator.cc @@ -97,4 +97,29 @@ void check_huge_pages(void *Buf,uint64_t BYTES) #endif } +std::string sizeString(const size_t bytes) +{ + constexpr unsigned int bufSize = 256; + const char *suffixes[7] = {"", "K", "M", "G", "T", "P", "E"}; + char buf[256]; + size_t s = 0; + double count = bytes; + + while (count >= 1024 && s < 7) + { + s++; + count /= 1024; + } + if (count - floor(count) == 0.0) + { + snprintf(buf, bufSize, "%d %sB", (int)count, suffixes[s]); + } + else + { + snprintf(buf, bufSize, "%.1f %sB", count, suffixes[s]); + } + + return std::string(buf); +} + } diff --git a/lib/allocator/AlignedAllocator.h b/lib/allocator/AlignedAllocator.h index 85e2b240..3b27aec9 100644 --- a/lib/allocator/AlignedAllocator.h +++ b/lib/allocator/AlignedAllocator.h @@ -64,6 +64,8 @@ namespace Grid { }; + std::string sizeString(size_t bytes); + struct MemoryStats { size_t totalAllocated{0}, maxAllocated{0}, @@ -77,15 +79,20 @@ namespace Grid { static bool debug; }; + #define memString(bytes) std::to_string(bytes) + " (" + sizeString(bytes) + ")" #define profilerDebugPrint \ if (MemoryProfiler::stats)\ {\ auto s = MemoryProfiler::stats;\ - std::cout << "[Memory debug] Stats " << MemoryProfiler::stats << std::endl;\ - std::cout << "[Memory debug] Total : " << s->totalAllocated << "B" << std::endl;\ - std::cout << "[Memory debug] Max : " << s->maxAllocated << "B" << std::endl;\ - std::cout << "[Memory debug] Current: " << s->totalAllocated << "B" << std::endl;\ - std::cout << "[Memory debug] Freed : " << s->totalFreed << "B" << std::endl;\ + std::cout << GridLogDebug << "[Memory debug] Stats " << MemoryProfiler::stats << std::endl;\ + std::cout << GridLogDebug << "[Memory debug] total : " << memString(s->totalAllocated) \ + << std::endl;\ + std::cout << GridLogDebug << "[Memory debug] max : " << memString(s->maxAllocated) \ + << std::endl;\ + std::cout << GridLogDebug << "[Memory debug] current: " << memString(s->currentlyAllocated) \ + << std::endl;\ + std::cout << GridLogDebug << "[Memory debug] freed : " << memString(s->totalFreed) \ + << std::endl;\ } #define profilerAllocate(bytes)\ @@ -98,7 +105,7 @@ namespace Grid { }\ if (MemoryProfiler::debug)\ {\ - std::cout << "[Memory debug] allocating " << bytes << "B" << std::endl;\ + std::cout << GridLogDebug << "[Memory debug] allocating " << memString(bytes) << std::endl;\ profilerDebugPrint;\ } @@ -111,7 +118,7 @@ namespace Grid { }\ if (MemoryProfiler::debug)\ {\ - std::cout << "[Memory debug] freeing " << bytes << "B" << std::endl;\ + std::cout << GridLogDebug << "[Memory debug] freeing " << memString(bytes) << std::endl;\ profilerDebugPrint;\ } diff --git a/lib/util/Init.cc b/lib/util/Init.cc index 031f8f5a..20367293 100644 --- a/lib/util/Init.cc +++ b/lib/util/Init.cc @@ -204,7 +204,7 @@ std::string GridCmdVectorIntToString(const std::vector & vec){ // Reinit guard ///////////////////////////////////////////////////////// static int Grid_is_initialised = 0; - +static MemoryStats dbgMemStats; void Grid_init(int *argc,char ***argv) { @@ -251,6 +251,11 @@ void Grid_init(int *argc,char ***argv) assert(fp!=(FILE *)NULL); } + if( GridCmdOptionExists(*argv,*argv+*argc,"--debug-mem") ){ + MemoryProfiler::debug = true; + MemoryProfiler::stats = &dbgMemStats; + } + //////////////////////////////////// // Banner //////////////////////////////////// @@ -324,6 +329,7 @@ void Grid_init(int *argc,char ***argv) std::cout<