diff options
author | babenko <babenko@yandex-team.ru> | 2022-02-10 16:49:19 +0300 |
---|---|---|
committer | Daniil Cherednik <dcherednik@yandex-team.ru> | 2022-02-10 16:49:19 +0300 |
commit | f31097c96270919a1f49360bdaaa69ea4f3fefab (patch) | |
tree | 5d5cb817648f650d76cf1076100726fd9b8448e8 /library/cpp/ytalloc | |
parent | cec37806d8847aa3db53bafc9e251d4aaf325c12 (diff) | |
download | ydb-f31097c96270919a1f49360bdaaa69ea4f3fefab.tar.gz |
Restoring authorship annotation for <babenko@yandex-team.ru>. Commit 2 of 2.
Diffstat (limited to 'library/cpp/ytalloc')
-rw-r--r-- | library/cpp/ytalloc/api/README.md | 12 | ||||
-rw-r--r-- | library/cpp/ytalloc/api/fallback.cpp | 420 | ||||
-rw-r--r-- | library/cpp/ytalloc/api/ya.make | 26 | ||||
-rw-r--r-- | library/cpp/ytalloc/api/ytalloc-inl.h | 210 | ||||
-rw-r--r-- | library/cpp/ytalloc/api/ytalloc.h | 810 | ||||
-rw-r--r-- | library/cpp/ytalloc/ya.make | 32 |
6 files changed, 755 insertions, 755 deletions
diff --git a/library/cpp/ytalloc/api/README.md b/library/cpp/ytalloc/api/README.md index 08d30a3e66..1b57e81b5c 100644 --- a/library/cpp/ytalloc/api/README.md +++ b/library/cpp/ytalloc/api/README.md @@ -1,6 +1,6 @@ -This lightweight module can be used by anyone interested in YTAlloc -functionality (memory allocation and disposal, memory tagging, etc). - -If YTAlloc happens to be linked in, it provides an efficient implementation. -Otherwise (non-YTAlloc build), weak implementations from fallback.cpp -are used.
\ No newline at end of file +This lightweight module can be used by anyone interested in YTAlloc +functionality (memory allocation and disposal, memory tagging, etc). + +If YTAlloc happens to be linked in, it provides an efficient implementation. +Otherwise (non-YTAlloc build), weak implementations from fallback.cpp +are used.
\ No newline at end of file diff --git a/library/cpp/ytalloc/api/fallback.cpp b/library/cpp/ytalloc/api/fallback.cpp index 6511b62f0f..5880ede439 100644 --- a/library/cpp/ytalloc/api/fallback.cpp +++ b/library/cpp/ytalloc/api/fallback.cpp @@ -1,24 +1,24 @@ -// This file contains the fallback implementations of YTAlloc-specific stuff. -// These implementations are annotated with Y_WEAK to ensure that if the actual YTAlloc -// is available at the link time, the latter is preferred over the fallback. -#include "ytalloc.h" - -#include <util/system/compiler.h> -#include <util/system/yassert.h> - -#include <cstdlib> - -namespace NYT::NYTAlloc { - -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK void* Allocate(size_t size) -{ - return ::malloc(size); -} - -Y_WEAK void* AllocatePageAligned(size_t size) -{ +// This file contains the fallback implementations of YTAlloc-specific stuff. +// These implementations are annotated with Y_WEAK to ensure that if the actual YTAlloc +// is available at the link time, the latter is preferred over the fallback. +#include "ytalloc.h" + +#include <util/system/compiler.h> +#include <util/system/yassert.h> + +#include <cstdlib> + +namespace NYT::NYTAlloc { + +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK void* Allocate(size_t size) +{ + return ::malloc(size); +} + +Y_WEAK void* AllocatePageAligned(size_t size) +{ #if defined(_win_) return ::_aligned_malloc(size, PageSize); #elif defined(_darwin_) || !defined(_musl_) @@ -26,195 +26,195 @@ Y_WEAK void* AllocatePageAligned(size_t size) #else return ::memalign(PageSize, size); #endif -} - -Y_WEAK void* AllocateSmall(size_t rank) -{ - return ::malloc(SmallRankToSize[rank]); -} - -Y_WEAK void Free(void* ptr) -{ - ::free(ptr); -} - -Y_WEAK void FreeNonNull(void* ptr) -{ - Y_ASSERT(ptr); - ::free(ptr); -} - -Y_WEAK size_t GetAllocationSize(const void* /*ptr*/) -{ - return 0; -} - -Y_WEAK size_t GetAllocationSize(size_t size) -{ - return size; -} - -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK TMemoryTag GetCurrentMemoryTag() -{ - return NullMemoryTag; -} - -Y_WEAK void SetCurrentMemoryTag(TMemoryTag /*tag*/) -{ } - -Y_WEAK size_t GetMemoryUsageForTag(TMemoryTag /*tag*/) -{ - return 0; -} - -Y_WEAK void GetMemoryUsageForTags(const TMemoryTag* /*tags*/, size_t /*count*/, size_t* /*results*/) -{ } - -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK void SetCurrentMemoryZone(EMemoryZone /*zone*/) -{ } - -Y_WEAK EMemoryZone GetCurrentMemoryZone() -{ - return EMemoryZone::Normal; -} - -Y_WEAK EMemoryZone GetAllocationMemoryZone(const void* /*ptr*/) -{ - return EMemoryZone::Normal; -} - -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK void SetCurrentFiberId(TFiberId /*id*/) -{ } - -Y_WEAK TFiberId GetCurrentFiberId() -{ - return 0; -} - -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK void EnableLogging(TLogHandler /*logHandler*/) -{ } - -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK void SetBacktraceProvider(TBacktraceProvider /*provider*/) -{ } - +} + +Y_WEAK void* AllocateSmall(size_t rank) +{ + return ::malloc(SmallRankToSize[rank]); +} + +Y_WEAK void Free(void* ptr) +{ + ::free(ptr); +} + +Y_WEAK void FreeNonNull(void* ptr) +{ + Y_ASSERT(ptr); + ::free(ptr); +} + +Y_WEAK size_t GetAllocationSize(const void* /*ptr*/) +{ + return 0; +} + +Y_WEAK size_t GetAllocationSize(size_t size) +{ + return size; +} + +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK TMemoryTag GetCurrentMemoryTag() +{ + return NullMemoryTag; +} + +Y_WEAK void SetCurrentMemoryTag(TMemoryTag /*tag*/) +{ } + +Y_WEAK size_t GetMemoryUsageForTag(TMemoryTag /*tag*/) +{ + return 0; +} + +Y_WEAK void GetMemoryUsageForTags(const TMemoryTag* /*tags*/, size_t /*count*/, size_t* /*results*/) +{ } + +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK void SetCurrentMemoryZone(EMemoryZone /*zone*/) +{ } + +Y_WEAK EMemoryZone GetCurrentMemoryZone() +{ + return EMemoryZone::Normal; +} + +Y_WEAK EMemoryZone GetAllocationMemoryZone(const void* /*ptr*/) +{ + return EMemoryZone::Normal; +} + +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK void SetCurrentFiberId(TFiberId /*id*/) +{ } + +Y_WEAK TFiberId GetCurrentFiberId() +{ + return 0; +} + +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK void EnableLogging(TLogHandler /*logHandler*/) +{ } + +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK void SetBacktraceProvider(TBacktraceProvider /*provider*/) +{ } + Y_WEAK void SetBacktraceFormatter(TBacktraceFormatter /*formatter*/) { } -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK void EnableStockpile() -{ } - -Y_WEAK void SetStockpileInterval(TDuration /*value*/) -{ } - -Y_WEAK void SetStockpileThreadCount(int /*value*/) -{ } - -Y_WEAK void SetStockpileSize(size_t /*value*/) -{ } - -Y_WEAK void SetLargeUnreclaimableCoeff(double /*value*/) -{ } - -Y_WEAK void SetMinLargeUnreclaimableBytes(size_t /*value*/) -{ } - -Y_WEAK void SetMaxLargeUnreclaimableBytes(size_t /*value*/) -{ } - -Y_WEAK void SetTimingEventThreshold(TDuration /*value*/) -{ } - -Y_WEAK void SetAllocationProfilingEnabled(bool /*value*/) -{ } - -Y_WEAK void SetAllocationProfilingSamplingRate(double /*rate*/) -{ } - -Y_WEAK void SetSmallArenaAllocationProfilingEnabled(size_t /*rank*/, bool /*value*/) -{ } - -Y_WEAK void SetLargeArenaAllocationProfilingEnabled(size_t /*rank*/, bool /*value*/) -{ } - -Y_WEAK void SetProfilingBacktraceDepth(int /*depth*/) -{ } - -Y_WEAK void SetMinProfilingBytesUsedToReport(size_t /*size*/) -{ } - -Y_WEAK void SetEnableEagerMemoryRelease(bool /*value*/) -{ } - -Y_WEAK void SetEnableMadvisePopulate(bool /*value*/) -{ } - -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK TEnumIndexedVector<ETotalCounter, ssize_t> GetTotalAllocationCounters() -{ - return {}; -} - -Y_WEAK TEnumIndexedVector<ESmallCounter, ssize_t> GetSmallAllocationCounters() -{ - return {}; -} - -Y_WEAK TEnumIndexedVector<ELargeCounter, ssize_t> GetLargeAllocationCounters() -{ - return {}; -} - -Y_WEAK std::array<TEnumIndexedVector<ESmallArenaCounter, ssize_t>, SmallRankCount> GetSmallArenaAllocationCounters() -{ - return {}; -} - -Y_WEAK std::array<TEnumIndexedVector<ELargeArenaCounter, ssize_t>, LargeRankCount> GetLargeArenaAllocationCounters() -{ - return {}; -} - -Y_WEAK TEnumIndexedVector<EHugeCounter, ssize_t> GetHugeAllocationCounters() -{ - return {}; -} - -Y_WEAK TEnumIndexedVector<ESystemCounter, ssize_t> GetSystemAllocationCounters() -{ - return {}; -} - -Y_WEAK TEnumIndexedVector<EUndumpableCounter, ssize_t> GetUndumpableAllocationCounters() -{ - return {}; -} - -Y_WEAK TEnumIndexedVector<ETimingEventType, TTimingEventCounters> GetTimingEventCounters() -{ - return {}; -} - -//////////////////////////////////////////////////////////////////////////////// - -Y_WEAK std::vector<TProfiledAllocation> GetProfiledAllocationStatistics() -{ - return {}; -} - -//////////////////////////////////////////////////////////////////////////////// - -} // namespace NYT::NYTAlloc - +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK void EnableStockpile() +{ } + +Y_WEAK void SetStockpileInterval(TDuration /*value*/) +{ } + +Y_WEAK void SetStockpileThreadCount(int /*value*/) +{ } + +Y_WEAK void SetStockpileSize(size_t /*value*/) +{ } + +Y_WEAK void SetLargeUnreclaimableCoeff(double /*value*/) +{ } + +Y_WEAK void SetMinLargeUnreclaimableBytes(size_t /*value*/) +{ } + +Y_WEAK void SetMaxLargeUnreclaimableBytes(size_t /*value*/) +{ } + +Y_WEAK void SetTimingEventThreshold(TDuration /*value*/) +{ } + +Y_WEAK void SetAllocationProfilingEnabled(bool /*value*/) +{ } + +Y_WEAK void SetAllocationProfilingSamplingRate(double /*rate*/) +{ } + +Y_WEAK void SetSmallArenaAllocationProfilingEnabled(size_t /*rank*/, bool /*value*/) +{ } + +Y_WEAK void SetLargeArenaAllocationProfilingEnabled(size_t /*rank*/, bool /*value*/) +{ } + +Y_WEAK void SetProfilingBacktraceDepth(int /*depth*/) +{ } + +Y_WEAK void SetMinProfilingBytesUsedToReport(size_t /*size*/) +{ } + +Y_WEAK void SetEnableEagerMemoryRelease(bool /*value*/) +{ } + +Y_WEAK void SetEnableMadvisePopulate(bool /*value*/) +{ } + +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK TEnumIndexedVector<ETotalCounter, ssize_t> GetTotalAllocationCounters() +{ + return {}; +} + +Y_WEAK TEnumIndexedVector<ESmallCounter, ssize_t> GetSmallAllocationCounters() +{ + return {}; +} + +Y_WEAK TEnumIndexedVector<ELargeCounter, ssize_t> GetLargeAllocationCounters() +{ + return {}; +} + +Y_WEAK std::array<TEnumIndexedVector<ESmallArenaCounter, ssize_t>, SmallRankCount> GetSmallArenaAllocationCounters() +{ + return {}; +} + +Y_WEAK std::array<TEnumIndexedVector<ELargeArenaCounter, ssize_t>, LargeRankCount> GetLargeArenaAllocationCounters() +{ + return {}; +} + +Y_WEAK TEnumIndexedVector<EHugeCounter, ssize_t> GetHugeAllocationCounters() +{ + return {}; +} + +Y_WEAK TEnumIndexedVector<ESystemCounter, ssize_t> GetSystemAllocationCounters() +{ + return {}; +} + +Y_WEAK TEnumIndexedVector<EUndumpableCounter, ssize_t> GetUndumpableAllocationCounters() +{ + return {}; +} + +Y_WEAK TEnumIndexedVector<ETimingEventType, TTimingEventCounters> GetTimingEventCounters() +{ + return {}; +} + +//////////////////////////////////////////////////////////////////////////////// + +Y_WEAK std::vector<TProfiledAllocation> GetProfiledAllocationStatistics() +{ + return {}; +} + +//////////////////////////////////////////////////////////////////////////////// + +} // namespace NYT::NYTAlloc + diff --git a/library/cpp/ytalloc/api/ya.make b/library/cpp/ytalloc/api/ya.make index 502d4273fa..26d0efd381 100644 --- a/library/cpp/ytalloc/api/ya.make +++ b/library/cpp/ytalloc/api/ya.make @@ -1,13 +1,13 @@ -LIBRARY() - -OWNER(g:yt) - -SRCS( - fallback.cpp -) - -PEERDIR( - library/cpp/yt/misc -) - -END() +LIBRARY() + +OWNER(g:yt) + +SRCS( + fallback.cpp +) + +PEERDIR( + library/cpp/yt/misc +) + +END() diff --git a/library/cpp/ytalloc/api/ytalloc-inl.h b/library/cpp/ytalloc/api/ytalloc-inl.h index 8b698a3125..263108423d 100644 --- a/library/cpp/ytalloc/api/ytalloc-inl.h +++ b/library/cpp/ytalloc/api/ytalloc-inl.h @@ -1,105 +1,105 @@ -#pragma once -#ifndef YT_ALLOC_INL_H_ -#error "Direct inclusion of this file is not allowed, include ytalloc.h" -// For the sake of sane code completion. -#include "ytalloc.h" -#endif - -#include <util/system/types.h> - -namespace NYT::NYTAlloc { - -//////////////////////////////////////////////////////////////////////////////// - -// Maps small chunk ranks to size in bytes. -constexpr ui16 SmallRankToSize[SmallRankCount] = { - 0, - 16, 32, 48, 64, 96, 128, - 192, 256, 384, 512, 768, 1024, 1536, 2048, - 3072, 4096, 6144, 8192, 12288, 16384, 24576, 32768 -}; - -// Helper array for mapping size to small chunk rank. -constexpr ui8 SizeToSmallRank1[65] = { - 1, 1, 1, 2, 2, // 16, 32 - 3, 3, 4, 4, // 48, 64 - 5, 5, 5, 5, 6, 6, 6, 6, // 96, 128 - 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, // 192, 256 - 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, // 384 - 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10 // 512 -}; - -// Helper array for mapping size to small chunk rank. -constexpr unsigned char SizeToSmallRank2[128] = { - 10, 10, 11, 12, // 512, 512, 768, 1022 - 13, 13, 14, 14, // 1536, 2048 - 15, 15, 15, 15, 16, 16, 16, 16, // 3072, 4096 - 17, 17, 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, // 6144, 8192 - 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, // 12288 - 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, // 16384 - 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, - 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, // 22576 - 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, - 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22 // 32768 -}; - -//////////////////////////////////////////////////////////////////////////////// - -constexpr size_t SizeToSmallRank(size_t size) -{ - if (size <= 512) { - return SizeToSmallRank1[(size + 7) >> 3]; - } else { - if (size <= LargeAllocationSizeThreshold) { - return SizeToSmallRank2[(size - 1) >> 8]; - } else { - return 0; - } - } -} - -void* AllocateSmall(size_t rank); - -template <size_t Size> -void* AllocateConstSize() -{ - constexpr auto rank = SizeToSmallRank(Size); - if constexpr(rank != 0) { - return AllocateSmall(rank); - } else { - return Allocate(Size); - } -} - -//////////////////////////////////////////////////////////////////////////////// - -inline TMemoryTagGuard::TMemoryTagGuard() - : Active_(false) - , PreviousTag_(NullMemoryTag) -{ } - -inline TMemoryTagGuard::TMemoryTagGuard(TMemoryTag tag) - : Active_(true) - , PreviousTag_(GetCurrentMemoryTag()) -{ - SetCurrentMemoryTag(tag); -} - -inline TMemoryTagGuard::TMemoryTagGuard(TMemoryTagGuard&& other) - : Active_(other.Active_) - , PreviousTag_(other.PreviousTag_) -{ - other.Active_ = false; - other.PreviousTag_ = NullMemoryTag; -} - -inline TMemoryTagGuard::~TMemoryTagGuard() -{ - if (Active_) { - SetCurrentMemoryTag(PreviousTag_); - } -} - -//////////////////////////////////////////////////////////////////////////////// - -} // namespace NYT::NYTAlloc +#pragma once +#ifndef YT_ALLOC_INL_H_ +#error "Direct inclusion of this file is not allowed, include ytalloc.h" +// For the sake of sane code completion. +#include "ytalloc.h" +#endif + +#include <util/system/types.h> + +namespace NYT::NYTAlloc { + +//////////////////////////////////////////////////////////////////////////////// + +// Maps small chunk ranks to size in bytes. +constexpr ui16 SmallRankToSize[SmallRankCount] = { + 0, + 16, 32, 48, 64, 96, 128, + 192, 256, 384, 512, 768, 1024, 1536, 2048, + 3072, 4096, 6144, 8192, 12288, 16384, 24576, 32768 +}; + +// Helper array for mapping size to small chunk rank. +constexpr ui8 SizeToSmallRank1[65] = { + 1, 1, 1, 2, 2, // 16, 32 + 3, 3, 4, 4, // 48, 64 + 5, 5, 5, 5, 6, 6, 6, 6, // 96, 128 + 7, 7, 7, 7, 7, 7, 7, 7, 8, 8, 8, 8, 8, 8, 8, 8, // 192, 256 + 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, // 384 + 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10, 10 // 512 +}; + +// Helper array for mapping size to small chunk rank. +constexpr unsigned char SizeToSmallRank2[128] = { + 10, 10, 11, 12, // 512, 512, 768, 1022 + 13, 13, 14, 14, // 1536, 2048 + 15, 15, 15, 15, 16, 16, 16, 16, // 3072, 4096 + 17, 17, 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, // 6144, 8192 + 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, 19, // 12288 + 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, 20, // 16384 + 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, + 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, 21, // 22576 + 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, + 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22, 22 // 32768 +}; + +//////////////////////////////////////////////////////////////////////////////// + +constexpr size_t SizeToSmallRank(size_t size) +{ + if (size <= 512) { + return SizeToSmallRank1[(size + 7) >> 3]; + } else { + if (size <= LargeAllocationSizeThreshold) { + return SizeToSmallRank2[(size - 1) >> 8]; + } else { + return 0; + } + } +} + +void* AllocateSmall(size_t rank); + +template <size_t Size> +void* AllocateConstSize() +{ + constexpr auto rank = SizeToSmallRank(Size); + if constexpr(rank != 0) { + return AllocateSmall(rank); + } else { + return Allocate(Size); + } +} + +//////////////////////////////////////////////////////////////////////////////// + +inline TMemoryTagGuard::TMemoryTagGuard() + : Active_(false) + , PreviousTag_(NullMemoryTag) +{ } + +inline TMemoryTagGuard::TMemoryTagGuard(TMemoryTag tag) + : Active_(true) + , PreviousTag_(GetCurrentMemoryTag()) +{ + SetCurrentMemoryTag(tag); +} + +inline TMemoryTagGuard::TMemoryTagGuard(TMemoryTagGuard&& other) + : Active_(other.Active_) + , PreviousTag_(other.PreviousTag_) +{ + other.Active_ = false; + other.PreviousTag_ = NullMemoryTag; +} + +inline TMemoryTagGuard::~TMemoryTagGuard() +{ + if (Active_) { + SetCurrentMemoryTag(PreviousTag_); + } +} + +//////////////////////////////////////////////////////////////////////////////// + +} // namespace NYT::NYTAlloc diff --git a/library/cpp/ytalloc/api/ytalloc.h b/library/cpp/ytalloc/api/ytalloc.h index ad8e8f948b..d942dde638 100644 --- a/library/cpp/ytalloc/api/ytalloc.h +++ b/library/cpp/ytalloc/api/ytalloc.h @@ -1,416 +1,416 @@ -#pragma once - -#include <stddef.h> - -#include <library/cpp/yt/misc/enum.h> - -#include <util/system/types.h> - -#include <util/generic/size_literals.h> - -#include <util/datetime/base.h> - -namespace NYT::NYTAlloc { - -//////////////////////////////////////////////////////////////////////////////// -// Macros - +#pragma once + +#include <stddef.h> + +#include <library/cpp/yt/misc/enum.h> + +#include <util/system/types.h> + +#include <util/generic/size_literals.h> + +#include <util/datetime/base.h> + +namespace NYT::NYTAlloc { + +//////////////////////////////////////////////////////////////////////////////// +// Macros + #if defined(_linux_) && \ !defined(_asan_enabled_) && \ !defined(_msan_enabled_) && \ - !defined(_tsan_enabled_) - #define YT_ALLOC_ENABLED -#endif - -//////////////////////////////////////////////////////////////////////////////// -// Constants - -constexpr int SmallRankCount = 23; -constexpr int MinLargeRank = 15; -constexpr int LargeRankCount = 30; -constexpr size_t LargeAllocationSizeThreshold = 32_KB; -constexpr size_t HugeAllocationSizeThreshold = 1ULL << (LargeRankCount - 1); -constexpr size_t MaxAllocationSize = 1_TB; -constexpr size_t PageSize = 4_KB; -constexpr size_t RightReadableAreaSize = 16; - -//////////////////////////////////////////////////////////////////////////////// -// Allocation API - -// Allocates a chunk of memory of (at least) #size bytes. -// The returned pointer is guaranteed to be 16-byte aligned. -// Moreover, it is guaranteeed that #RightReadableAreaSize bytes immediately following -// the allocated chunk are readable (but may belong to another allocated chunk). -// This enables eliminating some nasty corner cases in SIMD memory manipulations. -void* Allocate(size_t size); - -// Allocates a chunk of memory of (at least) #size bytes. -// The returned pointer is guaranteed to be 4K-byte aligned. -// #size, however, need not be divisible by page size (but internally it will be rounded up). -void* AllocatePageAligned(size_t size); - -// An optimized version of #Allocate with #Size being known at compile-time. -template <size_t Size> -void* AllocateConstSize(); - -// Frees a chunk of memory previously allocated via Allocate functions. -// Does nothing if #ptr is null. -void Free(void* ptr); - -// Similar to #Free but assumes that #ptr is not null. -void FreeNonNull(void* ptr); - -// Returns the size of the chunk pointed to by #ptr. -// This size is not guaranteed to be exactly equal to #size passed to allocation functions -// due to rounding; the returned size, however, is never less than the latter size. -// If #ptr is null or we are unable to determine the allocation size, then 0 is returned. -size_t GetAllocationSize(const void* ptr); - -// Returns the size of the chunk that will actually be allocated -// when requesting an allocation of given #size. This is never less than #size. -size_t GetAllocationSize(size_t size); - -//////////////////////////////////////////////////////////////////////////////// -// Memory tagging API -// -// Each allocation can be tagged with a number (from 1 to MaxMemoryTag). -// Setting this to NullMemoryTag disables tagging. -// Internally, YTAlloc tracks the number of bytes used by each tag. -// -// Tagged allocations are somewhat slower. Others (large and huge) are not affected -// (but for these performance implications are negligible anyway). -// -// The current memory tag used for allocations is stored in TLS. - -using TMemoryTag = ui32; -constexpr TMemoryTag NullMemoryTag = 0; -constexpr TMemoryTag MaxMemoryTag = (1ULL << 22) - 1; - -// Updates the current tag value in TLS. -void SetCurrentMemoryTag(TMemoryTag tag); - -// Returns the current tag value from TLS. -TMemoryTag GetCurrentMemoryTag(); - -// Returns the memory usage for a given tag. -// The value is somewhat approxiate and racy. -size_t GetMemoryUsageForTag(TMemoryTag tag); - -// A batched version of GetMemoryUsageForTag. -void GetMemoryUsageForTags(const TMemoryTag* tags, size_t count, size_t* results); - -//////////////////////////////////////////////////////////////////////////////// -// Memory zone API -// -// Each allocation is either in the "normal zone" or "undumpable zone". -// The latter indicates that this memory region will be excluded from a coredump -// should it happen. -// -// The current zone used for allocations is stored in TLS. - -// Memory zone is used to pass hint to the allocator. -DEFINE_ENUM(EMemoryZone, - ((Unknown) (-1)) // not a valid zone - ((Normal) ( 0)) // default memory type - ((Undumpable) ( 1)) // memory is omitted from the core dump -); - -// Updates the current zone in TLS. -void SetCurrentMemoryZone(EMemoryZone zone); - -// Returns the current zone from TLS. -EMemoryZone GetCurrentMemoryZone(); - -// Returns the zone where #ptr resides; -// EMemoryZone::Invalid indicates that #ptr is outside of any recognized memory zone. -EMemoryZone GetAllocationMemoryZone(const void* ptr); - -//////////////////////////////////////////////////////////////////////////////// -// When a "timing event" (hiccup) occurs during an allocation, -// YTAlloc records this event and captures the current fiber id. -// The latter is provided externally by calling SetCurrentFiberId. -// -// This may be helpful to correlate various application-level timings -// with internal events in YTAlloc. -// -// The current fiber id is stored in TLS. - -using TFiberId = ui64; - -// Updates the current fiber id in TLS. -void SetCurrentFiberId(TFiberId id); - -// Returns the currently assinged fiber id from TLS. -TFiberId GetCurrentFiberId(); - -//////////////////////////////////////////////////////////////////////////////// -// Logging - -DEFINE_ENUM(ELogEventSeverity, - (Debug) - (Info) - (Warning) - (Error) -); - -struct TLogEvent -{ - ELogEventSeverity Severity; - TStringBuf Message; -}; - -using TLogHandler = void(*)(const TLogEvent& event); - -// Sets the handler to be invoked for each log event produced by YTAlloc. -// Can be called multiple times (but calls to the previous incarnations of the handler -// are racy). -void EnableLogging(TLogHandler logHandler); - -//////////////////////////////////////////////////////////////////////////////// -// Backtraces - -using TBacktraceProvider = int(*)(void** frames, int maxFrames, int skipFrames); - -// Sets the provider used for collecting backtraces when allocation profiling -// is turned ON. Can be called multiple times (but calls to the previous -// incarnations of the provider are racy). -void SetBacktraceProvider(TBacktraceProvider provider); - -using TBacktraceFormatter = TString(*)(const void* const* frames, int frameCount); + !defined(_tsan_enabled_) + #define YT_ALLOC_ENABLED +#endif + +//////////////////////////////////////////////////////////////////////////////// +// Constants + +constexpr int SmallRankCount = 23; +constexpr int MinLargeRank = 15; +constexpr int LargeRankCount = 30; +constexpr size_t LargeAllocationSizeThreshold = 32_KB; +constexpr size_t HugeAllocationSizeThreshold = 1ULL << (LargeRankCount - 1); +constexpr size_t MaxAllocationSize = 1_TB; +constexpr size_t PageSize = 4_KB; +constexpr size_t RightReadableAreaSize = 16; + +//////////////////////////////////////////////////////////////////////////////// +// Allocation API + +// Allocates a chunk of memory of (at least) #size bytes. +// The returned pointer is guaranteed to be 16-byte aligned. +// Moreover, it is guaranteeed that #RightReadableAreaSize bytes immediately following +// the allocated chunk are readable (but may belong to another allocated chunk). +// This enables eliminating some nasty corner cases in SIMD memory manipulations. +void* Allocate(size_t size); + +// Allocates a chunk of memory of (at least) #size bytes. +// The returned pointer is guaranteed to be 4K-byte aligned. +// #size, however, need not be divisible by page size (but internally it will be rounded up). +void* AllocatePageAligned(size_t size); + +// An optimized version of #Allocate with #Size being known at compile-time. +template <size_t Size> +void* AllocateConstSize(); + +// Frees a chunk of memory previously allocated via Allocate functions. +// Does nothing if #ptr is null. +void Free(void* ptr); + +// Similar to #Free but assumes that #ptr is not null. +void FreeNonNull(void* ptr); + +// Returns the size of the chunk pointed to by #ptr. +// This size is not guaranteed to be exactly equal to #size passed to allocation functions +// due to rounding; the returned size, however, is never less than the latter size. +// If #ptr is null or we are unable to determine the allocation size, then 0 is returned. +size_t GetAllocationSize(const void* ptr); + +// Returns the size of the chunk that will actually be allocated +// when requesting an allocation of given #size. This is never less than #size. +size_t GetAllocationSize(size_t size); + +//////////////////////////////////////////////////////////////////////////////// +// Memory tagging API +// +// Each allocation can be tagged with a number (from 1 to MaxMemoryTag). +// Setting this to NullMemoryTag disables tagging. +// Internally, YTAlloc tracks the number of bytes used by each tag. +// +// Tagged allocations are somewhat slower. Others (large and huge) are not affected +// (but for these performance implications are negligible anyway). +// +// The current memory tag used for allocations is stored in TLS. + +using TMemoryTag = ui32; +constexpr TMemoryTag NullMemoryTag = 0; +constexpr TMemoryTag MaxMemoryTag = (1ULL << 22) - 1; + +// Updates the current tag value in TLS. +void SetCurrentMemoryTag(TMemoryTag tag); + +// Returns the current tag value from TLS. +TMemoryTag GetCurrentMemoryTag(); + +// Returns the memory usage for a given tag. +// The value is somewhat approxiate and racy. +size_t GetMemoryUsageForTag(TMemoryTag tag); + +// A batched version of GetMemoryUsageForTag. +void GetMemoryUsageForTags(const TMemoryTag* tags, size_t count, size_t* results); + +//////////////////////////////////////////////////////////////////////////////// +// Memory zone API +// +// Each allocation is either in the "normal zone" or "undumpable zone". +// The latter indicates that this memory region will be excluded from a coredump +// should it happen. +// +// The current zone used for allocations is stored in TLS. + +// Memory zone is used to pass hint to the allocator. +DEFINE_ENUM(EMemoryZone, + ((Unknown) (-1)) // not a valid zone + ((Normal) ( 0)) // default memory type + ((Undumpable) ( 1)) // memory is omitted from the core dump +); + +// Updates the current zone in TLS. +void SetCurrentMemoryZone(EMemoryZone zone); + +// Returns the current zone from TLS. +EMemoryZone GetCurrentMemoryZone(); + +// Returns the zone where #ptr resides; +// EMemoryZone::Invalid indicates that #ptr is outside of any recognized memory zone. +EMemoryZone GetAllocationMemoryZone(const void* ptr); + +//////////////////////////////////////////////////////////////////////////////// +// When a "timing event" (hiccup) occurs during an allocation, +// YTAlloc records this event and captures the current fiber id. +// The latter is provided externally by calling SetCurrentFiberId. +// +// This may be helpful to correlate various application-level timings +// with internal events in YTAlloc. +// +// The current fiber id is stored in TLS. + +using TFiberId = ui64; + +// Updates the current fiber id in TLS. +void SetCurrentFiberId(TFiberId id); + +// Returns the currently assinged fiber id from TLS. +TFiberId GetCurrentFiberId(); + +//////////////////////////////////////////////////////////////////////////////// +// Logging + +DEFINE_ENUM(ELogEventSeverity, + (Debug) + (Info) + (Warning) + (Error) +); + +struct TLogEvent +{ + ELogEventSeverity Severity; + TStringBuf Message; +}; + +using TLogHandler = void(*)(const TLogEvent& event); + +// Sets the handler to be invoked for each log event produced by YTAlloc. +// Can be called multiple times (but calls to the previous incarnations of the handler +// are racy). +void EnableLogging(TLogHandler logHandler); + +//////////////////////////////////////////////////////////////////////////////// +// Backtraces + +using TBacktraceProvider = int(*)(void** frames, int maxFrames, int skipFrames); + +// Sets the provider used for collecting backtraces when allocation profiling +// is turned ON. Can be called multiple times (but calls to the previous +// incarnations of the provider are racy). +void SetBacktraceProvider(TBacktraceProvider provider); + +using TBacktraceFormatter = TString(*)(const void* const* frames, int frameCount); // Sets the callback used for formatting backtraces during large arena mmap calls // to help detect memory leaks. Can be called multiple times (but calls to the // previous incarnations of the provider are racy). void SetBacktraceFormatter(TBacktraceFormatter provider); -//////////////////////////////////////////////////////////////////////////////// -// Misc - -//! Tries to mlock all opened file mappings of the current process. -//! Typically invoked on application startup to lock all binaries in memory -//! and prevent executable code and static data to be paged out -//! causing latency spikes. +//////////////////////////////////////////////////////////////////////////////// +// Misc + +//! Tries to mlock all opened file mappings of the current process. +//! Typically invoked on application startup to lock all binaries in memory +//! and prevent executable code and static data to be paged out +//! causing latency spikes. void MlockFileMappings(bool populate = true); - -//////////////////////////////////////////////////////////////////////////////// -// Configuration API - -// Calling this function enables periodic calls to madvise(ADV_STOCKPILE); -// cf. https://st.yandex-team.ru/KERNEL-186 -void EnableStockpile(); - -// Sets the interval between madvise(ADV_STOCKPILE) calls. -// Only makes sense if stockpile was enabled. -void SetStockpileInterval(TDuration value); - -// Sets the number of threads to be invoking madvise(ADV_STOCKPILE). -// This call should be made before calling #EnableStockpile. -void SetStockpileThreadCount(int value); - -// Sets the size passsed to madvise(ADV_STOCKPILE) calls. -// Only makes sense if stockpile was enabled. -void SetStockpileSize(size_t value); - -// For large blobs, YTAlloc keeps at least -// LargeUnreclaimableCoeff * TotalLargeBytesUsed clamped to range -// [MinLargeUnreclaimableBytes, MaxLargeUnreclaimableBytes] -// bytes of pooled (unreclaimable) memory. -void SetLargeUnreclaimableCoeff(double value); -void SetMinLargeUnreclaimableBytes(size_t value); -void SetMaxLargeUnreclaimableBytes(size_t value); - -// When a syscall (mmap, munmap, or madvise) or an internal lock acquisition -// takes longer then the configured time, a "timing event" is recorded. -void SetTimingEventThreshold(TDuration value); - -// Toggles the global allocation profiling knob (OFF by default). -// For profiled allocations, YTAlloc collects (see #SetBacktraceProvider) and aggregates their -// backtraces. -void SetAllocationProfilingEnabled(bool value); - -// Determines the fraction of allocations to be sampled for profiling. -void SetAllocationProfilingSamplingRate(double rate); - -// Controls if small allocations of a given rank are profiled (OFF by default). -void SetSmallArenaAllocationProfilingEnabled(size_t rank, bool value); - -// Controls if large allocations of a given rank are profiled (OFF by default). -void SetLargeArenaAllocationProfilingEnabled(size_t rank, bool value); - -// Controls the depth of the backtraces to collect. Deeper backtraces -// take more time and affect the program performance. -void SetProfilingBacktraceDepth(int depth); - -// Controls the minimum number of bytes a certain backtrace must -// allocate to appear in profiling reports. -void SetMinProfilingBytesUsedToReport(size_t size); - -// If set to true (default), YTAlloc uses madvise with MADV_DONTNEED to release unused large blob pages -// (slower but leads to more predicable RSS values); -// if false then MADV_FREE is used instead, if available -// (faster but RSS may get stuck arbitrary higher than the actual usage as long -// as no memory pressure is applied). -void SetEnableEagerMemoryRelease(bool value); - -// If set to true, YTAlloc uses madvise with MADV_POPULATE to prefault freshly acclaimed pages. -// Otherwise (this is the default), these pages are prefaulted with linear memory access. -// See https://st.yandex-team.ru/KERNEL-185. -void SetEnableMadvisePopulate(bool value); - -//////////////////////////////////////////////////////////////////////////////// -// Statistics API - -DEFINE_ENUM(EBasicCounter, - (BytesAllocated) - (BytesFreed) - (BytesUsed) -); - -using ESystemCounter = EBasicCounter; -using ESmallCounter = EBasicCounter; -using ELargeCounter = EBasicCounter; -using EUndumpableCounter = EBasicCounter; - -DEFINE_ENUM(ESmallArenaCounter, - (PagesMapped) - (BytesMapped) - (PagesCommitted) - (BytesCommitted) -); - -DEFINE_ENUM(ELargeArenaCounter, - (BytesSpare) - (BytesOverhead) - (BlobsAllocated) - (BlobsFreed) - (BlobsUsed) - (BytesAllocated) - (BytesFreed) - (BytesUsed) - (ExtentsAllocated) - (PagesMapped) - (BytesMapped) - (PagesPopulated) - (BytesPopulated) - (PagesReleased) - (BytesReleased) - (PagesCommitted) - (BytesCommitted) - (OverheadBytesReclaimed) - (SpareBytesReclaimed) -); - -DEFINE_ENUM(EHugeCounter, - (BytesAllocated) - (BytesFreed) - (BytesUsed) - (BlobsAllocated) - (BlobsFreed) - (BlobsUsed) -); - -DEFINE_ENUM(ETotalCounter, - (BytesAllocated) - (BytesFreed) - (BytesUsed) - (BytesCommitted) - (BytesUnaccounted) -); - -// Returns statistics for all user allocations. -TEnumIndexedVector<ETotalCounter, ssize_t> GetTotalAllocationCounters(); - -// Returns statistics for small allocations; these are included into total statistics. -TEnumIndexedVector<ESmallCounter, ssize_t> GetSmallAllocationCounters(); - -// Returns statistics for large allocations; these are included into total statistics. -TEnumIndexedVector<ELargeCounter, ssize_t> GetLargeAllocationCounters(); - -// Returns per-arena statistics for small allocations; these are included into total statistics. -std::array<TEnumIndexedVector<ESmallArenaCounter, ssize_t>, SmallRankCount> GetSmallArenaAllocationCounters(); - -// Returns per-arena statistics for large allocations; these are included into total statistics. -std::array<TEnumIndexedVector<ELargeArenaCounter, ssize_t>, LargeRankCount> GetLargeArenaAllocationCounters(); - -// Returns statistics for huge allocations; these are included into total statistics. -TEnumIndexedVector<EHugeCounter, ssize_t> GetHugeAllocationCounters(); - -// Returns statistics for all system allocations; these are not included into total statistics. -TEnumIndexedVector<ESystemCounter, ssize_t> GetSystemAllocationCounters(); - -// Returns statistics for undumpable allocations. -TEnumIndexedVector<EUndumpableCounter, ssize_t> GetUndumpableAllocationCounters(); - -DEFINE_ENUM(ETimingEventType, - (Mmap) - (Munmap) - (MadvisePopulate) - (MadviseFree) - (MadviseDontNeed) - (Locking) - (Prefault) + +//////////////////////////////////////////////////////////////////////////////// +// Configuration API + +// Calling this function enables periodic calls to madvise(ADV_STOCKPILE); +// cf. https://st.yandex-team.ru/KERNEL-186 +void EnableStockpile(); + +// Sets the interval between madvise(ADV_STOCKPILE) calls. +// Only makes sense if stockpile was enabled. +void SetStockpileInterval(TDuration value); + +// Sets the number of threads to be invoking madvise(ADV_STOCKPILE). +// This call should be made before calling #EnableStockpile. +void SetStockpileThreadCount(int value); + +// Sets the size passsed to madvise(ADV_STOCKPILE) calls. +// Only makes sense if stockpile was enabled. +void SetStockpileSize(size_t value); + +// For large blobs, YTAlloc keeps at least +// LargeUnreclaimableCoeff * TotalLargeBytesUsed clamped to range +// [MinLargeUnreclaimableBytes, MaxLargeUnreclaimableBytes] +// bytes of pooled (unreclaimable) memory. +void SetLargeUnreclaimableCoeff(double value); +void SetMinLargeUnreclaimableBytes(size_t value); +void SetMaxLargeUnreclaimableBytes(size_t value); + +// When a syscall (mmap, munmap, or madvise) or an internal lock acquisition +// takes longer then the configured time, a "timing event" is recorded. +void SetTimingEventThreshold(TDuration value); + +// Toggles the global allocation profiling knob (OFF by default). +// For profiled allocations, YTAlloc collects (see #SetBacktraceProvider) and aggregates their +// backtraces. +void SetAllocationProfilingEnabled(bool value); + +// Determines the fraction of allocations to be sampled for profiling. +void SetAllocationProfilingSamplingRate(double rate); + +// Controls if small allocations of a given rank are profiled (OFF by default). +void SetSmallArenaAllocationProfilingEnabled(size_t rank, bool value); + +// Controls if large allocations of a given rank are profiled (OFF by default). +void SetLargeArenaAllocationProfilingEnabled(size_t rank, bool value); + +// Controls the depth of the backtraces to collect. Deeper backtraces +// take more time and affect the program performance. +void SetProfilingBacktraceDepth(int depth); + +// Controls the minimum number of bytes a certain backtrace must +// allocate to appear in profiling reports. +void SetMinProfilingBytesUsedToReport(size_t size); + +// If set to true (default), YTAlloc uses madvise with MADV_DONTNEED to release unused large blob pages +// (slower but leads to more predicable RSS values); +// if false then MADV_FREE is used instead, if available +// (faster but RSS may get stuck arbitrary higher than the actual usage as long +// as no memory pressure is applied). +void SetEnableEagerMemoryRelease(bool value); + +// If set to true, YTAlloc uses madvise with MADV_POPULATE to prefault freshly acclaimed pages. +// Otherwise (this is the default), these pages are prefaulted with linear memory access. +// See https://st.yandex-team.ru/KERNEL-185. +void SetEnableMadvisePopulate(bool value); + +//////////////////////////////////////////////////////////////////////////////// +// Statistics API + +DEFINE_ENUM(EBasicCounter, + (BytesAllocated) + (BytesFreed) + (BytesUsed) +); + +using ESystemCounter = EBasicCounter; +using ESmallCounter = EBasicCounter; +using ELargeCounter = EBasicCounter; +using EUndumpableCounter = EBasicCounter; + +DEFINE_ENUM(ESmallArenaCounter, + (PagesMapped) + (BytesMapped) + (PagesCommitted) + (BytesCommitted) +); + +DEFINE_ENUM(ELargeArenaCounter, + (BytesSpare) + (BytesOverhead) + (BlobsAllocated) + (BlobsFreed) + (BlobsUsed) + (BytesAllocated) + (BytesFreed) + (BytesUsed) + (ExtentsAllocated) + (PagesMapped) + (BytesMapped) + (PagesPopulated) + (BytesPopulated) + (PagesReleased) + (BytesReleased) + (PagesCommitted) + (BytesCommitted) + (OverheadBytesReclaimed) + (SpareBytesReclaimed) +); + +DEFINE_ENUM(EHugeCounter, + (BytesAllocated) + (BytesFreed) + (BytesUsed) + (BlobsAllocated) + (BlobsFreed) + (BlobsUsed) +); + +DEFINE_ENUM(ETotalCounter, + (BytesAllocated) + (BytesFreed) + (BytesUsed) + (BytesCommitted) + (BytesUnaccounted) +); + +// Returns statistics for all user allocations. +TEnumIndexedVector<ETotalCounter, ssize_t> GetTotalAllocationCounters(); + +// Returns statistics for small allocations; these are included into total statistics. +TEnumIndexedVector<ESmallCounter, ssize_t> GetSmallAllocationCounters(); + +// Returns statistics for large allocations; these are included into total statistics. +TEnumIndexedVector<ELargeCounter, ssize_t> GetLargeAllocationCounters(); + +// Returns per-arena statistics for small allocations; these are included into total statistics. +std::array<TEnumIndexedVector<ESmallArenaCounter, ssize_t>, SmallRankCount> GetSmallArenaAllocationCounters(); + +// Returns per-arena statistics for large allocations; these are included into total statistics. +std::array<TEnumIndexedVector<ELargeArenaCounter, ssize_t>, LargeRankCount> GetLargeArenaAllocationCounters(); + +// Returns statistics for huge allocations; these are included into total statistics. +TEnumIndexedVector<EHugeCounter, ssize_t> GetHugeAllocationCounters(); + +// Returns statistics for all system allocations; these are not included into total statistics. +TEnumIndexedVector<ESystemCounter, ssize_t> GetSystemAllocationCounters(); + +// Returns statistics for undumpable allocations. +TEnumIndexedVector<EUndumpableCounter, ssize_t> GetUndumpableAllocationCounters(); + +DEFINE_ENUM(ETimingEventType, + (Mmap) + (Munmap) + (MadvisePopulate) + (MadviseFree) + (MadviseDontNeed) + (Locking) + (Prefault) (FilePrefault) -); - -struct TTimingEventCounters -{ - // Number of events happened since start. - size_t Count = 0; - // Total size of memory blocks involved in these events (if applicable). - size_t Size = 0; -}; - -// Returns statistics for timing events happened since start. -// See SetTimingEventThreshold. -TEnumIndexedVector<ETimingEventType, TTimingEventCounters> GetTimingEventCounters(); - -//////////////////////////////////////////////////////////////////////////////// - -// We never collect backtraces deeper than this limit. -constexpr int MaxAllocationProfilingBacktraceDepth = 16; - -struct TBacktrace -{ - int FrameCount; - std::array<void*, MaxAllocationProfilingBacktraceDepth> Frames; -}; - -struct TProfiledAllocation -{ - TBacktrace Backtrace; - TEnumIndexedVector<EBasicCounter, ssize_t> Counters; -}; - -// Returns statistics for profiled allocations (available when allocation -// profiling is ON). Allocations are grouped by backtrace; for each backtrace -// we provide the counters indicating the number of allocated, freed, and used bytes. -// To appear here, used bytes counter must be at least the value configured -// via SetMinProfilingBytesUsedToReport. -std::vector<TProfiledAllocation> GetProfiledAllocationStatistics(); - -//////////////////////////////////////////////////////////////////////////////// - -//! An RAII guard for setting the current memory tag in a scope. -class TMemoryTagGuard -{ -public: - TMemoryTagGuard(); - explicit TMemoryTagGuard(TMemoryTag tag); - - TMemoryTagGuard(const TMemoryTagGuard& other) = delete; - TMemoryTagGuard(TMemoryTagGuard&& other); - - ~TMemoryTagGuard(); - -private: - bool Active_; - TMemoryTag PreviousTag_; -}; - -//////////////////////////////////////////////////////////////////////////////// - -} // namespace NYT::NYTAlloc - -#define YT_ALLOC_INL_H_ -#include "ytalloc-inl.h" -#undef YT_ALLOC_INL_H_ +); + +struct TTimingEventCounters +{ + // Number of events happened since start. + size_t Count = 0; + // Total size of memory blocks involved in these events (if applicable). + size_t Size = 0; +}; + +// Returns statistics for timing events happened since start. +// See SetTimingEventThreshold. +TEnumIndexedVector<ETimingEventType, TTimingEventCounters> GetTimingEventCounters(); + +//////////////////////////////////////////////////////////////////////////////// + +// We never collect backtraces deeper than this limit. +constexpr int MaxAllocationProfilingBacktraceDepth = 16; + +struct TBacktrace +{ + int FrameCount; + std::array<void*, MaxAllocationProfilingBacktraceDepth> Frames; +}; + +struct TProfiledAllocation +{ + TBacktrace Backtrace; + TEnumIndexedVector<EBasicCounter, ssize_t> Counters; +}; + +// Returns statistics for profiled allocations (available when allocation +// profiling is ON). Allocations are grouped by backtrace; for each backtrace +// we provide the counters indicating the number of allocated, freed, and used bytes. +// To appear here, used bytes counter must be at least the value configured +// via SetMinProfilingBytesUsedToReport. +std::vector<TProfiledAllocation> GetProfiledAllocationStatistics(); + +//////////////////////////////////////////////////////////////////////////////// + +//! An RAII guard for setting the current memory tag in a scope. +class TMemoryTagGuard +{ +public: + TMemoryTagGuard(); + explicit TMemoryTagGuard(TMemoryTag tag); + + TMemoryTagGuard(const TMemoryTagGuard& other) = delete; + TMemoryTagGuard(TMemoryTagGuard&& other); + + ~TMemoryTagGuard(); + +private: + bool Active_; + TMemoryTag PreviousTag_; +}; + +//////////////////////////////////////////////////////////////////////////////// + +} // namespace NYT::NYTAlloc + +#define YT_ALLOC_INL_H_ +#include "ytalloc-inl.h" +#undef YT_ALLOC_INL_H_ diff --git a/library/cpp/ytalloc/ya.make b/library/cpp/ytalloc/ya.make index f3495efb13..97aa73c135 100644 --- a/library/cpp/ytalloc/ya.make +++ b/library/cpp/ytalloc/ya.make @@ -1,17 +1,17 @@ -OWNER(g:yt) - -IF (NOT OS_DARWIN AND NOT SANITIZER_TYPE) - SET(YT_ALLOC_ENABLED yes) -ENDIF() - -RECURSE( - api - impl -) - -IF (YT_ALLOC_ENABLED) - RECURSE( - ut +OWNER(g:yt) + +IF (NOT OS_DARWIN AND NOT SANITIZER_TYPE) + SET(YT_ALLOC_ENABLED yes) +ENDIF() + +RECURSE( + api + impl +) + +IF (YT_ALLOC_ENABLED) + RECURSE( + ut benchmarks - ) -ENDIF() + ) +ENDIF() |