mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 19:58:11 +00:00

The kernel and its static data structures are no longer identity-mapped in the bottom 8MB of the address space, but instead move above 3GB. The first 8MB above 3GB are pseudo-identity-mapped to the bottom 8MB of the physical address space. But things don't have to stay this way! Thanks to Jesse who made an earlier attempt at this, it was really easy to get device drivers working once the page tables were in place! :^) Fixes #734.
41 lines
1.3 KiB
C++
41 lines
1.3 KiB
C++
#pragma once
|
|
|
|
#include <AK/HashMap.h>
|
|
#include <AK/RefCounted.h>
|
|
#include <AK/RefPtr.h>
|
|
#include <Kernel/VM/PhysicalPage.h>
|
|
#include <Kernel/VM/RangeAllocator.h>
|
|
|
|
class Process;
|
|
|
|
class PageDirectory : public RefCounted<PageDirectory> {
|
|
friend class MemoryManager;
|
|
|
|
public:
|
|
static NonnullRefPtr<PageDirectory> create_for_userspace(Process& process, const RangeAllocator* parent_range_allocator = nullptr)
|
|
{
|
|
return adopt(*new PageDirectory(process, parent_range_allocator));
|
|
}
|
|
static NonnullRefPtr<PageDirectory> create_kernel_page_directory() { return adopt(*new PageDirectory); }
|
|
static RefPtr<PageDirectory> find_by_cr3(u32);
|
|
|
|
~PageDirectory();
|
|
|
|
u32 cr3() const { return m_directory_table->paddr().get(); }
|
|
PageDirectoryPointerTable& table() { return *reinterpret_cast<PageDirectoryPointerTable*>(0xc0000000 + cr3()); }
|
|
|
|
RangeAllocator& range_allocator() { return m_range_allocator; }
|
|
|
|
Process* process() { return m_process; }
|
|
const Process* process() const { return m_process; }
|
|
|
|
private:
|
|
PageDirectory(Process&, const RangeAllocator* parent_range_allocator);
|
|
PageDirectory();
|
|
|
|
Process* m_process { nullptr };
|
|
RangeAllocator m_range_allocator;
|
|
RefPtr<PhysicalPage> m_directory_table;
|
|
RefPtr<PhysicalPage> m_directory_pages[4];
|
|
HashMap<unsigned, RefPtr<PhysicalPage>> m_physical_pages;
|
|
};
|