diff options
author | dzwdz | 2022-05-03 20:26:13 +0200 |
---|---|---|
committer | dzwdz | 2022-05-03 20:26:13 +0200 |
commit | beb55e5fcaa5098943352bd07eb27cf8b00e336c (patch) | |
tree | b96159b57f0aba24c4511c48f156fbe0e10245f2 | |
parent | f70dc04d8ad6d1d3b385d798eaa5736a701b73a9 (diff) |
kernel/alloc: expose kmalloc_sanity
-rw-r--r-- | src/kernel/mem/alloc.c | 35 | ||||
-rw-r--r-- | src/kernel/mem/alloc.h | 1 |
2 files changed, 20 insertions, 16 deletions
diff --git a/src/kernel/mem/alloc.c b/src/kernel/mem/alloc.c index d099a31..0daf935 100644 --- a/src/kernel/mem/alloc.c +++ b/src/kernel/mem/alloc.c @@ -102,8 +102,9 @@ void page_free(void *first_addr, size_t pages) { } } -static void kmalloc_sanity(struct malloc_hdr *hdr) { - assert(hdr); +void kmalloc_sanity(void *addr) { + assert(addr); + struct malloc_hdr *hdr = addr - sizeof(struct malloc_hdr); assert(hdr->magic == MALLOC_MAGIC); if (hdr->next) assert(hdr->next->prev == hdr); if (hdr->prev) assert(hdr->prev->next == hdr); @@ -112,30 +113,32 @@ static void kmalloc_sanity(struct malloc_hdr *hdr) { void *kmalloc(size_t len) { // TODO better kmalloc - struct malloc_hdr *addr; + struct malloc_hdr *hdr; + void *addr; uint32_t pages; len += sizeof(struct malloc_hdr); pages = len / PAGE_SIZE + 1; - addr = page_alloc(pages); - addr->magic = MALLOC_MAGIC; - addr->page_amt = pages; + hdr = page_alloc(pages); + hdr->magic = MALLOC_MAGIC; + hdr->page_amt = pages; - addr->next = NULL; - addr->prev = malloc_last; - if (addr->prev) { - assert(!addr->prev->next); - addr->prev->next = addr; + hdr->next = NULL; + hdr->prev = malloc_last; + if (hdr->prev) { + assert(!hdr->prev->next); + hdr->prev->next = hdr; } for (size_t i = 0; i < 4; i++) - addr->stacktrace[i] = debug_caller(i); + hdr->stacktrace[i] = debug_caller(i); - malloc_last = addr; - kmalloc_sanity(addr); + malloc_last = hdr; - return (void*)addr + sizeof(struct malloc_hdr); + addr = (void*)hdr + sizeof(struct malloc_hdr); + kmalloc_sanity(addr); + return addr; } void kfree(void *ptr) { @@ -143,7 +146,7 @@ void kfree(void *ptr) { if (ptr == NULL) return; hdr = ptr - sizeof(struct malloc_hdr); - kmalloc_sanity(hdr); + kmalloc_sanity(ptr); hdr->magic = ~MALLOC_MAGIC; // (hopefully) detect double frees if (hdr->next) diff --git a/src/kernel/mem/alloc.h b/src/kernel/mem/alloc.h index 4f45520..0760d67 100644 --- a/src/kernel/mem/alloc.h +++ b/src/kernel/mem/alloc.h @@ -12,5 +12,6 @@ void *page_alloc(size_t pages); // frees `pages` consecutive pages starting from *first void page_free(void *first, size_t pages); +void kmalloc_sanity(void *addr); void *kmalloc(size_t len); void kfree(void *ptr); |