aboutsummaryrefslogtreecommitdiff
path: root/arch/x86_64/src/kernel/cpu
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86_64/src/kernel/cpu')
-rw-r--r--arch/x86_64/src/kernel/cpu/segment_register.cpp34
-rw-r--r--arch/x86_64/src/kernel/cpu/ss.cpp16
2 files changed, 34 insertions, 16 deletions
diff --git a/arch/x86_64/src/kernel/cpu/segment_register.cpp b/arch/x86_64/src/kernel/cpu/segment_register.cpp
new file mode 100644
index 0000000..f70c558
--- /dev/null
+++ b/arch/x86_64/src/kernel/cpu/segment_register.cpp
@@ -0,0 +1,34 @@
+#include "arch/kernel/cpu/segment_register.hpp"
+
+#include "arch/context_switching/interrupt_descriptor_table/segment_selector.hpp"
+
+namespace teachos::arch::kernel::cpu
+{
+ [[gnu::naked]]
+ auto reload_segment_registers() -> void
+ {
+ asm volatile("xor %rax, %rax\n"
+ "mov %rax, %ss\n"
+ "mov %rax, %ds\n"
+ "mov %rax, %es\n"
+ "mov %rax, %fs\n"
+ "mov %rax, %gs\n"
+ "ret");
+ }
+
+ [[gnu::naked]]
+ auto set_segment_registers(context_switching::interrupt_descriptor_table::segment_selector segment_selector) -> void
+ {
+ asm volatile("xor %%rax, %%rax\n"
+ "mov %[input], %%ax\n"
+ "mov %%rax, %%ss\n"
+ "mov %%rax, %%ds\n"
+ "mov %%rax, %%es\n"
+ "mov %%rax, %%fs\n"
+ "mov %%rax, %%gs\n"
+ "ret"
+ : /* No output from call */
+ : [input] "m"(segment_selector));
+ }
+
+} // namespace teachos::arch::kernel::cpu
diff --git a/arch/x86_64/src/kernel/cpu/ss.cpp b/arch/x86_64/src/kernel/cpu/ss.cpp
deleted file mode 100644
index 0978eca..0000000
--- a/arch/x86_64/src/kernel/cpu/ss.cpp
+++ /dev/null
@@ -1,16 +0,0 @@
-#include "arch/kernel/cpu/ss.hpp"
-
-namespace teachos::arch::kernel::cpu
-{
- auto read_ss() -> context_switching::interrupt_descriptor_table::segment_selector
- {
- context_switching::interrupt_descriptor_table::segment_selector segment_selector{};
- asm volatile("mov %%ss, %[output]" : [output] "=m"(segment_selector));
- return segment_selector;
- }
-
- auto write_ss(context_switching::interrupt_descriptor_table::segment_selector selector) -> void
- {
- asm volatile("mov %[input], %%ss" : /* no output from call */ : [input] "m"(selector));
- }
-} // namespace teachos::arch::kernel::cpu