summaryrefslogtreecommitdiff
path: root/src/kernel/mem/alloc.c
diff options
context:
space:
mode:
authordzwdz2022-08-06 23:07:41 +0200
committerdzwdz2022-08-06 23:07:41 +0200
commite86d720f6481e83ff555989006b7f62433318f57 (patch)
treedf972be07349e22f29cbce0d848a9af83e6609d2 /src/kernel/mem/alloc.c
parentd3bd832dff6a960938f2948a261ca096c17f516e (diff)
kernel/mem: cache the potential location of the first free page
~3x speedup in tests
Diffstat (limited to 'src/kernel/mem/alloc.c')
-rw-r--r--src/kernel/mem/alloc.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/src/kernel/mem/alloc.c b/src/kernel/mem/alloc.c
index c08b24a..843adfc 100644
--- a/src/kernel/mem/alloc.c
+++ b/src/kernel/mem/alloc.c
@@ -19,6 +19,7 @@ struct malloc_hdr *malloc_last = NULL;
extern uint8_t pbitmap[], pbitmap_start[]; /* linker.ld */
static size_t pbitmap_len;
+static size_t pbitmap_searchstart = 0;
static bool bitmap_get(size_t i) {
@@ -73,7 +74,7 @@ void mem_debugprint(void) {
void *page_alloc(size_t pages) {
/* i do realize how painfully slow this is */
size_t streak = 0;
- for (size_t i = 0; i < pbitmap_len * 8; i++) {
+ for (size_t i = pbitmap_searchstart; i < pbitmap_len * 8; i++) {
if (bitmap_get(i)) {
streak = 0;
continue;
@@ -83,6 +84,7 @@ void *page_alloc(size_t pages) {
i = i + 1 - streak;
for (size_t j = 0; j < streak; j++)
bitmap_set(i + j, true);
+ pbitmap_searchstart = i + streak - 1;
return pbitmap_start + i * PAGE_SIZE;
}
}
@@ -100,6 +102,8 @@ void *page_zalloc(size_t pages) {
void page_free(void *first_addr, size_t pages) {
assert(first_addr >= (void*)pbitmap_start);
size_t first = ((uintptr_t)first_addr - (uintptr_t)pbitmap_start) / PAGE_SIZE;
+ if (pbitmap_searchstart > first)
+ pbitmap_searchstart = first;
for (size_t i = 0; i < pages; i++) {
assert(bitmap_get(first + i));
bitmap_set(first + i, false);