| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- #include "Memory.h"
- #include <memory>
- #include <stdint.h>
- #include <stdlib.h>
- namespace Rml {
- namespace Detail {
- inline void* rmlui_align(size_t alignment, size_t size, void*& ptr, size_t& space)
- {
- #if defined(_MSC_VER)
- return std::align(alignment, size, ptr, space);
- #else
- // std::align replacement to support compilers missing this feature.
- // From https://gcc.gnu.org/bugzilla/show_bug.cgi?id=57350
- uintptr_t pn = reinterpret_cast<uintptr_t>(ptr);
- uintptr_t aligned = (pn + alignment - 1) & -alignment;
- size_t padding = aligned - pn;
- if (space < size + padding)
- return nullptr;
- space -= padding;
- return ptr = reinterpret_cast<void*>(aligned);
- #endif
- }
- BasicStackAllocator::BasicStackAllocator(size_t N) : N(N), data((byte*)malloc(N)), p(data) {}
- BasicStackAllocator::~BasicStackAllocator() noexcept
- {
- RMLUI_ASSERT(p == data);
- free(data);
- }
- void* BasicStackAllocator::allocate(size_t alignment, size_t byte_size)
- {
- size_t available_space = N - ((byte*)p - data);
- if (rmlui_align(alignment, byte_size, p, available_space))
- {
- void* result = p;
- p = (byte*)p + byte_size;
- return result;
- }
- // Fall back to malloc
- return malloc(byte_size);
- }
- void BasicStackAllocator::deallocate(void* obj) noexcept
- {
- if (obj < data || obj >= data + N)
- {
- free(obj);
- return;
- }
- p = obj;
- }
- BasicStackAllocator& GetGlobalBasicStackAllocator()
- {
- static BasicStackAllocator stack_allocator(10 * 1024);
- return stack_allocator;
- }
- } // namespace Detail
- } // namespace Rml
|