mirror of
https://github.com/cfenollosa/os-tutorial.git
synced 2024-10-27 20:34:19 +00:00
93 lines
2.2 KiB
C
93 lines
2.2 KiB
C
|
#include "isr.h"
|
||
|
#include "idt.h"
|
||
|
#include "../drivers/screen.h"
|
||
|
#include "../kernel/util.h"
|
||
|
|
||
|
/* Can't do this with a loop because we need the address
|
||
|
* of the function names */
|
||
|
void isr_install() {
|
||
|
set_idt_gate(0, (u32)isr0);
|
||
|
set_idt_gate(1, (u32)isr1);
|
||
|
set_idt_gate(2, (u32)isr2);
|
||
|
set_idt_gate(3, (u32)isr3);
|
||
|
set_idt_gate(4, (u32)isr4);
|
||
|
set_idt_gate(5, (u32)isr5);
|
||
|
set_idt_gate(6, (u32)isr6);
|
||
|
set_idt_gate(7, (u32)isr7);
|
||
|
set_idt_gate(8, (u32)isr8);
|
||
|
set_idt_gate(9, (u32)isr9);
|
||
|
set_idt_gate(10, (u32)isr10);
|
||
|
set_idt_gate(11, (u32)isr11);
|
||
|
set_idt_gate(12, (u32)isr12);
|
||
|
set_idt_gate(13, (u32)isr13);
|
||
|
set_idt_gate(14, (u32)isr14);
|
||
|
set_idt_gate(15, (u32)isr15);
|
||
|
set_idt_gate(16, (u32)isr16);
|
||
|
set_idt_gate(17, (u32)isr17);
|
||
|
set_idt_gate(18, (u32)isr18);
|
||
|
set_idt_gate(19, (u32)isr19);
|
||
|
set_idt_gate(20, (u32)isr20);
|
||
|
set_idt_gate(21, (u32)isr21);
|
||
|
set_idt_gate(22, (u32)isr22);
|
||
|
set_idt_gate(23, (u32)isr23);
|
||
|
set_idt_gate(24, (u32)isr24);
|
||
|
set_idt_gate(25, (u32)isr25);
|
||
|
set_idt_gate(26, (u32)isr26);
|
||
|
set_idt_gate(27, (u32)isr27);
|
||
|
set_idt_gate(28, (u32)isr28);
|
||
|
set_idt_gate(29, (u32)isr29);
|
||
|
set_idt_gate(30, (u32)isr30);
|
||
|
set_idt_gate(31, (u32)isr31);
|
||
|
|
||
|
set_idt(); // Load with ASM
|
||
|
}
|
||
|
|
||
|
/* To print the message which defines every exception */
|
||
|
char *exception_messages[] = {
|
||
|
"Division By Zero",
|
||
|
"Debug",
|
||
|
"Non Maskable Interrupt",
|
||
|
"Breakpoint",
|
||
|
"Into Detected Overflow",
|
||
|
"Out of Bounds",
|
||
|
"Invalid Opcode",
|
||
|
"No Coprocessor",
|
||
|
|
||
|
"Double Fault",
|
||
|
"Coprocessor Segment Overrun",
|
||
|
"Bad TSS",
|
||
|
"Segment Not Present",
|
||
|
"Stack Fault",
|
||
|
"General Protection Fault",
|
||
|
"Page Fault",
|
||
|
"Unknown Interrupt",
|
||
|
|
||
|
"Coprocessor Fault",
|
||
|
"Alignment Check",
|
||
|
"Machine Check",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved",
|
||
|
"Reserved"
|
||
|
};
|
||
|
|
||
|
void isr_handler(registers_t r) {
|
||
|
kprint("received interrupt: ");
|
||
|
char s[3];
|
||
|
int_to_ascii(r.int_no, s);
|
||
|
kprint(s);
|
||
|
kprint("\n");
|
||
|
kprint(exception_messages[r.int_no]);
|
||
|
kprint("\n");
|
||
|
}
|