Begin work for exceptions post

This commit is contained in:
Philipp Oppermann
2016-05-13 15:54:19 +02:00
parent 7c565abba8
commit 431bb39fdb
4 changed files with 96 additions and 0 deletions

26
src/interrupts/idt.rs Normal file
View File

@@ -0,0 +1,26 @@
use x86::irq::IdtEntry;
pub struct Idt([IdtEntry; 16]);
impl Idt {
pub fn new() -> Idt {
Idt([IdtEntry::missing(); 16])
}
pub fn set_handler(&mut self, entry: usize, handler: extern fn()->!) {
let ptr = handler as usize;
self.0[entry] = IdtEntry::interrupt_gate(0x8, ptr as *const _);
}
pub unsafe fn load(&self) {
use x86::dtables::{DescriptorTablePointer, lidt};
use core::mem::size_of;
let ptr = DescriptorTablePointer{
base: self as *const _ as u64,
limit: (size_of::<Self>() - 1) as u16,
};
lidt(&ptr);
}
}

41
src/interrupts/mod.rs Normal file
View File

@@ -0,0 +1,41 @@
mod idt;
lazy_static! {
static ref IDT: idt::Idt = {
let mut idt = idt::Idt::new();
idt.set_handler(0, divide_by_zero_handler);
idt.set_handler(8, double_fault_handler);
idt.set_handler(13, general_protection_fault_handler);
idt.set_handler(14, page_fault_handler);
idt
};
}
pub fn init() {
assert_has_not_been_called!();
unsafe { IDT.load() }
}
pub extern fn divide_by_zero_handler() -> ! {
println!("EXCEPTION: DIVIDE BY ZERO");
loop {}
}
pub extern fn double_fault_handler() -> ! {
println!("EXCEPTION: DOUBLE FAULT");
loop {}
}
pub extern fn general_protection_fault_handler() -> ! {
println!("EXCEPTION: GENERAL PROTECTION FAULT");
loop {}
}
pub extern fn page_fault_handler() -> ! {
println!("EXCEPTION: PAGE FAULT");
loop {}
}

View File

@@ -10,6 +10,7 @@
#![feature(lang_items)]
#![feature(const_fn, unique)]
#![feature(alloc, collections)]
#![feature(asm)]
#![no_std]
extern crate rlibc;
@@ -29,6 +30,7 @@ extern crate collections;
#[macro_use]
mod vga_buffer;
mod memory;
mod interrupts;
#[no_mangle]
pub extern "C" fn rust_main(multiboot_information_address: usize) {
@@ -50,6 +52,14 @@ pub extern "C" fn rust_main(multiboot_information_address: usize) {
format!("Some String");
}
interrupts::init();
unsafe { *(0xdeadbeaf as *mut u32) = 42};
unsafe {
asm!("xor eax, eax; idiv eax" :::: "intel");
}
println!("It did not crash!");
loop {}