aboutsummaryrefslogtreecommitdiff
path: root/arch/x86_64/src/kernel/cpu/tr.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86_64/src/kernel/cpu/tr.cpp')
-rw-r--r--arch/x86_64/src/kernel/cpu/tr.cpp8
1 files changed, 7 insertions, 1 deletions
diff --git a/arch/x86_64/src/kernel/cpu/tr.cpp b/arch/x86_64/src/kernel/cpu/tr.cpp
index d0e037f..e281189 100644
--- a/arch/x86_64/src/kernel/cpu/tr.cpp
+++ b/arch/x86_64/src/kernel/cpu/tr.cpp
@@ -11,6 +11,12 @@ namespace teachos::arch::kernel::cpu
auto load_task_register(uint16_t gdt_offset) -> void
{
- asm volatile("ltr %[input]" : /* no output from call */ : [input] "r"(gdt_offset));
+ // asm volatile("ltr %[input]" : /* no output from call */ : [input] "R"(gdt_offset));
+ // https://www.scs.stanford.edu/05au-cs240c/lab/i386/s07_03.htm
+ asm volatile("mov %[input], %%ax\n"
+ "ltr %%ax\n"
+ : /* no output from call */
+ : [input] "r"(gdt_offset)
+ : "ax");
}
} // namespace teachos::arch::kernel::cpu