mirror of
https://github.com/DragonOS-Community/DragonOS.git
synced 2025-06-08 18:26:48 +00:00
* feat(kprobe): Add basic kprobe support for x86_64 * feat: add ebpf support (#912) - 实现bpf()一部分命令,包括几种基本map,相关的helper函数 - 实现部分perf相关的数据结构 - 暂时为文件实现简单mmap - 实现一个使用kprobe统计syscall 调用次数的ebpf程序 对eBPF支持程度(基本): - 简单的eBPF程序(没有指定特殊的Map) - 使用内核已经实现的Map的eBPF程序 - 可以和kprobe配合使用 - 内核Map相关的接口定义已经实现,添加新的Map较为简单 不支持的功能: - 区分不同的eBPF程序类型(Network/Cgroup)并限定可调用的helper函数集 - 与内核其它跟踪机制配合(tracepoint) - 其它helper和Map todo - [ ] 修改mmap,需要讨论,因为这个和块缓存层相关 - [x] 添加文档 - [x] 修复可能的错误 - [x] 增加rbpf版本信息 * feat: add /sys/devices/system/cpu/possible file * feat: add /sys/devices/system/cpu/online
76 lines
1.7 KiB
Rust
76 lines
1.7 KiB
Rust
use crate::{ebpf::STACK_SIZE, vec, Vec};
|
|
|
|
pub struct StackFrame {
|
|
return_address: u16,
|
|
saved_registers: [u64; 4],
|
|
sp: u16,
|
|
frame: Vec<u8>,
|
|
}
|
|
|
|
impl StackFrame {
|
|
/// Create a new stack frame
|
|
///
|
|
/// The stack frame is created with a capacity of `STACK_SIZE` == 512 bytes
|
|
pub fn new() -> Self {
|
|
Self {
|
|
sp: 0,
|
|
return_address: 0,
|
|
saved_registers: [0; 4],
|
|
frame: vec![0; STACK_SIZE],
|
|
}
|
|
}
|
|
|
|
/// Create a new stack frame with a given capacity
|
|
#[allow(unused)]
|
|
pub fn with_capacity(capacity: usize) -> Self {
|
|
Self {
|
|
sp: 0,
|
|
return_address: 0,
|
|
saved_registers: [0; 4],
|
|
frame: vec![0; capacity],
|
|
}
|
|
}
|
|
|
|
/// The capacity of the stack frame
|
|
pub fn len(&self) -> usize {
|
|
self.frame.len()
|
|
}
|
|
|
|
pub fn as_ptr(&self) -> *const u8 {
|
|
self.frame.as_ptr()
|
|
}
|
|
|
|
pub fn as_slice(&self) -> &[u8] {
|
|
self.frame.as_slice()
|
|
}
|
|
/// Save the callee-saved registers
|
|
pub fn save_registers(&mut self, regs: &[u64]) {
|
|
self.saved_registers.copy_from_slice(regs);
|
|
}
|
|
|
|
/// Get the callee-saved registers
|
|
pub fn get_registers(&self) -> [u64; 4] {
|
|
self.saved_registers
|
|
}
|
|
|
|
/// Save the return address
|
|
pub fn save_return_address(&mut self, address: u16) {
|
|
self.return_address = address;
|
|
}
|
|
|
|
/// Get the return address
|
|
pub fn get_return_address(&self) -> u16 {
|
|
self.return_address
|
|
}
|
|
|
|
/// Save the stack pointer
|
|
pub fn save_sp(&mut self, sp: u16) {
|
|
self.sp = sp;
|
|
}
|
|
|
|
/// Get the stack pointer
|
|
pub fn get_sp(&self) -> u16 {
|
|
self.sp
|
|
}
|
|
}
|