|
|
@ -2,8 +2,9 @@ use libc::close;
|
|
|
|
use std::os::unix::io::RawFd;
|
|
|
|
use std::os::unix::io::RawFd;
|
|
|
|
|
|
|
|
|
|
|
|
use crate::{
|
|
|
|
use crate::{
|
|
|
|
sys::perf_event_ioctl, PERF_EVENT_IOC_DISABLE, PERF_EVENT_IOC_ENABLE, PERF_EVENT_IOC_SET_BPF,
|
|
|
|
programs::{probe::detach_debug_fs, ProbeKind},
|
|
|
|
programs::ProbeKind, programs::probe::detach_debug_fs
|
|
|
|
sys::perf_event_ioctl,
|
|
|
|
|
|
|
|
PERF_EVENT_IOC_DISABLE, PERF_EVENT_IOC_ENABLE, PERF_EVENT_IOC_SET_BPF,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
use super::{Link, LinkRef, ProgramData, ProgramError};
|
|
|
|
use super::{Link, LinkRef, ProgramData, ProgramError};
|
|
|
@ -62,20 +63,13 @@ pub(crate) fn perf_attach(data: &mut ProgramData, fd: RawFd) -> Result<LinkRef,
|
|
|
|
}))
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub(crate) fn perf_attach_debugfs(data: &mut ProgramData, fd: RawFd, probe_kind: ProbeKind, event_alias: String) -> Result<LinkRef, ProgramError> {
|
|
|
|
pub(crate) fn perf_attach_debugfs(
|
|
|
|
let prog_fd = data.fd_or_err()?;
|
|
|
|
data: &mut ProgramData,
|
|
|
|
perf_event_ioctl(fd, PERF_EVENT_IOC_SET_BPF, prog_fd).map_err(|(_, io_error)| {
|
|
|
|
fd: RawFd,
|
|
|
|
ProgramError::SyscallError {
|
|
|
|
probe_kind: ProbeKind,
|
|
|
|
call: "PERF_EVENT_IOC_SET_BPF".to_owned(),
|
|
|
|
event_alias: String,
|
|
|
|
io_error,
|
|
|
|
) -> Result<LinkRef, ProgramError> {
|
|
|
|
}
|
|
|
|
perf_attach(data, fd)?;
|
|
|
|
})?;
|
|
|
|
|
|
|
|
perf_event_ioctl(fd, PERF_EVENT_IOC_ENABLE, 0).map_err(|(_, io_error)| {
|
|
|
|
|
|
|
|
ProgramError::SyscallError {
|
|
|
|
|
|
|
|
call: "PERF_EVENT_IOC_ENABLE".to_owned(),
|
|
|
|
|
|
|
|
io_error,
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
})?;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Ok(data.link(PerfLink {
|
|
|
|
Ok(data.link(PerfLink {
|
|
|
|
perf_fd: Some(fd),
|
|
|
|
perf_fd: Some(fd),
|
|
|
|