The memory block allocation routines provide a simple yet powerful set of functions for managing a set of memory blocks of fixed size. More...
Files | |
file | memb.c |
Memory block allocation routines. | |
file | memb.h |
Memory block allocation routines. | |
Defines | |
#define | MEMB(name, structure, num) |
Declare a memory block. | |
Functions | |
void | memb_init (struct memb *m) |
Initialize a memory block that was declared with MEMB(). | |
void * | memb_alloc (struct memb *m) |
Allocate a memory block from a block of memory declared with MEMB(). | |
char | memb_free (struct memb *m, void *ptr) |
Deallocate a memory block from a memory block previously declared with MEMB(). |
The memory block allocation routines provide a simple yet powerful set of functions for managing a set of memory blocks of fixed size.
A set of memory blocks is statically declared with the MEMB() macro. Memory blocks are allocated from the declared memory by the memb_alloc() function, and are deallocated with the memb_free() function.
#define MEMB | ( | name, | |||
structure, | |||||
num | ) |
static char CC_CONCAT(name,_memb_count)[num]; \ static structure CC_CONCAT(name,_memb_mem)[num]; \ static struct memb name = {sizeof(structure), num, \ CC_CONCAT(name,_memb_count), \ (void *)CC_CONCAT(name,_memb_mem)}
Declare a memory block.
This macro is used to statically declare a block of memory that can be used by the block allocation functions. The macro statically declares a C array with a size that matches the specified number of blocks and their individual sizes.
Example:
MEMB(connections, struct connection, 16);
name | The name of the memory block (later used with memb_init(), memb_alloc() and memb_free()). | |
structure | The name of the struct that the memory block holds | |
num | The total number of memory chunks in the block. |
void * memb_alloc | ( | struct memb * | m | ) |
Allocate a memory block from a block of memory declared with MEMB().
m | A memory block previously declared with MEMB(). |
char memb_free | ( | struct memb * | m, | |
void * | ptr | |||
) |
Deallocate a memory block from a memory block previously declared with MEMB().
m | m A memory block previously declared with MEMB(). | |
ptr | A pointer to the memory block that is to be deallocated. |
void memb_init | ( | struct memb * | m | ) |
Initialize a memory block that was declared with MEMB().
m | A memory block previously declared with MEMB(). |