2018-04-12 02:37:55 +08:00
|
|
|
#ifndef MEM_POOL_H
|
|
|
|
#define MEM_POOL_H
|
|
|
|
|
|
|
|
struct mp_block {
|
|
|
|
struct mp_block *next_block;
|
|
|
|
char *next_free;
|
|
|
|
char *end;
|
|
|
|
uintmax_t space[FLEX_ARRAY]; /* more */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct mem_pool {
|
|
|
|
struct mp_block *mp_block;
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The amount of available memory to grow the pool by.
|
|
|
|
* This size does not include the overhead for the mp_block.
|
|
|
|
*/
|
|
|
|
size_t block_alloc;
|
|
|
|
|
|
|
|
/* The total amount of memory allocated by the pool. */
|
|
|
|
size_t pool_alloc;
|
|
|
|
};
|
|
|
|
|
2018-07-03 03:49:34 +08:00
|
|
|
/*
|
|
|
|
* Initialize mem_pool with specified initial size.
|
|
|
|
*/
|
|
|
|
void mem_pool_init(struct mem_pool **mem_pool, size_t initial_size);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Discard a memory pool and free all the memory it is responsible for.
|
|
|
|
*/
|
2018-07-03 03:49:39 +08:00
|
|
|
void mem_pool_discard(struct mem_pool *mem_pool, int invalidate_memory);
|
2018-07-03 03:49:34 +08:00
|
|
|
|
2018-04-12 02:37:55 +08:00
|
|
|
/*
|
|
|
|
* Alloc memory from the mem_pool.
|
|
|
|
*/
|
|
|
|
void *mem_pool_alloc(struct mem_pool *pool, size_t len);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Allocate and zero memory from the memory pool.
|
|
|
|
*/
|
|
|
|
void *mem_pool_calloc(struct mem_pool *pool, size_t count, size_t size);
|
|
|
|
|
2018-07-03 03:49:35 +08:00
|
|
|
/*
|
|
|
|
* Move the memory associated with the 'src' pool to the 'dst' pool. The 'src'
|
|
|
|
* pool will be empty and not contain any memory. It still needs to be free'd
|
|
|
|
* with a call to `mem_pool_discard`.
|
|
|
|
*/
|
|
|
|
void mem_pool_combine(struct mem_pool *dst, struct mem_pool *src);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Check if a memory pointed at by 'mem' is part of the range of
|
|
|
|
* memory managed by the specified mem_pool.
|
|
|
|
*/
|
|
|
|
int mem_pool_contains(struct mem_pool *mem_pool, void *mem);
|
|
|
|
|
2018-04-12 02:37:55 +08:00
|
|
|
#endif
|