|
|
@ -22,6 +22,8 @@ pub fn init() {
|
|
|
|
stvec::write(__alltraps as usize, stvec::TrapMode::Direct);
|
|
|
|
stvec::write(__alltraps as usize, stvec::TrapMode::Direct);
|
|
|
|
// Enable IPI
|
|
|
|
// Enable IPI
|
|
|
|
sie::set_ssoft();
|
|
|
|
sie::set_ssoft();
|
|
|
|
|
|
|
|
// Enable serial interrupt
|
|
|
|
|
|
|
|
sie::set_sext();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
info!("interrupt: init end");
|
|
|
|
info!("interrupt: init end");
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -72,6 +74,7 @@ pub extern fn rust_trap(tf: &mut TrapFrame) {
|
|
|
|
use super::riscv::register::scause::{Trap, Interrupt as I, Exception as E};
|
|
|
|
use super::riscv::register::scause::{Trap, Interrupt as I, Exception as E};
|
|
|
|
trace!("Interrupt: {:?}", tf.scause.cause());
|
|
|
|
trace!("Interrupt: {:?}", tf.scause.cause());
|
|
|
|
match tf.scause.cause() {
|
|
|
|
match tf.scause.cause() {
|
|
|
|
|
|
|
|
Trap::Interrupt(I::SupervisorExternal) => serial(),
|
|
|
|
Trap::Interrupt(I::SupervisorTimer) => timer(),
|
|
|
|
Trap::Interrupt(I::SupervisorTimer) => timer(),
|
|
|
|
Trap::Exception(E::IllegalInstruction) => illegal_inst(tf),
|
|
|
|
Trap::Exception(E::IllegalInstruction) => illegal_inst(tf),
|
|
|
|
Trap::Exception(E::UserEnvCall) => syscall(tf),
|
|
|
|
Trap::Exception(E::UserEnvCall) => syscall(tf),
|
|
|
@ -83,6 +86,10 @@ pub extern fn rust_trap(tf: &mut TrapFrame) {
|
|
|
|
trace!("Interrupt end");
|
|
|
|
trace!("Interrupt end");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fn serial() {
|
|
|
|
|
|
|
|
::trap::serial(super::io::getchar());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn ipi() {
|
|
|
|
fn ipi() {
|
|
|
|
debug!("IPI");
|
|
|
|
debug!("IPI");
|
|
|
|
super::bbl::sbi::clear_ipi();
|
|
|
|
super::bbl::sbi::clear_ipi();
|
|
|
|