From c8a7755461d5e806bd734b75f441ac61c9963ee9 Mon Sep 17 00:00:00 2001 From: Alon Zakai Date: Fri, 22 Apr 2016 20:06:46 -0700 Subject: refactor arena to allow allocating space directly --- src/mixed_arena.h | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) (limited to 'src') diff --git a/src/mixed_arena.h b/src/mixed_arena.h index 16183286b..3258a2d31 100644 --- a/src/mixed_arena.h +++ b/src/mixed_arena.h @@ -73,8 +73,7 @@ struct MixedArena { next = nullptr; } - template - T* alloc() { + void* allocSpace(size_t size) { // the bump allocator data should not be modified by multiple threads at once. if (std::this_thread::get_id() != threadId) { // TODO use a fast double-checked locking pattern. @@ -87,17 +86,23 @@ struct MixedArena { curr->next = new MixedArena(); // will have our thread id } } - return curr->alloc(); + return curr->allocSpace(size); } const size_t CHUNK = 10000; - size_t currSize = (sizeof(T) + 7) & (-8); // same alignment as malloc TODO optimize? - assert(currSize < CHUNK); - if (chunks.size() == 0 || index + currSize >= CHUNK) { + size = (size + 7) & (-8); // same alignment as malloc TODO optimize? + assert(size < CHUNK); + if (chunks.size() == 0 || index + size >= CHUNK) { chunks.push_back(new char[CHUNK]); index = 0; } - T* ret = (T*)(chunks.back() + index); - index += currSize; + auto* ret = chunks.back() + index; + index += size; + return static_cast(ret); + } + + template + T* alloc() { + auto* ret = static_cast(allocSpace(sizeof(T))); new (ret) T(); return ret; } -- cgit v1.2.3