summaryrefslogtreecommitdiff
path: root/src/arch/i386/interrupts/isr.c
diff options
context:
space:
mode:
authordzwdz2021-07-10 17:41:32 +0200
committerdzwdz2021-07-10 17:41:32 +0200
commit1bf5e324005ce7122a195af106cec656960648dc (patch)
tree7a8394a5243ad50d1e8d5574d94908461fe96cc6 /src/arch/i386/interrupts/isr.c
parent6cbdc62b5cbe34d7355047722d6d483a4d25c7f3 (diff)
a sensible source structure
The idea is that src/kernel/ is only allowed to interface with the hardware using whatever's defined in src/arch/generic.h. I'll probably write a small script for checking this later on. This is a giant commit so I've probably fucked something up. It boots fine on Bochs and QEMU, so at least there's that.
Diffstat (limited to 'src/arch/i386/interrupts/isr.c')
-rw-r--r--src/arch/i386/interrupts/isr.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/src/arch/i386/interrupts/isr.c b/src/arch/i386/interrupts/isr.c
new file mode 100644
index 0000000..03399ea
--- /dev/null
+++ b/src/arch/i386/interrupts/isr.c
@@ -0,0 +1,24 @@
+#include <arch/i386/interrupts/isr.h>
+#include <arch/i386/tty.h>
+#include <kernel/panic.h>
+#include <stdbool.h>
+#include <stdint.h>
+
+bool isr_test_interrupt_called = false;
+
+__attribute__((interrupt))
+void isr_double_fault(struct interrupt_frame *frame) {
+ tty_const("#DF");
+ panic();
+}
+
+__attribute__((interrupt))
+void isr_general_protection_fault(struct interrupt_frame *frame) {
+ tty_const("#GP");
+ panic();
+}
+
+__attribute__((interrupt))
+void isr_test_interrupt(struct interrupt_frame *frame) {
+ isr_test_interrupt_called = true;
+}