forked from Bananymous/banan-os
Kernel: Process now frees up its pages on destruction
This commit is contained in:
parent
7530482cc2
commit
cc04990ce3
|
@ -4,6 +4,7 @@
|
||||||
#include <BAN/StringView.h>
|
#include <BAN/StringView.h>
|
||||||
#include <BAN/Vector.h>
|
#include <BAN/Vector.h>
|
||||||
#include <kernel/FS/Inode.h>
|
#include <kernel/FS/Inode.h>
|
||||||
|
#include <kernel/Memory/Heap.h>
|
||||||
#include <kernel/Memory/MMU.h>
|
#include <kernel/Memory/MMU.h>
|
||||||
#include <kernel/SpinLock.h>
|
#include <kernel/SpinLock.h>
|
||||||
#include <kernel/Terminal/TTY.h>
|
#include <kernel/Terminal/TTY.h>
|
||||||
|
@ -78,6 +79,7 @@ namespace Kernel
|
||||||
BAN::ErrorOr<int> get_free_fd();
|
BAN::ErrorOr<int> get_free_fd();
|
||||||
|
|
||||||
BAN::Vector<OpenFileDescription> m_open_files;
|
BAN::Vector<OpenFileDescription> m_open_files;
|
||||||
|
BAN::Vector<Memory::paddr_t> m_allocated_pages;
|
||||||
|
|
||||||
mutable RecursiveSpinLock m_lock;
|
mutable RecursiveSpinLock m_lock;
|
||||||
|
|
||||||
|
|
|
@ -66,10 +66,12 @@ namespace Kernel
|
||||||
{
|
{
|
||||||
size_t page_start = elf_program_header.p_vaddr / 4096;
|
size_t page_start = elf_program_header.p_vaddr / 4096;
|
||||||
size_t page_end = BAN::Math::div_round_up<size_t>(elf_program_header.p_vaddr + elf_program_header.p_memsz, 4096);
|
size_t page_end = BAN::Math::div_round_up<size_t>(elf_program_header.p_vaddr + elf_program_header.p_memsz, 4096);
|
||||||
|
MUST(process->m_allocated_pages.reserve(page_end - page_start + 1));
|
||||||
for (size_t page = page_start; page <= page_end; page++)
|
for (size_t page = page_start; page <= page_end; page++)
|
||||||
{
|
{
|
||||||
auto addr = Memory::Heap::get().take_free_page();
|
auto paddr = Memory::Heap::get().take_free_page();
|
||||||
process->m_mmu->map_page_at(addr, page * 4096, MMU::Flags::UserSupervisor | MMU::Flags::ReadWrite | MMU::Flags::Present);
|
MUST(process->m_allocated_pages.push_back(paddr));
|
||||||
|
process->m_mmu->map_page_at(paddr, page * 4096, MMU::Flags::UserSupervisor | MMU::Flags::ReadWrite | MMU::Flags::Present);
|
||||||
}
|
}
|
||||||
process->m_mmu->load();
|
process->m_mmu->load();
|
||||||
memcpy((void*)elf_program_header.p_vaddr, elf->data() + elf_program_header.p_offset, elf_program_header.p_filesz);
|
memcpy((void*)elf_program_header.p_vaddr, elf->data() + elf_program_header.p_offset, elf_program_header.p_filesz);
|
||||||
|
@ -98,8 +100,11 @@ namespace Kernel
|
||||||
|
|
||||||
Process::~Process()
|
Process::~Process()
|
||||||
{
|
{
|
||||||
if (!m_threads.empty())
|
ASSERT(m_threads.empty());
|
||||||
exit();
|
if (m_mmu)
|
||||||
|
delete m_mmu;
|
||||||
|
for (auto paddr : m_allocated_pages)
|
||||||
|
Memory::Heap::get().release_page(paddr);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Process::add_thread(Thread* thread)
|
void Process::add_thread(Thread* thread)
|
||||||
|
|
Loading…
Reference in New Issue