rcore-tutorial/os/src/trap/context.rs

31 lines
841 B
Rust
Raw Normal View History

2022-01-21 14:21:32 -08:00
use riscv::register::sstatus::{self, Sstatus, SPP};
2022-03-25 16:45:39 +08:00
/// Trap Context
2020-11-19 18:01:16 +08:00
#[repr(C)]
pub struct TrapContext {
2022-03-25 16:45:39 +08:00
/// general regs[0..31]
pub x: [usize; 32],
2022-03-25 16:45:39 +08:00
/// CSR sstatus
pub sstatus: Sstatus,
2022-03-25 16:45:39 +08:00
/// CSR sepc
pub sepc: usize,
2020-11-19 18:01:16 +08:00
}
impl TrapContext {
2022-03-25 16:45:39 +08:00
/// set stack pointer to x_2 reg (sp)
2022-01-21 14:21:32 -08:00
pub fn set_sp(&mut self, sp: usize) {
self.x[2] = sp;
}
2022-03-25 16:45:39 +08:00
/// init app context
2020-11-19 18:01:16 +08:00
pub fn app_init_context(entry: usize, sp: usize) -> Self {
2022-03-25 16:45:39 +08:00
let mut sstatus = sstatus::read(); // CSR sstatus
sstatus.set_spp(SPP::User); //previous privilege mode: user mode
2020-11-19 18:01:16 +08:00
let mut cx = Self {
x: [0; 32],
sstatus,
2022-03-25 16:45:39 +08:00
sepc: entry, // entry point of app
2020-11-19 18:01:16 +08:00
};
2022-03-25 16:45:39 +08:00
cx.set_sp(sp); // app's user stack pointer
cx // return initial Trap Context of app
2020-11-19 18:01:16 +08:00
}
}