diff options
| author | nasr <nsrddyn@gmail.com> | 2026-03-07 22:58:48 +0000 |
|---|---|---|
| committer | nasr <nsrddyn@gmail.com> | 2026-03-07 22:58:48 +0000 |
| commit | 735e27c41863f9f9d40653d6403f26477be22706 (patch) | |
| tree | 45a1727f3a7a155d8fd30276f9e1d8a1ee9220ef /source | |
| parent | 2c9057b8f009bd39d97a2d30cf71135cb07c5e4b (diff) | |
refactor(base): split the arena allocator into a zero and non zero one
Diffstat (limited to 'source')
| -rwxr-xr-x | source/base/base_arena.c | 8 | ||||
| -rwxr-xr-x | source/base/base_arena.h | 6 |
2 files changed, 8 insertions, 6 deletions
diff --git a/source/base/base_arena.c b/source/base/base_arena.c index 3e9a6df..5855e5e 100755 --- a/source/base/base_arena.c +++ b/source/base/base_arena.c | |||
| @@ -33,7 +33,7 @@ arena_destroy(mem_arena *arena) | |||
| 33 | munmap(arena, arena->capacity + sizeof(mem_arena)); | 33 | munmap(arena, arena->capacity + sizeof(mem_arena)); |
| 34 | } | 34 | } |
| 35 | internal void * | 35 | internal void * |
| 36 | arena_alloc(mem_arena *arena, u64 size) | 36 | arena_alloc(mem_arena *arena, u64 size, b32 zero) |
| 37 | { | 37 | { |
| 38 | if (!arena) | 38 | if (!arena) |
| 39 | { | 39 | { |
| @@ -51,7 +51,7 @@ arena_alloc(mem_arena *arena, u64 size) | |||
| 51 | arena->previous_position = arena->current_position; | 51 | arena->previous_position = arena->current_position; |
| 52 | arena->current_position = aligned + size; | 52 | arena->current_position = aligned + size; |
| 53 | 53 | ||
| 54 | MemSet(out, size); | 54 | if (zero) MemSet(out, size); |
| 55 | 55 | ||
| 56 | return out; | 56 | return out; |
| 57 | } | 57 | } |
| @@ -88,7 +88,7 @@ arena_resize_align(mem_arena *arena, void *old_memory, u64 new_size, u64 old_siz | |||
| 88 | 88 | ||
| 89 | if (old_memory == NULL || old_size == 0) | 89 | if (old_memory == NULL || old_size == 0) |
| 90 | { | 90 | { |
| 91 | return (mem_arena *)arena_alloc(arena, new_size); | 91 | return (mem_arena *)arena_alloc(arena, new_size, 0); |
| 92 | } | 92 | } |
| 93 | else if ((old_mem >= arena->base_position && old_mem < arena->base_position + arena->capacity)) | 93 | else if ((old_mem >= arena->base_position && old_mem < arena->base_position + arena->capacity)) |
| 94 | { | 94 | { |
| @@ -103,7 +103,7 @@ arena_resize_align(mem_arena *arena, void *old_memory, u64 new_size, u64 old_siz | |||
| 103 | } | 103 | } |
| 104 | else | 104 | else |
| 105 | { | 105 | { |
| 106 | void *new_memory = arena_alloc(arena, new_size); | 106 | void *new_memory = arena_alloc(arena, new_size, 0); |
| 107 | umm copy_size = old_size < new_size ? old_size : new_size; | 107 | umm copy_size = old_size < new_size ? old_size : new_size; |
| 108 | memmove(new_memory, old_mem, copy_size); | 108 | memmove(new_memory, old_mem, copy_size); |
| 109 | } | 109 | } |
diff --git a/source/base/base_arena.h b/source/base/base_arena.h index fe71c24..2818ae4 100755 --- a/source/base/base_arena.h +++ b/source/base/base_arena.h | |||
| @@ -2,8 +2,10 @@ | |||
| 2 | #define BASE_ARENA_H | 2 | #define BASE_ARENA_H |
| 3 | 3 | ||
| 4 | #define Align(pointer, alignment) align((u64)(pointer), (umm)(alignment)) | 4 | #define Align(pointer, alignment) align((u64)(pointer), (umm)(alignment)) |
| 5 | #define PushStruct(arena, type) (type *)arena_alloc((arena), sizeof(type)) | 5 | #define PushStruct(arena, type) (type *)arena_alloc((arena), sizeof(type), 0) |
| 6 | #define PushArray(arena, type, len) (type *)arena_alloc((arena), sizeof(type) * (len)) | 6 | #define PushStructZero(arena, type) (type *)arena_alloc((arena), sizeof(type), 1) |
| 7 | #define PushArray(arena, type, len) (type *)arena_alloc((arena), sizeof(type) * (len), 0) | ||
| 8 | #define PushArrayZero(arena, type, len) (type *)arena_alloc((arena), sizeof(type) * (len), 1) | ||
| 7 | 9 | ||
| 8 | typedef struct mem_arena mem_arena; | 10 | typedef struct mem_arena mem_arena; |
| 9 | struct mem_arena | 11 | struct mem_arena |
