summaryrefslogtreecommitdiff
path: root/kernel/src/cpu
diff options
context:
space:
mode:
authorAleksa Vuckovic <aleksa@vuckovic.cc>2023-02-22 17:31:52 +0100
committerAleksa Vuckovic <aleksa@vuckovic.cc>2023-02-22 17:36:02 +0100
commit57e6722453c27d35a3b02309ce21263d225a23e3 (patch)
tree7469dce46d063ddc7a3f3a7da6dcff928730488a /kernel/src/cpu
parent2bb4e7fb4c0f5895148bb32da64381b985c8dcef (diff)
curr_cpu_apic_id() now works on old amd cpus
Diffstat (limited to 'kernel/src/cpu')
-rw-r--r--kernel/src/cpu/irq.c3
-rw-r--r--kernel/src/cpu/kcpuid.c7
-rw-r--r--kernel/src/cpu/msr.c21
3 files changed, 31 insertions, 0 deletions
diff --git a/kernel/src/cpu/irq.c b/kernel/src/cpu/irq.c
index 6975fec..e5f811c 100644
--- a/kernel/src/cpu/irq.c
+++ b/kernel/src/cpu/irq.c
@@ -84,6 +84,9 @@ void irq_def_handler(uint64_t number)
case 1:
keyboard_handler();
break;
+ default:
+ printf("spurious interrupt\n");
+ break;
}
eoi(number);
}
diff --git a/kernel/src/cpu/kcpuid.c b/kernel/src/cpu/kcpuid.c
new file mode 100644
index 0000000..30a4d3e
--- /dev/null
+++ b/kernel/src/cpu/kcpuid.c
@@ -0,0 +1,7 @@
+#include <types.h>
+#include <kcpuid.h>
+
+void kcpuid(uint32_t func, uint32_t subfunc, CPUIDinfo* info)
+{
+ __asm__ __volatile__ ( "cpuid" : "=a"(info->EAX), "=b"(info->EBX), "=c"(info->ECX), "=d"(info->EDX) : "a"(func), "c"(subfunc) : );
+}
diff --git a/kernel/src/cpu/msr.c b/kernel/src/cpu/msr.c
new file mode 100644
index 0000000..75fc602
--- /dev/null
+++ b/kernel/src/cpu/msr.c
@@ -0,0 +1,21 @@
+#include <msr.h>
+
+uint64_t read_msr(uint32_t addr)
+{
+ uint64_t eax;
+ uint64_t edx;
+ uint64_t ecx = addr;
+
+ __asm__ volatile ("rdmsr;" : "=a"(eax), "=d"(edx) : "c"(ecx) :);
+
+ return (edx << 32) | eax;
+}
+
+void write_msr(uint32_t addr, uint64_t value)
+{
+ uint64_t eax = value & 0xFFFFFFFF;
+ uint64_t edx = value >> 32;
+ uint64_t ecx = addr;
+
+ __asm__ volatile ("wrmsr;" : : "a"(eax), "d"(edx), "c"(ecx) :);
+}