aboutsummaryrefslogtreecommitdiffstats
path: root/util/memory/pool.cpp
diff options
context:
space:
mode:
authorAnton Samokhvalov <pg83@yandex.ru>2022-02-10 16:45:15 +0300
committerDaniil Cherednik <dcherednik@yandex-team.ru>2022-02-10 16:45:15 +0300
commit72cb13b4aff9bc9cf22e49251bc8fd143f82538f (patch)
treeda2c34829458c7d4e74bdfbdf85dff449e9e7fb8 /util/memory/pool.cpp
parent778e51ba091dc39e7b7fcab2b9cf4dbedfb6f2b5 (diff)
downloadydb-72cb13b4aff9bc9cf22e49251bc8fd143f82538f.tar.gz
Restoring authorship annotation for Anton Samokhvalov <pg83@yandex.ru>. Commit 1 of 2.
Diffstat (limited to 'util/memory/pool.cpp')
-rw-r--r--util/memory/pool.cpp76
1 files changed, 38 insertions, 38 deletions
diff --git a/util/memory/pool.cpp b/util/memory/pool.cpp
index 9a011f0e4f..b3144aefc3 100644
--- a/util/memory/pool.cpp
+++ b/util/memory/pool.cpp
@@ -1,55 +1,55 @@
-#include "pool.h"
-
+#include "pool.h"
+
TMemoryPool::IGrowPolicy* TMemoryPool::TLinearGrow::Instance() noexcept {
- return SingletonWithPriority<TLinearGrow, 0>();
-}
-
+ return SingletonWithPriority<TLinearGrow, 0>();
+}
+
TMemoryPool::IGrowPolicy* TMemoryPool::TExpGrow::Instance() noexcept {
- return SingletonWithPriority<TExpGrow, 0>();
-}
-
-void TMemoryPool::AddChunk(size_t hint) {
- const size_t dataLen = Max(BlockSize_, hint);
+ return SingletonWithPriority<TExpGrow, 0>();
+}
+
+void TMemoryPool::AddChunk(size_t hint) {
+ const size_t dataLen = Max(BlockSize_, hint);
size_t allocSize = dataLen + sizeof(TChunk);
if (Options_.RoundUpToNextPowerOfTwo) {
allocSize = FastClp2(allocSize);
}
TBlock nb = Alloc_->Allocate(allocSize);
-
+
// Add previous chunk's stats
if (Current_ != &Empty_) {
MemoryAllocatedBeforeCurrent_ += Current_->Used();
MemoryWasteBeforeCurrent_ += Current_->Left();
}
- BlockSize_ = GrowPolicy_->Next(dataLen);
- Current_ = new (nb.Data) TChunk(nb.Len - sizeof(TChunk));
- Chunks_.PushBack(Current_);
-}
-
-void TMemoryPool::DoClear(bool keepfirst) noexcept {
- while (!Chunks_.Empty()) {
- TChunk* c = Chunks_.PopBack();
-
- if (keepfirst && Chunks_.Empty()) {
- c->ResetChunk();
- Chunks_.PushBack(c);
- Current_ = c;
- BlockSize_ = c->BlockLength() - sizeof(TChunk);
- MemoryAllocatedBeforeCurrent_ = 0;
+ BlockSize_ = GrowPolicy_->Next(dataLen);
+ Current_ = new (nb.Data) TChunk(nb.Len - sizeof(TChunk));
+ Chunks_.PushBack(Current_);
+}
+
+void TMemoryPool::DoClear(bool keepfirst) noexcept {
+ while (!Chunks_.Empty()) {
+ TChunk* c = Chunks_.PopBack();
+
+ if (keepfirst && Chunks_.Empty()) {
+ c->ResetChunk();
+ Chunks_.PushBack(c);
+ Current_ = c;
+ BlockSize_ = c->BlockLength() - sizeof(TChunk);
+ MemoryAllocatedBeforeCurrent_ = 0;
MemoryWasteBeforeCurrent_ = 0;
- return;
- }
-
- TBlock b = {c, c->BlockLength()};
-
- c->~TChunk();
- Alloc_->Release(b);
- }
-
- Current_ = &Empty_;
- BlockSize_ = Origin_;
+ return;
+ }
+
+ TBlock b = {c, c->BlockLength()};
+
+ c->~TChunk();
+ Alloc_->Release(b);
+ }
+
+ Current_ = &Empty_;
+ BlockSize_ = Origin_;
MemoryAllocatedBeforeCurrent_ = 0;
MemoryWasteBeforeCurrent_ = 0;
-}
+}