BarinkOS/source/kernel/Memory/GDT/gdtc.cpp

59 lines
1.6 KiB
C++
Raw Normal View History

2021-05-12 22:03:00 +00:00
#include "gdtc.h"
#include "../../Terminal/kterm.h"
2021-11-06 20:56:42 +00:00
2021-11-16 20:17:49 +00:00
#define NULL_SEGMENT 0
#define KERNEL_CODE_SEGMENT 1
#define KERNEL_DATA_SEGMENT 2
#define USER_CODE_SEGMENT 3
#define USER_DATA_SEGMENT 4
2021-05-12 22:03:00 +00:00
2021-11-16 20:17:49 +00:00
SegmentDescriptor GlobalDescriptorTable[5];
GlobalDescriptorTableDescriptor gdtDescriptor;
2021-05-12 22:03:00 +00:00
2021-11-16 20:17:49 +00:00
void add_descriptor(int which , unsigned long base, unsigned long limit, unsigned char access, unsigned char granularity ){
GlobalDescriptorTable[which].base_low = (base & 0xFFFF );
GlobalDescriptorTable[which].base_middle = (base >> 6) & 0xFF;
GlobalDescriptorTable[which].base_high = (base >> 24) & 0xFF;
GlobalDescriptorTable[which].limit_low = (limit & 0xFFFF);
GlobalDescriptorTable[which].granularity = ((limit >> 16) & 0x0F);
GlobalDescriptorTable[which].granularity |= (granularity & 0xF0);
GlobalDescriptorTable[which].access = access;
2021-05-12 22:03:00 +00:00
}
2021-11-16 20:17:49 +00:00
void initGDT(){
#ifdef __VERBOSE__
printf("Init GDT!\n");
#endif
2021-11-16 20:17:49 +00:00
// NULL segment
add_descriptor(NULL_SEGMENT, 0,0,0,0);
// Kernel Code Segment
add_descriptor(KERNEL_CODE_SEGMENT, 0, 0xFFFFFFFF, 0x9A, 0xCF);
// Kernel Data Segment
add_descriptor(KERNEL_DATA_SEGMENT, 0, 0xFFFFFFFF, 0x92, 0xCF);
// User Code Segment
// TODO:
// User Data Segement
// TODO:
// init Gdt Descriptor
gdtDescriptor.limit = ((sizeof(SegmentDescriptor ) * 5 ) - 1);
gdtDescriptor.base = (unsigned int) &GlobalDescriptorTable;
printf("GDT at address 0x%x, with an size of 0x%x bytes\n" , (unsigned int)GlobalDescriptorTable, sizeof(GlobalDescriptorTable));
2021-11-16 20:17:49 +00:00
LoadGlobalDescriptorTable();
2021-05-12 22:03:00 +00:00
}