2021-11-02 20:15:00 +00:00
|
|
|
#include "PageDirectory.h"
|
2021-11-02 20:03:11 +00:00
|
|
|
#include <stdint.h>
|
2021-05-10 20:32:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
2021-11-02 20:15:00 +00:00
|
|
|
void PageDirectory::enable(){
|
2021-05-10 20:32:28 +00:00
|
|
|
|
|
|
|
//set each entry to not present
|
|
|
|
int i;
|
|
|
|
for(i = 0; i < 1024; i++)
|
|
|
|
{
|
|
|
|
// This sets the following flags to the pages:
|
|
|
|
// Supervisor: Only kernel-mode can access them
|
|
|
|
// Write Enabled: It can be both read from and written to
|
|
|
|
// Not Present: The page table is not present
|
|
|
|
this->page_directory[i] = 0x00000002;
|
|
|
|
}
|
|
|
|
|
|
|
|
// holds the physical address where we want to start mapping these pages to.
|
|
|
|
// in this case, we want to map these pages to the very beginning of memory.
|
|
|
|
|
|
|
|
//we will fill all 1024 entries in the table, mapping 4 megabytes
|
|
|
|
for(unsigned int i = 0; i < 1024; i++)
|
|
|
|
{
|
2021-07-22 19:02:47 +00:00
|
|
|
// As the address is page aligned, it will always leave 12 bits zeroed.
|
|
|
|
// Those bits are used by the attributes ;)
|
|
|
|
first_page_table[i] = (i * 0x1000) | 3; // attributes: supervisor level, read/write, present.
|
2021-05-10 20:32:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// attributes: supervisor level, read/write, present
|
|
|
|
this->page_directory[0] = ((unsigned int)first_page_table) | 3;
|
|
|
|
|
|
|
|
|
|
|
|
loadPageDirectory(this->page_directory);
|
|
|
|
enablePaging();
|
2021-07-22 19:02:47 +00:00
|
|
|
}
|
|
|
|
|
2021-11-02 20:03:11 +00:00
|
|
|
/*
|
|
|
|
void IdentityPaging(uint32_t *first_pte, vaddr from, int size)
|
|
|
|
{
|
|
|
|
from = from & 0xFFFFF000; // Discard the bits we don't want
|
|
|
|
for (; size > 0; from += 4096, first_pte++)
|
|
|
|
{
|
|
|
|
*first_pte = from | 1; // makr page present.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
*/
|