diff options
| author | Yong He <yonghe@outlook.com> | 2018-02-20 23:55:51 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-02-20 23:55:51 -0500 |
| commit | 01c4134d33cea3a4f98fad9248584278fd4bc452 (patch) | |
| tree | 8ca6b0f7e844fbf56cb1991284aff3ebbcc8aa89 /source/slang/memory_pool.cpp | |
| parent | 51cdcad24b5271ac8c0f816174c6a760e264ed9e (diff) | |
| parent | 4cf46e5c8b2af8a4ea4db15cd402aae4145a614c (diff) | |
Merge pull request #417 from csyonghe/leakfix
Fix IR memory leaks.
Diffstat (limited to 'source/slang/memory_pool.cpp')
| -rw-r--r-- | source/slang/memory_pool.cpp | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/source/slang/memory_pool.cpp b/source/slang/memory_pool.cpp new file mode 100644 index 000000000..884c9cfe4 --- /dev/null +++ b/source/slang/memory_pool.cpp @@ -0,0 +1,52 @@ +#include "memory_pool.h" + +namespace Slang +{ + const size_t kPoolSegmentSize = 4 << 20; // use 4MB segments + + struct MemoryPoolSegment + { + unsigned char* data = nullptr; + size_t allocPtr = 0; + MemoryPoolSegment* nextSegment = nullptr; + }; + + MemoryPool::~MemoryPool() + { + while (curSegment) + { + auto nxtSegment = curSegment->nextSegment; + free(curSegment->data); + delete curSegment; + curSegment = nxtSegment; + } + } + + void newSegment(MemoryPool* pool) + { + auto seg = new MemoryPoolSegment(); + seg->nextSegment = pool->curSegment; + seg->data = (unsigned char*)malloc(kPoolSegmentSize); + pool->curSegment = seg; + } + + void * MemoryPool::alloc(size_t size) + { + assert(size < kPoolSegmentSize); + // ensure there is a segment available + if (!curSegment) + newSegment(this); + if (curSegment->allocPtr + size > kPoolSegmentSize) + newSegment(this); + // alloc memory from current segment + void* rs = curSegment->data + curSegment->allocPtr; + curSegment->allocPtr += size; + return rs; + } + void * MemoryPool::allocZero(size_t size) + { + auto rs = alloc(size); + memset(rs, 0, size); + return rs; + } +} |
