From 5b3da5c94f0e3a1de2c529f7d7cc560c0134c663 Mon Sep 17 00:00:00 2001 From: En Yi Date: Fri, 30 Dec 2022 17:51:05 +0800 Subject: [PATCH] Improve and fix up mempool Changelog: - Fix incorrect queue size init in mempool - Replace map with boolean array for use list which is much simpler - Remove unused component mempool --- mempool.c | 47 ++++++++++++++++++++++------------------------- 1 file changed, 22 insertions(+), 25 deletions(-) diff --git a/mempool.c b/mempool.c index f440dfa..0c747f2 100644 --- a/mempool.c +++ b/mempool.c @@ -1,12 +1,11 @@ #include "mempool.h" #include "sc/queue/sc_queue.h" -#include "sc/map/sc_map.h" +#include // Static allocate buffers static Entity_t entity_buffer[MAX_COMP_POOL_SIZE]; static CBBox_t bbox_buffer[MAX_COMP_POOL_SIZE]; static CTransform_t ctransform_buffer[MAX_COMP_POOL_SIZE]; -//static CTileCoord_t ctilecoord_buffer[MAX_COMP_POOL_SIZE]; static CJump_t cjump_buffer[1]; // Only player is expected to have this static CPlayerState_t cplayerstate_buffer[1]; // Only player is expected to have this @@ -21,20 +20,19 @@ typedef struct MemPool void * const buffer; const unsigned long max_size; const unsigned long elem_size; - struct sc_map_64 use_list; + bool *use_list; struct sc_queue_uint free_list; }MemPool_t; // Static allocate mempools static MemPool_t comp_mempools[N_COMPONENTS] = { - {bbox_buffer, MAX_COMP_POOL_SIZE, sizeof(CBBox_t), {0}, {0}}, - {ctransform_buffer, MAX_COMP_POOL_SIZE, sizeof(CTransform_t), {0}, {0}}, - //{ctilecoord_buffer, MAX_COMP_POOL_SIZE, sizeof(CTileCoord_t), {0}, {0}}, - {cjump_buffer, 1, sizeof(CJump_t), {0}, {0}}, - {cplayerstate_buffer, 1, sizeof(CPlayerState_t), {0}, {0}}, + {bbox_buffer, MAX_COMP_POOL_SIZE, sizeof(CBBox_t), NULL, {0}}, + {ctransform_buffer, MAX_COMP_POOL_SIZE, sizeof(CTransform_t), NULL, {0}}, + {cjump_buffer, 1, sizeof(CJump_t), NULL, {0}}, + {cplayerstate_buffer, 1, sizeof(CPlayerState_t), NULL, {0}}, }; -static MemPool_t ent_mempool = {entity_buffer, MAX_COMP_POOL_SIZE, sizeof(Entity_t), {0}, {0}}; +static MemPool_t ent_mempool = {entity_buffer, MAX_COMP_POOL_SIZE, sizeof(Entity_t), NULL, {0}}; static bool pool_inited = false; void init_memory_pools(void) @@ -44,9 +42,10 @@ void init_memory_pools(void) for (size_t i=0; icomponents); ent->m_alive = true; @@ -100,16 +99,15 @@ Entity_t* new_entity_from_mempool(unsigned long *p_e_idx) Entity_t * get_entity_wtih_id(unsigned long idx) { - sc_map_get_64(&ent_mempool.use_list, idx); - if (!sc_map_found(&ent_mempool.use_list)) return NULL; + if (!ent_mempool.use_list[idx]) return NULL; return entity_buffer + idx; } void free_entity_to_mempool(unsigned long idx) { - sc_map_del_64(&ent_mempool.use_list, idx); - if (sc_map_found(&ent_mempool.use_list)) + if (ent_mempool.use_list[idx]) { + ent_mempool.use_list[idx] = false; sc_queue_add_first(&ent_mempool.free_list, idx); } } @@ -121,7 +119,7 @@ void* new_component_from_mempool(ComponentEnum_t comp_type, unsigned long *idx) if(!sc_queue_empty(&comp_mempools[comp_type].free_list)) { *idx = sc_queue_del_first(&comp_mempools[comp_type].free_list); - sc_map_put_64(&comp_mempools[comp_type].use_list, *idx, *idx); + comp_mempools[comp_type].use_list[*idx] = true; comp = comp_mempools[comp_type].buffer + (*idx * comp_mempools[comp_type].elem_size); memset(comp, 0, comp_mempools[comp_type].elem_size); } @@ -132,8 +130,7 @@ void* get_component_wtih_id(ComponentEnum_t comp_type, unsigned long idx) { void * comp = NULL; assert(comp_type < N_COMPONENTS); - sc_map_get_64(&comp_mempools[comp_type].use_list, idx); - if (sc_map_found(&comp_mempools[comp_type].use_list)) + if (comp_mempools[comp_type].use_list[idx]) { comp = comp_mempools[comp_type].buffer + (idx * comp_mempools[comp_type].elem_size); } @@ -144,9 +141,9 @@ void free_component_to_mempool(ComponentEnum_t comp_type, unsigned long idx) { assert(comp_type < N_COMPONENTS); // This just free the component from the memory pool - sc_map_del_64(&comp_mempools[comp_type].use_list, idx); - if (sc_map_found(&comp_mempools[comp_type].use_list)) + if (comp_mempools[comp_type].use_list[idx]) { + comp_mempools[comp_type].use_list[idx] = false; sc_queue_add_first(&comp_mempools[comp_type].free_list, idx); } }