Exception handler can access their ID
This commit is contained in:
parent
de14e795d6
commit
59a8d3b582
@ -1,16 +1,22 @@
|
|||||||
#include "exception.h"
|
#include "exception.h"
|
||||||
|
#include "klibc.h"
|
||||||
#include "vga.h"
|
#include "vga.h"
|
||||||
|
#define STR_HELPER(x) #x
|
||||||
|
#define STR(x) STR_HELPER(x)
|
||||||
|
|
||||||
// Need GCC > 6
|
// Need GCC > 6
|
||||||
__attribute__((interrupt)) void print_handler(struct interrupt_frame *frame, ulong error_code)
|
#define DEFINE_INTERRUPT(int_nb) \
|
||||||
{
|
__attribute__((interrupt)) void print_handler_##int_nb(struct interrupt_frame *frame, \
|
||||||
|
ulong error_code) \
|
||||||
printStringDetails("EXCEPTION", RED, BLACK, 0, VGA_HEIGHT - 1);
|
{ \
|
||||||
printIntDetails(error_code, RED, BLACK, 11, VGA_HEIGHT - 1);
|
int intNbInt = int_nb; \
|
||||||
(void)frame;
|
printStringDetails("EXCEPTION ", RED, BLACK, 0, VGA_HEIGHT - 1); \
|
||||||
(void)error_code;
|
printIntDetails(intNbInt, RED, BLACK, 11, VGA_HEIGHT - 1); \
|
||||||
|
printIntDetails(error_code, RED, BLACK, 14, VGA_HEIGHT - 1); \
|
||||||
|
printf("Exception %d (Err %d) at 0x%x\n", int_nb, error_code, frame->eip); \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DEFINE_INTERRUPT(EXCEPTION_DOUBLE_FAULT)
|
||||||
// c.f. https://wiki.osdev.org/Paging#Handling
|
// c.f. https://wiki.osdev.org/Paging#Handling
|
||||||
// error_code bit0: Present ?
|
// error_code bit0: Present ?
|
||||||
// bit1: Trying to write ?
|
// bit1: Trying to write ?
|
||||||
|
@ -12,8 +12,14 @@ struct interrupt_frame {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Exception
|
// Exception
|
||||||
void print_handler(struct interrupt_frame *frame, ulong error_code);
|
// Exception
|
||||||
|
#define DECLARE_INTERRUPT(int_nb) \
|
||||||
|
void print_handler_##int_nb(struct interrupt_frame *frame, ulong error_code);
|
||||||
|
|
||||||
|
#define ACCESS_INTERRUPT(int_nb) print_handler_##int_nb
|
||||||
|
|
||||||
void pagefault_handler(struct interrupt_frame *frame, ulong error_code);
|
void pagefault_handler(struct interrupt_frame *frame, ulong error_code);
|
||||||
|
DECLARE_INTERRUPT(EXCEPTION_DOUBLE_FAULT)
|
||||||
|
|
||||||
// IRQ
|
// IRQ
|
||||||
void pit_handler(struct interrupt_frame *frame);
|
void pit_handler(struct interrupt_frame *frame);
|
||||||
|
@ -110,7 +110,7 @@ void kmain(unsigned long magic, unsigned long addr)
|
|||||||
irqSetRoutine(IRQ_KEYBOARD, keyboard_handler);
|
irqSetRoutine(IRQ_KEYBOARD, keyboard_handler);
|
||||||
|
|
||||||
printf("Enabling HW interrupts\n");
|
printf("Enabling HW interrupts\n");
|
||||||
exceptionSetRoutine(EXCEPTION_DOUBLE_FAULT, print_handler);
|
exceptionSetRoutine(EXCEPTION_DOUBLE_FAULT, ACCESS_INTERRUPT(EXCEPTION_DOUBLE_FAULT));
|
||||||
exceptionSetRoutine(EXCEPTION_PAGE_FAULT, pagefault_handler);
|
exceptionSetRoutine(EXCEPTION_PAGE_FAULT, pagefault_handler);
|
||||||
// Enabling the HW interrupts
|
// Enabling the HW interrupts
|
||||||
asm volatile("sti\n");
|
asm volatile("sti\n");
|
||||||
|
Loading…
Reference in New Issue
Block a user