[kernel] Re-add slab_allocated mixin

The return of slab_allocated! Now after the kutil/util/kernel giant
cleanup, this belongs squarely in the kernel, and works much better
there. Slabs are allocated via a bump pointer into a new kernel VMA,
instead of using kalloc() or allocating pages directly.
This commit is contained in:
Justin C. Miller
2022-01-30 20:46:19 -08:00
parent a7245116b6
commit dd535158f2
3 changed files with 68 additions and 0 deletions

View File

@@ -23,6 +23,8 @@ using bootproto::allocation_register;
using obj::vm_flags;
uintptr_t g_slabs_bump_pointer;
// These objects are initialized _before_ global constructors are called,
// so we don't want them to have global constructors at all, lest they
// overwrite the previous initialization.
@@ -44,6 +46,10 @@ obj::vm_area_guarded g_kernel_buffers {
mem::buffers_size,
vm_flags::write};
obj::vm_area_open g_kernel_slabs {
mem::slabs_size,
vm_flags::write};
void * operator new(size_t size) { return g_kernel_heap.allocate(size); }
void * operator new [] (size_t size) { return g_kernel_heap.allocate(size); }
void operator delete (void *p) noexcept { return g_kernel_heap.free(p); }
@@ -106,6 +112,8 @@ memory_initialize_post_ctors(bootproto::args &kargs)
{
vm_space &vm = vm_space::kernel_space();
vm.add(mem::buffers_offset, &g_kernel_buffers);
vm.add(mem::slabs_offset, &g_kernel_slabs);
g_slabs_bump_pointer = mem::slabs_offset;
g_frame_allocator.free(
get_physical_page(kargs.page_tables.pointer),