diff options
Diffstat (limited to 'memory/test.cpp')
-rw-r--r-- | memory/test.cpp | 230 |
1 files changed, 115 insertions, 115 deletions
diff --git a/memory/test.cpp b/memory/test.cpp index 4d17abd..97c0f25 100644 --- a/memory/test.cpp +++ b/memory/test.cpp @@ -1,29 +1,29 @@ #include <stdlib.h> #include <stdio.h> -#include "memory.cpp" +#include "memory.c" // ================ ARENA ================ // -void test_arena_init(unsigned char *buffer, U32 buffer_size) +void test_arena_init(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); - assert((a.buffer == buffer) && "arena does not start at the buffer"); - assert((a.curr_offset == 0) && (a.prev_offset == 0) && "arena offsets not initialised properly"); - assert((a.capacity == buffer_size) && "arena capacity does not match buffer size"); + assert((a.buffer == buffer) && "Arena does not start at the buffer"); + assert((a.curr_offset == 0) && (a.prev_offset == 0) && "Arena offsets not initialised properly"); + assert((a.capacity == buffer_size) && "Arena capacity does not match buffer size"); } -void test_arena_alloc(unsigned char *buffer, U32 buffer_size) +void test_arena_alloc(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 8); assert((qres != NULL) && "Arena Allocation Test Failed: " "Reason: Failed to allocate memory"); } -void test_arena_alloc_low_memory(unsigned char *buffer, U32 buffer_size) +void test_arena_alloc_low_memory(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, buffer_size + 20); assert((qres == NULL) && "Low Memory Arena Allocation Test Failed: " @@ -31,12 +31,12 @@ void test_arena_alloc_low_memory(unsigned char *buffer, U32 buffer_size) qres = arena_alloc(&a, 20); } -void test_arena_alloc_negative_size(unsigned char *buffer, U32 buffer_size) +void test_arena_alloc_negative_size(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 16); - U8* n1 = (U8*)qres; + u8* n1 = (u8*)qres; qres = arena_alloc(&a, -16); @@ -44,93 +44,93 @@ void test_arena_alloc_negative_size(unsigned char *buffer, U32 buffer_size) "Reason: Should have allocated the remaining buffer. \n"); } -void test_arena_resize(unsigned char *buffer, U32 buffer_size) +void test_arena_resize(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 8); - U8* n1 = (U8*)qres; + u8* n1 = (u8*)qres; *n1 = 23; qres = arena_alloc(&a, 8); - U8* n2 = (U8*)qres; + u8* n2 = (u8*)qres; *n2 = 20; qres = arena_resize(&a, n1, 8, 16); assert((qres != NULL) && "Arena Resize Test Failed: " "Reason: Failed to resize previously allocated memory\n" "this should not have happened since we do not have anything causing availability issues\n"); - U8* n1_1 = (U8*)qres; + u8* n1_1 = (u8*)qres; assert((*n1 == *n1_1) && "Arena Resize Test Failed: " "Reason: Value of resized memory changed. This should not happen in any case!\n"); } -void test_arena_resize_tail(unsigned char *buffer, U32 buffer_size) +void test_arena_resize_tail(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 16); - U8* n1 = (U8*)qres; + u8* n1 = (u8*)qres; *n1 = 23; qres = arena_alloc(&a, 16); - U8* n2 = (U8*)qres; + u8* n2 = (u8*)qres; *n2 = 20; qres = arena_resize(&a, n2, 16, 8); /*assert((qres.bytes_count == 8) && "Arena Resize Tail Test Failed: " "Reason: Failed to resize previously allocated memory at tail\n");*/ - U8* n2_1 = (U8*)qres; + u8* n2_1 = (u8*)qres; assert((*n2 == *n2_1) && "Arena Resize Test Failed: " "Reason: Value of resized memory changed. This should not happen in any case!\n"); } -void test_arena_resize_filled_completely(unsigned char *buffer, U32 buffer_size) +void test_arena_resize_filled_completely(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 8); - U8* n1 = (U8*)qres; + u8* n1 = (u8*)qres; *n1 = 23; qres = arena_alloc(&a, 8); - U8* n2 = (U8*)qres; + u8* n2 = (u8*)qres; *n2 = 20; qres = arena_resize(&a, n1, 8, buffer_size - 32); assert((qres != NULL) && "Arena Resize Filled Completely Failed: \n" - "Reason: Failed to resize an element even though it perfectly fills the memory arena"); + "Reason: Failed to resize an element even though it perfectly fills the memory Arena"); } -void test_arena_resize_out_of_bounds(unsigned char *buffer, U32 buffer_size) +void test_arena_resize_out_of_bounds(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 8); - U8* n1 = (U8*)qres; + u8* n1 = (u8*)qres; *n1 = 23; qres = arena_alloc(&a, 8); - U8* n2 = (U8*)qres; + u8* n2 = (u8*)qres; *n2 = 20; qres = arena_resize(&a, n1, 8, buffer_size - 8); assert(qres == NULL && "Arena Resize OUT OF BOUNDS test Failed: \n" - "Reason: Failed to fit a larger than capacity element within arena capacity.\n"); + "Reason: Failed to fit a larger than capacity element within Arena capacity.\n"); } -void test_arena_resize_negative_size(unsigned char *buffer, U32 buffer_size) +void test_arena_resize_negative_size(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 8); - U8* n1 = (U8*)qres; + u8* n1 = (u8*)qres; *n1 = 23; qres = arena_alloc(&a, 8); - U8* n2 = (U8*)qres; + u8* n2 = (u8*)qres; *n2 = 20; qres = arena_resize(&a, n1, 8, -35); @@ -138,47 +138,47 @@ void test_arena_resize_negative_size(unsigned char *buffer, U32 buffer_size) "Reason: Failed to handle allocating a -ve size (VERY LARGE IN UINT) space.\n"); } -void test_arena_resize_tail_negative_size(unsigned char *buffer, U32 buffer_size) +void test_arena_resize_tail_negative_size(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 8); - U8* n1 = (U8*)qres; + u8* n1 = (u8*)qres; *n1 = 23; qres = arena_alloc(&a, 8); - U8* n2 = (U8*)qres; + u8* n2 = (u8*)qres; *n2 = 20; qres = arena_resize(&a, n2, 8, -35); assert(qres == NULL && "Arena Resize OUT OF BOUNDS test Failed: \n" - "Reason: Failed to fit a larger than capacity element within arena capacity.\n"); + "Reason: Failed to fit a larger than capacity element within Arena capacity.\n"); } -void test_arena_clear(unsigned char *buffer, U32 buffer_size) +void test_arena_clear(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 8); arena_clear(&a); assert((a.prev_offset == 0) && (a.curr_offset == 0) && "Arena Clear Test Failed: \n" - "Reason: Failed to clear offsets on an active arena entity after it was cleared.\n"); + "Reason: Failed to clear offsets on an active Arena entity after it was cleared.\n"); } -void test_arena_realloc(unsigned char *buffer, U32 buffer_size) +void test_arena_realloc(unsigned char *buffer, u32 buffer_size) { - struct arena a = {0}; + struct Arena a = {0}; arena_init(&a, buffer, buffer_size); void *qres = arena_alloc(&a, 8); - U8* n1 = (U8*)qres; + u8* n1 = (u8*)qres; *n1 = 12; - U8 n1_value = *n1; + u8 n1_value = *n1; - // free arena + // free Arena arena_clear(&a); qres = arena_alloc(&a, 16); - U8* n1_realloc = (U8*)qres; + u8* n1_realloc = (u8*)qres; assert((*n1_realloc != n1_value) && "Arena Realloc Test Failed: \n" "Reason: Failed to properly clear memory in a region where memory was already allocated.\n"); @@ -186,7 +186,7 @@ void test_arena_realloc(unsigned char *buffer, U32 buffer_size) // ================ STACK ================ // -void test_stack_init(unsigned char *buffer, U32 buffer_size) +void test_stack_init(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); @@ -195,16 +195,16 @@ void test_stack_init(unsigned char *buffer, U32 buffer_size) assert((s.capacity == buffer_size) && "stack capacity does not match buffer size"); } -void test_stack_alloc_n1(unsigned char *buffer, U32 buffer_size) +void test_stack_alloc_n1(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); assert((qres.status == MEM_OK) && "failed to allocate stack element"); - U8 *ele = (U8 *)qres.memory; + u8 *ele = (u8 *)qres.memory; struct stack_hdr *header = (struct stack_hdr*)((uintptr_t)ele - sizeof(struct stack_hdr)); assert((header->prev_offset == 0) && "incorrect prev_offset for first stack element"); @@ -213,20 +213,20 @@ void test_stack_alloc_n1(unsigned char *buffer, U32 buffer_size) assert((s.curr_offset == pad + ele_sz ) && "incorrect curr offset memory"); } -void test_stack_alloc_n2(unsigned char *buffer, U32 buffer_size) +void test_stack_alloc_n2(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; + u8 ele_sz = 16; stack_alloc(&s, ele_sz); size_t last_ele_head = s.prev_offset; size_t last_ele_tail = s.curr_offset; - struct res_void qres = stack_alloc(&s, ele_sz); + struct ResVoid qres = stack_alloc(&s, ele_sz); assert((qres.status == MEM_OK) && "failed to allocate stack element"); - U8 *ele = (U8 *)qres.memory; + u8 *ele = (u8 *)qres.memory; struct stack_hdr *header = (struct stack_hdr*)((uintptr_t)ele - sizeof(struct stack_hdr)); assert((header->prev_offset == last_ele_head) && "incorrect prev_offset for second stack element"); @@ -234,12 +234,12 @@ void test_stack_alloc_n2(unsigned char *buffer, U32 buffer_size) assert((s.curr_offset == last_ele_tail + pad + ele_sz ) && "incorrect curr offset memory"); } -void test_stack_free(unsigned char *buffer, U32 buffer_size) +void test_stack_free(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; + u8 ele_sz = 16; stack_alloc(&s, ele_sz); enum MemStatus status = stack_free(&s); @@ -249,72 +249,72 @@ void test_stack_free(unsigned char *buffer, U32 buffer_size) assert((s.prev_offset == 0) && (s.curr_offset == 0) && "failed to move offsets back correctly"); } -void test_stack_resize_n0(unsigned char *buffer, U32 buffer_size) +void test_stack_resize_n0(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 static_mem[8] = {0,1,2,3,4,5,6,7}; - struct res_void qres = stack_resize(&s, static_mem, 8, 16); + u8 static_mem[8] = {0,1,2,3,4,5,6,7}; + struct ResVoid qres = stack_resize(&s, static_mem, 8, 16); assert((qres.status == MEM_OUT_OF_BOUNDS) && "Stack Resize n0 Failed: \ Reason: should not have resized an element not belonging to the stack\n"); } -void test_stack_resize_n1(unsigned char *buffer, U32 buffer_size) +void test_stack_resize_n1(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); - U8* n1 = (U8*)qres.memory; + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); + u8* n1 = (u8*)qres.memory; *n1 = 23; qres = stack_resize(&s, n1, ele_sz, ele_sz + 20); assert((qres.status == MEM_OK) && "Stack Resize n1 Failed: \ Reason: failed to resize stack element\n"); - n1 = (U8*)qres.memory; + n1 = (u8*)qres.memory; struct stack_hdr* header = (struct stack_hdr*)(n1 - sizeof(struct stack_hdr)); assert((s.curr_offset == 52) && "Stack Resize n1 Failed: \ Reason: incorrectly resized stack element\n"); } -void test_stack_resize_n1_low_memory(unsigned char *buffer, U32 buffer_size) +void test_stack_resize_n1_low_memory(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); - U8* n1 = (U8*)qres.memory; + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); + u8* n1 = (u8*)qres.memory; *n1 = 23; qres = stack_resize(&s, n1, ele_sz, ele_sz + 256); - n1 = (U8*)qres.memory; + n1 = (u8*)qres.memory; assert((qres.status == MEM_FULL) && "Stack Resize n1 low memory Failed: \ Reason: Should not be allowed to resize beyond the allocated stack capacity\n"); } -void test_stack_resize_n2(unsigned char *buffer, U32 buffer_size) +void test_stack_resize_n2(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); - U8* n1 = (U8*)qres.memory; + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); + u8* n1 = (u8*)qres.memory; *n1 = 1; qres = stack_alloc(&s, ele_sz); - U8* n2 = (U8*)qres.memory; + u8* n2 = (u8*)qres.memory; *n2 = 2; size_t last_ele_head = s.prev_offset; qres = stack_resize(&s, n1, ele_sz, 8); - U8* n3 = (U8*)qres.memory; + u8* n3 = (u8*)qres.memory; assert((qres.status == MEM_OK) && "Stack Resize n2 Failed: " "Reason: failed to resize first element in a two element array\n"); @@ -326,14 +326,14 @@ void test_stack_resize_n2(unsigned char *buffer, U32 buffer_size) "Reason: failed to set the previous offset of the header element properly after resize"); } -void test_stack_resize_tail(unsigned char *buffer, U32 buffer_size) +void test_stack_resize_tail(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); - U8* n1 = (U8*)qres.memory; + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); + u8* n1 = (u8*)qres.memory; *n1 = 1; qres = stack_resize(&s, n1, ele_sz, 8); @@ -341,20 +341,20 @@ void test_stack_resize_tail(unsigned char *buffer, U32 buffer_size) "Reason: failed to resize last element to be smaller\n"); } -void test_stack_alloc_free(unsigned char *buffer, U32 buffer_size) +void test_stack_alloc_free(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); - U8* n1 = (U8*)qres.memory; + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); + u8* n1 = (u8*)qres.memory; *n1 = 1; size_t head_n1 = s.prev_offset; size_t tail_n1 = s.curr_offset; qres = stack_alloc(&s, ele_sz); - U8* n2 = (U8*)qres.memory; + u8* n2 = (u8*)qres.memory; *n2 = 2; size_t head_n2 = s.prev_offset; size_t tail_n2 = s.curr_offset; @@ -390,31 +390,31 @@ void test_stack_alloc_free(unsigned char *buffer, U32 buffer_size) */ qres = stack_alloc(&s, ele_sz); - U8* n2_1 = (U8*)qres.memory; + u8* n2_1 = (u8*)qres.memory; assert((*n2_1 == 0) && "Stack Alloc Free error" "Reason: failed to free up memory properly on allocating memory that was cleared"); } -void test_stack_alloc_free_resize(unsigned char *buffer, U32 buffer_size) +void test_stack_alloc_free_resize(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); - U8* n1 = (U8*)qres.memory; + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); + u8* n1 = (u8*)qres.memory; *n1 = 1; size_t head_n1 = s.prev_offset; size_t tail_n1 = s.curr_offset; qres = stack_alloc(&s, ele_sz); - U8* n2 = (U8*)qres.memory; + u8* n2 = (u8*)qres.memory; *n2 = 2; size_t head_n2 = s.prev_offset; size_t tail_n2 = s.curr_offset; qres = stack_alloc(&s, ele_sz); - U8* n3 = (U8*)qres.memory; + u8* n3 = (u8*)qres.memory; *n3 = 3; size_t head_n3 = s.prev_offset; size_t tail_n3 = s.curr_offset; @@ -422,7 +422,7 @@ void test_stack_alloc_free_resize(unsigned char *buffer, U32 buffer_size) stack_free(&s); qres = stack_resize(&s, n1, ele_sz, 32); - U8* n1_1 = (U8*)qres.memory; + u8* n1_1 = (u8*)qres.memory; assert((*n1_1 != 3) && "Stack Alloc Free Resize Test Failed: " "Reason: the newly resized memory was not setup properly.\n" "It had the memory contents of a previously allocated statement\n"); @@ -431,20 +431,20 @@ void test_stack_alloc_free_resize(unsigned char *buffer, U32 buffer_size) "It should have the same memory address as memory allocation #3\n"); } -void test_stack_resize_n2_low_space(unsigned char *buffer, U32 buffer_size) +void test_stack_resize_n2_low_space(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); - U8* n1 = (U8*)qres.memory; + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); + u8* n1 = (u8*)qres.memory; *n1 = 1; size_t head_n1 = s.prev_offset; size_t tail_n1 = s.curr_offset; qres = stack_alloc(&s, s.capacity - 64); - U8* n2 = (U8*)qres.memory; + u8* n2 = (u8*)qres.memory; *n2 = 2; size_t head_n2 = s.prev_offset; size_t tail_n2 = s.curr_offset; @@ -455,7 +455,7 @@ void test_stack_resize_n2_low_space(unsigned char *buffer, U32 buffer_size) "Reason: Failed to catch resize with size larger than available space. \n"); } -void test_stack_alloc_negative_size(unsigned char *buffer, U32 buffer_size) +void test_stack_alloc_negative_size(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); @@ -464,19 +464,19 @@ void test_stack_alloc_negative_size(unsigned char *buffer, U32 buffer_size) // so we get a really large number, that actually ends up looping around and becomes less than the array. // so we have a bounds check for that. stack_alloc(&s, 16); - struct res_void qres = stack_alloc(&s, -16); + struct ResVoid qres = stack_alloc(&s, -16); assert((qres.status == MEM_FULL) && "Test Stack Alloc Negative Size Failed\n" "Reason: Failed to catch allocation with -ve size. \n" "That will translate to be a very large size since the size variable is a size_t (unsigned)\n"); } -void test_stack_resize_negative_size(unsigned char *buffer, U32 buffer_size) +void test_stack_resize_negative_size(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - struct res_void qres = stack_alloc(&s, 16); - S8* n1 = (S8*)qres.memory; + struct ResVoid qres = stack_alloc(&s, 16); + s8* n1 = (s8*)qres.memory; *n1 = -20; qres = stack_resize(&s, n1, 16, -16); @@ -485,26 +485,26 @@ void test_stack_resize_negative_size(unsigned char *buffer, U32 buffer_size) "That will translate to be a very large size since the size variable is a size_t (unsigned)\n"); } -void test_stack_resize_tail_negative_size(unsigned char *buffer, U32 buffer_size) +void test_stack_resize_tail_negative_size(unsigned char *buffer, u32 buffer_size) { struct stack s = {0}; stack_init(&s, buffer, buffer_size); - U8 ele_sz = 16; - struct res_void qres = stack_alloc(&s, ele_sz); - U8* n1 = (U8*)qres.memory; + u8 ele_sz = 16; + struct ResVoid qres = stack_alloc(&s, ele_sz); + u8* n1 = (u8*)qres.memory; *n1 = 1; qres = stack_resize(&s, n1, ele_sz, -8); - U8* n2 = (U8*)qres.memory; + u8* n2 = (u8*)qres.memory; assert((qres.status == MEM_FULL) && "Stack Resize tail Negative Size Failed: " "Reason: Failed to catch resize with -ve size. \n" "That will translate to be a very large size since the size variable is a size_t (unsigned)\n"); } int main(int argc, char** argv) { - U32 sz = 256*sizeof(U8); - U8 *buffer = (U8 *)malloc(sz); + u32 sz = 256*sizeof(u8); + u8 *buffer = (u8 *)malloc(sz); // --------- ARENA --------- // printf("\n===== Testing Arena Allocator =====\n"); test_arena_init(buffer, sz); |