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]
|
2020-11-20 01:18:25 +08:00
|
|
|
pub x: [usize; 32],
|
2022-03-25 16:45:39 +08:00
|
|
|
/// CSR sstatus
|
2020-11-20 01:18:25 +08:00
|
|
|
pub sstatus: Sstatus,
|
2022-03-25 16:45:39 +08:00
|
|
|
/// CSR sepc
|
2020-11-20 01:18:25 +08:00
|
|
|
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
|
|
|
}
|
|
|
|
}
|