2024-11-27 21:57:18 +01:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stddef.h>
|
|
|
|
|
|
|
|
#include <kernel/paging.h>
|
|
|
|
#include <kernel/tty.h>
|
|
|
|
|
|
|
|
struct x86_Page_Directory {
|
|
|
|
bool present: 1;
|
2025-02-23 16:03:03 +01:00
|
|
|
bool read_write: 1;
|
|
|
|
bool user_supervisor: 1;
|
|
|
|
bool write_through: 1;
|
|
|
|
bool cache_disable: 1;
|
|
|
|
bool accesed: 1;
|
|
|
|
bool available_2: 1;
|
|
|
|
bool page_size: 1;
|
|
|
|
uint8_t available_1 : 4;
|
2025-02-23 18:26:02 +01:00
|
|
|
uint32_t address : 20; // Multiply by 0x1000
|
2024-11-27 21:57:18 +01:00
|
|
|
} __attribute__((packed));
|
|
|
|
|
2025-02-23 18:26:02 +01:00
|
|
|
struct x86_Page_Table {
|
|
|
|
bool present: 1;
|
|
|
|
bool read_write: 1;
|
|
|
|
bool user_supervisor: 1;
|
|
|
|
bool write_through: 1;
|
|
|
|
bool cache_disable: 1;
|
|
|
|
bool accesed: 1;
|
|
|
|
bool dirty: 1;
|
|
|
|
bool page_attribute_table: 1;
|
|
|
|
bool global: 1;
|
|
|
|
uint8_t available_1 : 3;
|
|
|
|
uint32_t address : 20; // Multiply by 0x1000
|
|
|
|
} __attribute__((packed));
|
|
|
|
|
|
|
|
extern struct x86_Page_Directory boot_page_directory[1024] __attribute__((aligned(4096)));
|
|
|
|
|
|
|
|
static struct x86_Page_Table* get_table(uint16_t index) {
|
|
|
|
struct x86_Page_Table* table = (struct x86_Page_Table*)(boot_page_directory[index].address * 0x1000 + 0xC0000000);
|
|
|
|
return table;
|
|
|
|
}
|
2024-11-27 21:57:18 +01:00
|
|
|
|
|
|
|
void setup_paging() {
|
2025-02-23 18:26:02 +01:00
|
|
|
struct x86_Page_Table* kernel = get_table(768);
|
|
|
|
for (int i = 0; i < 1024; i++) {
|
|
|
|
if (kernel[i].address != 0) {
|
|
|
|
struct x86_Page_Table test = kernel[i];
|
|
|
|
}
|
|
|
|
}
|
2024-11-27 21:57:18 +01:00
|
|
|
}
|
2025-02-23 18:26:02 +01:00
|
|
|
|