2023-11-15 15:14:29 -08:00
|
|
|
#include "memory/kernel_vmm.h"
|
|
|
|
|
|
|
|
#include "debug/debug.h"
|
|
|
|
#include "memory/paging_util.h"
|
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
KernelVmm* gKernelVmm = nullptr;
|
|
|
|
|
|
|
|
}
|
|
|
|
KernelVmm::KernelVmm() {
|
|
|
|
if (gKernelVmm) {
|
|
|
|
panic("KernelVmm double init.");
|
|
|
|
}
|
|
|
|
gKernelVmm = this;
|
2023-11-15 15:38:25 -08:00
|
|
|
stack_manager_ = glcr::MakeUnique<KernelStackManager>();
|
|
|
|
stack_manager_->SetupInterruptStack();
|
2023-11-15 15:14:29 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
uint64_t KernelVmm::AcquireSlabHeapRegion(uint64_t slab_size_bytes) {
|
|
|
|
return gKernelVmm->AcquireSlabHeapRegionInternal(slab_size_bytes);
|
|
|
|
}
|
|
|
|
|
2023-11-15 15:38:25 -08:00
|
|
|
uint64_t KernelVmm::AcquireKernelStack() {
|
|
|
|
return gKernelVmm->stack_manager_->AllocateKernelStack();
|
|
|
|
}
|
|
|
|
|
2023-11-19 17:29:09 -08:00
|
|
|
void KernelVmm::FreeKernelStack(uint64_t stack_addr) {
|
|
|
|
return gKernelVmm->stack_manager_->FreeKernelStack(stack_addr);
|
|
|
|
}
|
|
|
|
|
2023-11-15 15:14:29 -08:00
|
|
|
uint64_t KernelVmm::AcquireSlabHeapRegionInternal(uint64_t slab_size_bytes) {
|
|
|
|
uint64_t next_slab = next_slab_heap_page_;
|
|
|
|
if (next_slab >= kKernelBuddyHeapEnd) {
|
|
|
|
panic("Slab heap overrun");
|
|
|
|
}
|
|
|
|
next_slab_heap_page_ += slab_size_bytes;
|
|
|
|
// TODO: Consider handling this as a part of a page-fault handler
|
|
|
|
// rather than auto mapping all over the place.
|
|
|
|
EnsureResident(next_slab, slab_size_bytes);
|
|
|
|
return next_slab;
|
|
|
|
}
|