From 043b8b9d4624d4208a330cbce9775c43f1bf1fc6 Mon Sep 17 00:00:00 2001 From: Vegard Storheil Eriksen Date: Wed, 20 Jan 2010 22:19:56 +0100 Subject: Added TSS. --- kernel/gdt.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'kernel/gdt.c') diff --git a/kernel/gdt.c b/kernel/gdt.c index 7d23289..92d3d4c 100644 --- a/kernel/gdt.c +++ b/kernel/gdt.c @@ -1,11 +1,14 @@ #include "gdt.h" +tss_entry tss = tss_entry_init(0xfffff800, 0x10, 0x0b, 0x13); + gdt_entry gdt[] = { gdt_entry_init(0, 0, 0), gdt_entry_init(0, 0xfffff, 0xc09a), // Code segment. gdt_entry_init(0, 0xfffff, 0xc092), // Data segment. gdt_entry_init(0, 0xfffff, 0xc0fa), // User mode code segment. gdt_entry_init(0, 0xfffff, 0xc0f2), // User mode data segment. + gdt_entry_init(0, sizeof(tss_entry), 0x00e9), // TSS. }; gdt_ptr gdtr = { @@ -14,6 +17,10 @@ gdt_ptr gdtr = { }; void gdt_init() { + gdt[5].base_low = (uint32_t)&tss & 0xffff; + gdt[5].base_mid = (uint32_t)&tss >> 16 & 0xff; + gdt[5].base_high = (uint32_t)&tss >> 24 & 0xff; + asm volatile( "lgdt (%0)\n" "mov %w1, %%ds\n" @@ -23,6 +30,7 @@ void gdt_init() { "mov %w1, %%ss\n" "ljmp $0x08, $.flush\n" ".flush:\n" - : : "r" (&gdtr), "r" (0x10) + "ltr %w2\n" + : : "r" (&gdtr), "r" (0x10), "r" (0x28) ); } -- cgit v1.2.3