diff options
Diffstat (limited to 'src/mem_pool.h')
-rw-r--r-- | src/mem_pool.h | 179 |
1 files changed, 151 insertions, 28 deletions
diff --git a/src/mem_pool.h b/src/mem_pool.h index cd1af2e77..79f029bf3 100644 --- a/src/mem_pool.h +++ b/src/mem_pool.h @@ -4,15 +4,32 @@ #include <sys/types.h> #include <glib.h> +/** + * \brief Memory pools library. + * + * Memory pools library. Library is designed to implement efficient way to + * store data in memory avoiding calling of many malloc/free. It has overhead + * because of fact that objects live in pool for rather long time and are not freed + * immediately after use, but if we know certainly when these objects can be used, we + * can use pool for them + */ + +/** Destructor type definition */ typedef void (*pool_destruct_func)(void *ptr); +/** + * Pool page structure + */ struct _pool_chain { - u_char *begin; - u_char *pos; - size_t len; - struct _pool_chain *next; + u_char *begin; /** < begin of pool chain block */ + u_char *pos; /** < current start of free space in block */ + size_t len; /** < length of block */ + struct _pool_chain *next; /** < chain link */ }; +/** + * Shared pool page + */ struct _pool_chain_shared { u_char *begin; u_char *pos; @@ -21,69 +38,175 @@ struct _pool_chain_shared { struct _pool_chain_shared *next; }; +/** + * Destructors list item structure + */ struct _pool_destructors { - pool_destruct_func func; - void *data; - struct _pool_destructors *prev; + pool_destruct_func func; /** < pointer to destructor */ + void *data; /** < data to free */ + struct _pool_destructors *prev; /** < chain link */ }; +/** + * Memory pool type + */ typedef struct memory_pool_s { - struct _pool_chain *cur_pool; - struct _pool_chain *first_pool; - struct _pool_chain_shared *shared_pool; - struct _pool_destructors *destructors; + struct _pool_chain *cur_pool; /** < currently used page */ + struct _pool_chain *first_pool; /** < first page */ + struct _pool_chain_shared *shared_pool; /** < shared chain */ + struct _pool_destructors *destructors; /** < destructors chain */ } memory_pool_t; +/** + * Statistics structure + */ typedef struct memory_pool_stat_s { - size_t bytes_allocated; - size_t chunks_allocated; - size_t shared_chunks_allocated; - size_t chunks_freed; + size_t bytes_allocated; /** < bytes that are allocated with pool allocator */ + size_t chunks_allocated; /** < number of chunks that are allocated */ + size_t shared_chunks_allocated; /** < shared chunks allocated */ + size_t chunks_freed; /** < chunks freed */ } memory_pool_stat_t; +/** + * Rwlock for locking shared memory regions + */ typedef struct memory_pool_rwlock_s { - gint *__r_lock; - gint *__w_lock; + gint *__r_lock; /** < read mutex (private) */ + gint *__w_lock; /** < write mutex (private) */ } memory_pool_rwlock_t; -/* Allocate new memory poll */ +/** + * Allocate new memory poll + * @param size size of pool's page + * @return new memory pool object + */ memory_pool_t* memory_pool_new (size_t size); -/* Get memory from pool */ +/** + * Get memory from pool + * @param pool memory pool object + * @param size bytes to allocate + * @return pointer to allocated object + */ void* memory_pool_alloc (memory_pool_t* pool, size_t size); -/* Get memory and set it to zero */ + +/** + * Get memory and set it to zero + * @param pool memory pool object + * @param size bytes to allocate + * @return pointer to allocated object + */ void* memory_pool_alloc0 (memory_pool_t* pool, size_t size); -/* Make a copy of string in pool */ + +/** + * Make a copy of string in pool + * @param pool memory pool object + * @param src source string + * @return pointer to newly created string that is copy of src + */ char* memory_pool_strdup (memory_pool_t* pool, const char *src); -/* Allocate piece of shared memory */ +/** + * Allocate piece of shared memory + * @param pool memory pool object + * @param size bytes to allocate + */ void* memory_pool_alloc_shared (memory_pool_t *pool, size_t size); -/* Lock and unlock chunk of shared memory in which pointer is placed */ + +/** + * Lock chunk of shared memory in which pointer is placed + * @param pool memory pool object + * @param pointer pointer of shared memory object that is to be locked (the whole page that contains that object is locked) + */ void memory_pool_lock_shared (memory_pool_t *pool, void *pointer); + +/** + * Unlock chunk of shared memory in which pointer is placed + * @param pool memory pool object + * @param pointer pointer of shared memory object that is to be unlocked (the whole page that contains that object is locked) + */ void memory_pool_unlock_shared (memory_pool_t *pool, void *pointer); -/* Add destructor callback to pool */ +/** + * Add destructor callback to pool + * @param pool memory pool object + * @param func pointer to function-destructor + * @param data pointer to data that would be passed to destructor + */ void memory_pool_add_destructor (memory_pool_t *pool, pool_destruct_func func, void *data); -/* Delete pool, free all its chunks and call destructors chain */ + +/** + * Delete pool, free all its chunks and call destructors chain + * @param pool memory pool object + */ void memory_pool_delete (memory_pool_t *pool); -/* Mutexes operations */ +/** + * Get new mutex from pool (allocated in shared memory) + * @param pool memory pool object + * @return mutex object + */ gint* memory_pool_get_mutex (memory_pool_t *pool); + +/** + * Lock mutex + * @param mutex mutex to lock + */ void memory_pool_lock_mutex (gint *mutex); + +/** + * Unlock mutex + * @param mutex mutex to unlock + */ void memory_pool_unlock_mutex (gint *mutex); -/* Simple rwlock implementation */ +/** + * Create new rwlock and place it in shared memory + * @param pool memory pool object + * @return rwlock object + */ memory_pool_rwlock_t* memory_pool_get_rwlock (memory_pool_t *pool); + +/** + * Aquire read lock + * @param lock rwlock object + */ void memory_pool_rlock_rwlock (memory_pool_rwlock_t *lock); + +/** + * Aquire write lock + * @param lock rwlock object + */ void memory_pool_wlock_rwlock (memory_pool_rwlock_t *lock); + +/** + * Release read lock + * @param lock rwlock object + */ void memory_pool_runlock_rwlock (memory_pool_rwlock_t *lock); + +/** + * Release write lock + * @param lock rwlock object + */ void memory_pool_wunlock_rwlock (memory_pool_rwlock_t *lock); +/** + * Get pool allocator statistics + * @param st stat pool struct + */ void memory_pool_stat (memory_pool_stat_t *st); -/* Get optimal pool size based on page size for this system */ +/** + * Get optimal pool size based on page size for this system + * @return size of memory page in system + */ size_t memory_pool_get_size (); +/** + * Macro that return free space in pool page + * @param x pool page struct + */ #define memory_pool_free(x) ((x)->len - ((x)->pos - (x)->begin)) #endif |