2020-11-10 12:19:15 +00:00
|
|
|
#ifndef __KOLIBRI_HEAP_H_INCLUDED_
|
|
|
|
#define __KOLIBRI_HEAP_H_INCLUDED_
|
2011-01-28 13:00:06 +00:00
|
|
|
|
2020-11-02 18:44:51 +00:00
|
|
|
#include <kolibri.h>
|
2011-01-28 13:00:06 +00:00
|
|
|
#include <memheap.h>
|
|
|
|
|
2020-11-02 18:44:51 +00:00
|
|
|
// Kolibri memory heap interface.
|
2011-01-28 13:00:06 +00:00
|
|
|
|
2020-11-02 18:44:51 +00:00
|
|
|
namespace Kolibri // All kolibri functions, types and data are nested in the (Kolibri) namespace.
|
2011-01-28 13:00:06 +00:00
|
|
|
{
|
|
|
|
void *Alloc(unsigned int size);
|
|
|
|
void *ReAlloc(void *mem, unsigned int size);
|
|
|
|
void Free(void *mem);
|
|
|
|
}
|
|
|
|
|
2020-11-10 12:19:15 +00:00
|
|
|
#ifdef __KOLIBRI__
|
2011-01-28 13:00:06 +00:00
|
|
|
|
2020-11-02 18:44:51 +00:00
|
|
|
namespace Kolibri
|
2011-01-28 13:00:06 +00:00
|
|
|
{
|
|
|
|
|
|
|
|
// Global variables
|
|
|
|
|
2020-11-10 12:19:15 +00:00
|
|
|
MemoryHeap::TFreeSpace _KolibriFreeSpace;
|
|
|
|
MemoryHeap::TMemBlock _KolibriMemBlock;
|
|
|
|
TMutex _MemHeapMutex = KOLIBRI_MUTEX_INIT;
|
2011-01-28 13:00:06 +00:00
|
|
|
|
|
|
|
// Functions
|
|
|
|
|
|
|
|
void *_HeapInit(void *begin, void *use_end, void *end)
|
|
|
|
{
|
2020-11-10 12:19:15 +00:00
|
|
|
MemoryHeap::InitFreeSpace(_KolibriFreeSpace);
|
|
|
|
_KolibriMemBlock = MemoryHeap::CreateBlock(begin, end, _KolibriFreeSpace);
|
|
|
|
unsigned int use_beg = (unsigned int)MemoryHeap::BlockBegin(_KolibriMemBlock) +
|
2011-01-28 13:00:06 +00:00
|
|
|
MemoryHeap::BlockAddSize - MemoryHeap::BlockEndSize;
|
|
|
|
unsigned int use_size = (unsigned int)use_end;
|
|
|
|
if (use_size <= use_beg) return 0;
|
|
|
|
else use_size -= use_beg;
|
2020-11-10 12:19:15 +00:00
|
|
|
return MemoryHeap::Alloc(_KolibriFreeSpace, use_size);
|
2011-01-28 13:00:06 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
bool _SetUseMemory(unsigned int use_mem);
|
|
|
|
|
|
|
|
int _RecalculateUseMemory(unsigned int use_mem);
|
|
|
|
|
|
|
|
void *Alloc(unsigned int size)
|
|
|
|
{
|
|
|
|
if (!size) return 0;
|
|
|
|
Lock(&_MemHeapMutex);
|
2020-11-10 12:19:15 +00:00
|
|
|
void *res = MemoryHeap::Alloc(_KolibriFreeSpace, size);
|
2011-01-28 13:00:06 +00:00
|
|
|
if (!res)
|
|
|
|
{
|
2020-11-10 12:19:15 +00:00
|
|
|
unsigned use_mem = (unsigned int)MemoryHeap::BlockEndFor(_KolibriMemBlock, size);
|
2011-01-28 13:00:06 +00:00
|
|
|
if (_SetUseMemory(_RecalculateUseMemory(use_mem)))
|
|
|
|
{
|
2020-11-10 12:19:15 +00:00
|
|
|
res = MemoryHeap::Alloc(_KolibriFreeSpace, size);
|
2011-01-28 13:00:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
UnLock(&_MemHeapMutex);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
void *ReAlloc(void *mem, unsigned int size)
|
|
|
|
{
|
|
|
|
Lock(&_MemHeapMutex);
|
2020-11-10 12:19:15 +00:00
|
|
|
void *res = MemoryHeap::ReAlloc(_KolibriFreeSpace, mem, size);
|
2011-01-28 13:00:06 +00:00
|
|
|
if (!res && size)
|
|
|
|
{
|
2020-11-10 12:19:15 +00:00
|
|
|
unsigned use_mem = (unsigned int)MemoryHeap::BlockEndFor(_KolibriMemBlock, size);
|
2011-01-28 13:00:06 +00:00
|
|
|
if (_SetUseMemory(_RecalculateUseMemory(use_mem)))
|
|
|
|
{
|
2020-11-10 12:19:15 +00:00
|
|
|
res = MemoryHeap::ReAlloc(_KolibriFreeSpace, mem, size);
|
2011-01-28 13:00:06 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
UnLock(&_MemHeapMutex);
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
void Free(void *mem)
|
|
|
|
{
|
|
|
|
Lock(&_MemHeapMutex);
|
2020-11-10 12:19:15 +00:00
|
|
|
MemoryHeap::Free(_KolibriFreeSpace, mem);
|
2011-01-28 13:00:06 +00:00
|
|
|
UnLock(&_MemHeapMutex);
|
|
|
|
}
|
|
|
|
|
|
|
|
void _FreeAndThreadFinish(void *mem, int *exit_proc_now);
|
|
|
|
}
|
|
|
|
|
2020-11-10 12:19:15 +00:00
|
|
|
#endif // def __KOLIBRI__
|
2011-01-28 13:00:06 +00:00
|
|
|
|
2020-11-10 12:19:15 +00:00
|
|
|
#endif // ndef __KOLIBRI_HEAP_H_INCLUDED_
|