aboutsummaryrefslogtreecommitdiff
path: root/src/kernel/tables/gdt.c
diff options
context:
space:
mode:
authorNic Gaffney <gaffney_nic@protonmail.com>2024-02-06 04:58:35 -0600
committerNic Gaffney <gaffney_nic@protonmail.com>2024-02-06 04:58:35 -0600
commitecf636f2797647d5dfc38a4562cae53fe275217d (patch)
treec71d113c553821c2b949eb6a6cd67de5f2fce068 /src/kernel/tables/gdt.c
parentf1dee4bc58e4bfb97a1b41831c5d4fc327882991 (diff)
downloadgftos-ecf636f2797647d5dfc38a4562cae53fe275217d.tar.gz
Interrupts + basic keyboard driver
Diffstat (limited to 'src/kernel/tables/gdt.c')
-rw-r--r--src/kernel/tables/gdt.c52
1 files changed, 52 insertions, 0 deletions
diff --git a/src/kernel/tables/gdt.c b/src/kernel/tables/gdt.c
new file mode 100644
index 0000000..9c65152
--- /dev/null
+++ b/src/kernel/tables/gdt.c
@@ -0,0 +1,52 @@
+#include "gdt.h"
+#include <stdint.h>
+
+GDT_t table = 0x0;
+extern GDTR_t gdtr;
+void get_gdtr() {
+ uint32_t base = (uint32_t)table;
+
+ table[0] = make_descriptor(base, 0, 0);
+ table[1] = make_descriptor(base, 0x3FFFF, make_code(0, 0, 1));
+ table[2] = make_descriptor(base, 0x3FFFF, make_data(0, 0, 1));
+
+ gdtr.size = sizeof(Segment_Descriptor_t) * 3 - 1;
+ gdtr.offset = base;
+}
+
+uint16_t make_code(uint8_t priv, uint8_t dc, uint8_t rw) {
+ uint16_t access = 0;
+ access |= (1 << 7);
+ access |= (priv << 5);
+ access |= (0b11 << 3);
+ access |= (dc << 2);
+ access |= (rw << 1); // 10
+ access <<= 8;
+ access |= FLAG;
+ return access;
+}
+
+uint16_t make_data(uint8_t priv, uint8_t dc, uint8_t rw) {
+ uint16_t access = 0;
+ access |= (1 << 7);
+ access |= (priv << 5);
+ access |= (0b10 << 3);
+ access |= (dc << 2);
+ access |= (rw << 1); // 10
+ access <<= 8;
+ access |= FLAG;
+ return access;
+}
+
+Segment_Descriptor_t make_descriptor(uint32_t base, uint32_t limit,
+ uint16_t access_flag) {
+ uint16_t lim_low = limit;
+ uint16_t base_low = base;
+ uint8_t base_mid = (base >> 16);
+ uint8_t access_byte = access_flag >> 8;
+ uint8_t lim_flag = ((access_flag << 4) | (limit >> 16));
+ uint8_t base_high = (base >> 24);
+ return (Segment_Descriptor_t){
+ lim_low, base_low, base_mid, access_byte, lim_flag, base_high,
+ };
+}