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
34 lines
1.1 KiB
Rust
34 lines
1.1 KiB
Rust
use crate::arch::interrupt::TrapFrame;
|
|
use crate::arch::kprobe::clear_single_step;
|
|
use crate::debug::kprobe::KPROBE_MANAGER;
|
|
use kprobe::{KprobeOps, ProbeArgs};
|
|
use log::debug;
|
|
use system_error::SystemError;
|
|
|
|
#[derive(Debug)]
|
|
pub struct DebugException;
|
|
|
|
impl DebugException {
|
|
pub fn handle(frame: &mut TrapFrame) -> Result<(), SystemError> {
|
|
Self::post_kprobe_handler(frame)
|
|
}
|
|
|
|
fn post_kprobe_handler(frame: &mut TrapFrame) -> Result<(), SystemError> {
|
|
let pc = frame.debug_address();
|
|
if let Some(kprobe_list) = KPROBE_MANAGER.lock().get_debug_list(pc) {
|
|
for kprobe in kprobe_list {
|
|
let guard = kprobe.read();
|
|
if guard.is_enabled() {
|
|
guard.call_post_handler(frame);
|
|
guard.call_event_callback(frame);
|
|
}
|
|
}
|
|
let return_address = kprobe_list[0].read().probe_point().return_address();
|
|
clear_single_step(frame, return_address);
|
|
} else {
|
|
debug!("There is no kprobe on pc {:#x}", pc);
|
|
}
|
|
Ok(())
|
|
}
|
|
}
|