diff --git a/crate/process/src/interrupt.rs b/crate/process/src/interrupt.rs index e0f2283..17d62ce 100644 --- a/crate/process/src/interrupt.rs +++ b/crate/process/src/interrupt.rs @@ -10,8 +10,8 @@ pub unsafe fn disable_and_store() -> usize { #[cfg(target_arch = "riscv32")] pub unsafe fn disable_and_store() -> usize { let sstatus: usize; - asm!("csrrci $0, 0x100, 1" : "=r"(sstatus)); - sstatus & 1 + asm!("csrrci $0, 0x100, 2" : "=r"(sstatus)); + sstatus & 2 } #[inline(always)] diff --git a/crate/process/src/processor.rs b/crate/process/src/processor.rs index ef617fe..d29d560 100644 --- a/crate/process/src/processor.rs +++ b/crate/process/src/processor.rs @@ -92,7 +92,10 @@ impl Processor { } pub fn tick(&self) { + let flags = unsafe { interrupt::disable_and_store() }; let need_reschedule = self.manager().tick(self.pid()); + unsafe { interrupt::restore(flags); } + if need_reschedule { self.yield_now(); } diff --git a/kernel/src/logging.rs b/kernel/src/logging.rs index 513e0c0..86bd1c2 100644 --- a/kernel/src/logging.rs +++ b/kernel/src/logging.rs @@ -1,6 +1,6 @@ use core::fmt; use log::{self, Level, LevelFilter, Log, Metadata, Record}; -use spin::Mutex; +use crate::sync::SpinNoIrqLock as Mutex; use lazy_static::lazy_static; lazy_static! {