From 6ab267bb9b0db4c4f37f27a5907c4cbe87c65531 Mon Sep 17 00:00:00 2001 From: Danila Fedorin Date: Tue, 23 Apr 2019 14:26:02 -0700 Subject: [PATCH] Add basic trap handlers --- kern/trap.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/kern/trap.c b/kern/trap.c index fc8252e..e7b6a1a 100644 --- a/kern/trap.c +++ b/kern/trap.c @@ -100,7 +100,7 @@ trap_init(void) SETGATE(idt[T_DIVIDE], 0, GD_KT, t_divide, 0); SETGATE(idt[T_DEBUG], 0, GD_KT, t_debug, 0); SETGATE(idt[T_NMI], 0, GD_KT, t_nmi, 0); - SETGATE(idt[T_BRKPT], 0, GD_KT, t_brkpt, 0); + SETGATE(idt[T_BRKPT], 0, GD_KT, t_brkpt, 3); SETGATE(idt[T_OFLOW], 0, GD_KT, t_oflow, 0); SETGATE(idt[T_BOUND], 0, GD_KT, t_bound, 0); SETGATE(idt[T_ILLOP], 0, GD_KT, t_illop, 0); @@ -196,6 +196,11 @@ trap_dispatch(struct Trapframe *tf) { // Handle processor exceptions. // LAB 3: Your code here. + if (tf->tf_trapno == T_PGFLT) { + page_fault_handler(tf); + } else if (tf->tf_trapno == T_BRKPT) { + monitor(tf); + } // Unexpected trap: The user process or the kernel has a bug. print_trapframe(tf);