21 releases
0.10.0 | Jul 12, 2024 |
---|---|
0.9.0 | Feb 27, 2022 |
0.8.0 | Jul 26, 2021 |
0.7.0 | Feb 13, 2021 |
0.1.4 | Mar 24, 2020 |
#351 in Embedded development
2,321 downloads per month
66KB
2K
SLoC
TrapFrame-rs
Handle Trap Frame across kernel and user space on multiple ISAs.
Supported ISA: x86_64, aarch64, riscv32, riscv64, mipsel
Example
Go to user space
use trapframe::{UserContext, GeneralRegs};
fn kernel_thread() {
// initialize trap handling
unsafe {
trapframe::init();
}
// construct a user space context, set registers
let mut context = UserContext {
general: GeneralRegs {
rip: 0x1000,
rsp: 0x10000,
..Default::default()
},
..Default::default()
};
// go to user space with the context
context.run();
// come back from user space, maybe syscall or trap
println!("back from user: {:#x?}", context);
// check the context and handle the trap
match context.trap_num {
0x3 => println!("breakpoint"),
0xd => println!("general protection fault"),
0x100 => println!("syscall: id={}", context.general.rax),
...
}
}
Handle kernel trap
use trapframe::TrapFrame;
#[no_mangle] // export a function 'trap_handler'
extern "sysv64" fn trap_handler(tf: &mut TrapFrame) {
match tf.trap_num {
0x3 => {
println!("TRAP: Breakpoint");
tf.rip += 1;
}
_ => panic!("TRAP: {:#x?}", tf),
}
}
More examples
Internal
Control flow on x86_64:
Dependencies
~1MB
~20K SLoC