umalloc small bug fixes
This commit is contained in:
@ -7,6 +7,7 @@
|
|||||||
#include <linklist.h>
|
#include <linklist.h>
|
||||||
#include <string/string.h>
|
#include <string/string.h>
|
||||||
#include <write/write.h>
|
#include <write/write.h>
|
||||||
|
#include <util/util.h>
|
||||||
|
|
||||||
#define ARENA_SIZE (1<<20)
|
#define ARENA_SIZE (1<<20)
|
||||||
|
|
||||||
@ -14,7 +15,7 @@ typedef struct UmArena {
|
|||||||
struct UmArena *next;
|
struct UmArena *next;
|
||||||
uintptr_t mem;
|
uintptr_t mem;
|
||||||
size_t cursor;
|
size_t cursor;
|
||||||
int64_t balance;
|
int balance;
|
||||||
} UmArena;
|
} UmArena;
|
||||||
|
|
||||||
static UmArena *ARENAS = NULL;
|
static UmArena *ARENAS = NULL;
|
||||||
@ -30,7 +31,7 @@ UmArena *um_newarena(void) {
|
|||||||
string_memset(mem, 0, arenasize);
|
string_memset(mem, 0, arenasize);
|
||||||
|
|
||||||
UmArena *arena = (UmArena *)mem;
|
UmArena *arena = (UmArena *)mem;
|
||||||
arena->mem = (uintptr_t)mem + sizeof(arena);
|
arena->mem = (uintptr_t)mem + sizeof(UmArena);
|
||||||
arena->cursor = 0;
|
arena->cursor = 0;
|
||||||
LL_APPEND(ARENAS, arena);
|
LL_APPEND(ARENAS, arena);
|
||||||
|
|
||||||
@ -42,7 +43,7 @@ void *umalloc(size_t size) {
|
|||||||
|
|
||||||
UmArena *arena, *arenatmp;
|
UmArena *arena, *arenatmp;
|
||||||
LL_FOREACH_SAFE(ARENAS, arena, arenatmp) {
|
LL_FOREACH_SAFE(ARENAS, arena, arenatmp) {
|
||||||
if (arena->cursor + size < ARENA_SIZE) {
|
if (arena->cursor + size <= ARENA_SIZE - sizeof(UmArena)) {
|
||||||
usable = arena;
|
usable = arena;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -69,7 +70,7 @@ void ufree(void *ptr_) {
|
|||||||
|
|
||||||
UmArena *arena, *arenatmp;
|
UmArena *arena, *arenatmp;
|
||||||
LL_FOREACH_SAFE(ARENAS, arena, arenatmp) {
|
LL_FOREACH_SAFE(ARENAS, arena, arenatmp) {
|
||||||
if (ptr >= arena->mem && ptr < arena->mem + ARENA_SIZE) {
|
if (ptr >= arena->mem && ptr < arena->mem + ARENA_SIZE - sizeof(UmArena)) {
|
||||||
freeable = arena;
|
freeable = arena;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -81,9 +82,15 @@ void ufree(void *ptr_) {
|
|||||||
|
|
||||||
freeable->balance -= 1;
|
freeable->balance -= 1;
|
||||||
|
|
||||||
if (freeable->balance <= 0) {
|
if (freeable->balance < 0) {
|
||||||
uintptr_t origin = (uintptr_t)freeable - sizeof(UmArena);
|
writefmt("umalloc: ufree() called more times than umalloc() ({d})\n", freeable->balance);
|
||||||
mman_unmap((void *)origin);
|
quit();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (freeable->balance == 0) {
|
||||||
|
LL_REMOVE(ARENAS, freeable);
|
||||||
|
|
||||||
|
mman_unmap((void *)(freeable->mem - sizeof(UmArena)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user