diff options
| author | 3gg <3gg@shellblade.net> | 2023-07-13 08:22:18 -0700 |
|---|---|---|
| committer | 3gg <3gg@shellblade.net> | 2023-07-13 08:22:18 -0700 |
| commit | 9f254f0c7b03236be615b1235cf3fc765d6000ea (patch) | |
| tree | f0b878ef2b431b909d9efd45c1f9ec8ed8ca54f8 /listpool/src | |
| parent | fc5886c75ab2626acbc0d7b3db475d17d2cbe01f (diff) | |
Add mem allocator, remove listpool.
Diffstat (limited to 'listpool/src')
| -rw-r--r-- | listpool/src/listpool.c | 92 |
1 files changed, 0 insertions, 92 deletions
diff --git a/listpool/src/listpool.c b/listpool/src/listpool.c deleted file mode 100644 index 758062c..0000000 --- a/listpool/src/listpool.c +++ /dev/null | |||
| @@ -1,92 +0,0 @@ | |||
| 1 | #include "listpool.h" | ||
| 2 | |||
| 3 | #include <string.h> | ||
| 4 | |||
| 5 | void listpool_make_( | ||
| 6 | listpool* pool, list* nodes, void* blocks, size_t num_blocks, | ||
| 7 | size_t block_size_bytes) { | ||
| 8 | assert(pool); | ||
| 9 | pool->block_size_bytes = block_size_bytes; | ||
| 10 | pool->num_blocks = num_blocks; | ||
| 11 | pool->free = &nodes[0]; | ||
| 12 | pool->used = 0; | ||
| 13 | pool->nodes = nodes; | ||
| 14 | pool->blocks = blocks; | ||
| 15 | list_make(nodes, num_blocks); | ||
| 16 | memset(blocks, 0, num_blocks * block_size_bytes); | ||
| 17 | } | ||
| 18 | |||
| 19 | void* listpool_alloc_(listpool* pool) { | ||
| 20 | assert(pool); | ||
| 21 | if (!pool->free) { | ||
| 22 | return 0; | ||
| 23 | } | ||
| 24 | |||
| 25 | const size_t index = pool->free - pool->nodes; | ||
| 26 | assert(index < pool->num_blocks); | ||
| 27 | |||
| 28 | list* free = pool->free; | ||
| 29 | pool->free = pool->free->next; | ||
| 30 | |||
| 31 | // pool->used is always the head of the used list, so prepend the new item to | ||
| 32 | // the list. | ||
| 33 | list* new_used = free; | ||
| 34 | new_used->prev = 0; | ||
| 35 | new_used->next = pool->used; | ||
| 36 | if (pool->used) { | ||
| 37 | pool->used->prev = new_used; | ||
| 38 | } | ||
| 39 | pool->used = new_used; | ||
| 40 | |||
| 41 | return pool->blocks + index * pool->block_size_bytes; | ||
| 42 | } | ||
| 43 | |||
| 44 | void listpool_free_(listpool* pool, void** block_ptr) { | ||
| 45 | assert(pool); | ||
| 46 | assert(block_ptr); | ||
| 47 | |||
| 48 | memset(*block_ptr, 0, pool->block_size_bytes); | ||
| 49 | |||
| 50 | const size_t index = | ||
| 51 | ((uint8_t*)*block_ptr - pool->blocks) / pool->block_size_bytes; | ||
| 52 | assert(index < pool->num_blocks); | ||
| 53 | |||
| 54 | list* item = &pool->nodes[index]; | ||
| 55 | |||
| 56 | // We must remove the item from the used list first. | ||
| 57 | if (item->prev) { | ||
| 58 | item->prev->next = item->next; | ||
| 59 | } | ||
| 60 | if (item->next) { | ||
| 61 | item->next->prev = item->prev; | ||
| 62 | } | ||
| 63 | if (item == pool->used) { | ||
| 64 | pool->used = item->next; | ||
| 65 | } | ||
| 66 | |||
| 67 | // pool->free is always the head of the free list, so prepend the new item to | ||
| 68 | // the list. The item is now free to wire after removing it from the used | ||
| 69 | // list. | ||
| 70 | if (!pool->free) { | ||
| 71 | pool->free = item; | ||
| 72 | } else { | ||
| 73 | item->next = pool->free; | ||
| 74 | pool->free->prev = item; | ||
| 75 | pool->free = item; | ||
| 76 | } | ||
| 77 | |||
| 78 | *block_ptr = 0; | ||
| 79 | } | ||
| 80 | |||
| 81 | void* listpool_get_block_(const listpool* pool, size_t block_index) { | ||
| 82 | assert(pool); | ||
| 83 | assert(block_index < pool->num_blocks); | ||
| 84 | return pool->blocks + block_index * pool->block_size_bytes; | ||
| 85 | } | ||
| 86 | |||
| 87 | size_t listpool_get_block_index_(const listpool* pool, const void* block) { | ||
| 88 | assert(pool); | ||
| 89 | const size_t block_byte_index = (const uint8_t*)block - pool->blocks; | ||
| 90 | assert(block_byte_index % pool->block_size_bytes == 0); | ||
| 91 | return block_byte_index / pool->block_size_bytes; | ||
| 92 | } | ||
