Limit the size of cListAllocationPool's free list
This commit is contained in:
parent
6c3dd41717
commit
7d512f2191
@ -11,18 +11,18 @@ class cAllocationPool
|
|||||||
public:
|
public:
|
||||||
class cStarvationCallbacks
|
class cStarvationCallbacks
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual ~cStarvationCallbacks() {}
|
virtual ~cStarvationCallbacks() {}
|
||||||
|
|
||||||
/** Is called when the reserve buffer starts to be used */
|
/** Is called when the reserve buffer starts to be used */
|
||||||
virtual void OnStartUsingReserve() = 0;
|
virtual void OnStartUsingReserve() = 0;
|
||||||
|
|
||||||
/** Is called once the reserve buffer has returned to normal size */
|
/** Is called once the reserve buffer has returned to normal size */
|
||||||
virtual void OnEndUsingReserve() = 0;
|
virtual void OnEndUsingReserve() = 0;
|
||||||
|
|
||||||
/** Is called when the allocation pool is unable to allocate memory. Will be repeatedly
|
/** Is called when the allocation pool is unable to allocate memory. Will be repeatedly
|
||||||
called if it does not free sufficient memory */
|
called if it does not free sufficient memory */
|
||||||
virtual void OnOutOfReserve() = 0;
|
virtual void OnOutOfReserve() = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
virtual ~cAllocationPool() {}
|
virtual ~cAllocationPool() {}
|
||||||
@ -65,11 +65,12 @@ class cListAllocationPool:
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
cListAllocationPool(std::unique_ptr<typename cAllocationPool<T>::cStarvationCallbacks> a_Callbacks, size_t a_NumElementsInReserve):
|
cListAllocationPool(std::unique_ptr<typename cAllocationPool<T>::cStarvationCallbacks> a_Callbacks, size_t a_MinElementsInReserve, size_t a_MaxElementsInReserve) :
|
||||||
m_NumElementsInReserve(a_NumElementsInReserve),
|
m_MinElementsInReserve(a_MinElementsInReserve),
|
||||||
|
m_MaxElementsInReserve(a_MaxElementsInReserve),
|
||||||
m_Callbacks(std::move(a_Callbacks))
|
m_Callbacks(std::move(a_Callbacks))
|
||||||
{
|
{
|
||||||
for (size_t i = 0; i < m_NumElementsInReserve; i++)
|
for (size_t i = 0; i < m_MinElementsInReserve; i++)
|
||||||
{
|
{
|
||||||
void * space = malloc(sizeof(T));
|
void * space = malloc(sizeof(T));
|
||||||
if (space == nullptr)
|
if (space == nullptr)
|
||||||
@ -86,7 +87,7 @@ public:
|
|||||||
{
|
{
|
||||||
while (!m_FreeList.empty())
|
while (!m_FreeList.empty())
|
||||||
{
|
{
|
||||||
free (m_FreeList.front());
|
free(m_FreeList.front());
|
||||||
m_FreeList.pop_front();
|
m_FreeList.pop_front();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -94,7 +95,7 @@ public:
|
|||||||
|
|
||||||
virtual T * Allocate() override
|
virtual T * Allocate() override
|
||||||
{
|
{
|
||||||
if (m_FreeList.size() <= m_NumElementsInReserve)
|
if (m_FreeList.size() <= m_MinElementsInReserve)
|
||||||
{
|
{
|
||||||
void * space = malloc(sizeof(T));
|
void * space = malloc(sizeof(T));
|
||||||
if (space != nullptr)
|
if (space != nullptr)
|
||||||
@ -113,7 +114,7 @@ public:
|
|||||||
#pragma pop_macro("new")
|
#pragma pop_macro("new")
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
else if (m_FreeList.size() == m_NumElementsInReserve)
|
else if (m_FreeList.size() == m_MinElementsInReserve)
|
||||||
{
|
{
|
||||||
m_Callbacks->OnStartUsingReserve();
|
m_Callbacks->OnStartUsingReserve();
|
||||||
}
|
}
|
||||||
@ -151,10 +152,17 @@ public:
|
|||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// placement destruct.
|
|
||||||
a_ptr->~T();
|
a_ptr->~T(); // placement destruct.
|
||||||
|
|
||||||
|
if (m_FreeList.size() >= m_MaxElementsInReserve)
|
||||||
|
{
|
||||||
|
free(a_ptr);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
m_FreeList.push_front(a_ptr);
|
m_FreeList.push_front(a_ptr);
|
||||||
if (m_FreeList.size() == m_NumElementsInReserve)
|
if (m_FreeList.size() == m_MinElementsInReserve)
|
||||||
{
|
{
|
||||||
m_Callbacks->OnEndUsingReserve();
|
m_Callbacks->OnEndUsingReserve();
|
||||||
}
|
}
|
||||||
@ -162,7 +170,9 @@ public:
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
/** The minimum number of elements to keep in the free list before malloc fails */
|
/** The minimum number of elements to keep in the free list before malloc fails */
|
||||||
size_t m_NumElementsInReserve;
|
size_t m_MinElementsInReserve;
|
||||||
|
/** Maximum free list size before returning memory to the OS */
|
||||||
|
size_t m_MaxElementsInReserve;
|
||||||
std::list<void *> m_FreeList;
|
std::list<void *> m_FreeList;
|
||||||
std::unique_ptr<typename cAllocationPool<T>::cStarvationCallbacks> m_Callbacks;
|
std::unique_ptr<typename cAllocationPool<T>::cStarvationCallbacks> m_Callbacks;
|
||||||
|
|
||||||
|
@ -115,7 +115,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
cChunkDataCopyCollector():
|
cChunkDataCopyCollector():
|
||||||
m_Pool(cpp14::make_unique<MemCallbacks>(), cChunkData::NumSections), // Keep 1 chunk worth of reserve
|
m_Pool(cpp14::make_unique<MemCallbacks>(), 0, cChunkData::NumSections), // Keep 1 chunk worth of reserve
|
||||||
m_Data(m_Pool)
|
m_Data(m_Pool)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ cChunkMap::cChunkMap(cWorld * a_World) :
|
|||||||
m_World(a_World),
|
m_World(a_World),
|
||||||
m_Pool(
|
m_Pool(
|
||||||
cpp14::make_unique<cListAllocationPool<cChunkData::sChunkSection>>(
|
cpp14::make_unique<cListAllocationPool<cChunkData::sChunkSection>>(
|
||||||
cpp14::make_unique<cStarvationCallbacks>(), 1600u
|
cpp14::make_unique<cStarvationCallbacks>(), 1600u, 5000u
|
||||||
)
|
)
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
@ -26,7 +26,7 @@ struct sMemCallbacks:
|
|||||||
cSetChunkData::cSetChunkData(int a_ChunkX, int a_ChunkZ, bool a_ShouldMarkDirty) :
|
cSetChunkData::cSetChunkData(int a_ChunkX, int a_ChunkZ, bool a_ShouldMarkDirty) :
|
||||||
m_ChunkX(a_ChunkX),
|
m_ChunkX(a_ChunkX),
|
||||||
m_ChunkZ(a_ChunkZ),
|
m_ChunkZ(a_ChunkZ),
|
||||||
m_Pool(cpp14::make_unique<sMemCallbacks>(), cChunkData::NumSections),
|
m_Pool(cpp14::make_unique<sMemCallbacks>(), 0u, cChunkData::NumSections),
|
||||||
m_ChunkData(m_Pool),
|
m_ChunkData(m_Pool),
|
||||||
m_IsLightValid(false),
|
m_IsLightValid(false),
|
||||||
m_IsHeightMapValid(false),
|
m_IsHeightMapValid(false),
|
||||||
|
Loading…
Reference in New Issue
Block a user