|
|
@ -118,7 +118,7 @@ pub(crate) struct BpfLoadProgramAttrs<'a> {
|
|
|
|
pub(crate) kernel_version: u32,
|
|
|
|
pub(crate) kernel_version: u32,
|
|
|
|
pub(crate) expected_attach_type: Option<bpf_attach_type>,
|
|
|
|
pub(crate) expected_attach_type: Option<bpf_attach_type>,
|
|
|
|
pub(crate) prog_btf_fd: Option<BorrowedFd<'a>>,
|
|
|
|
pub(crate) prog_btf_fd: Option<BorrowedFd<'a>>,
|
|
|
|
pub(crate) attach_btf_obj_fd: Option<u32>,
|
|
|
|
pub(crate) attach_btf_obj_fd: Option<BorrowedFd<'a>>,
|
|
|
|
pub(crate) attach_btf_id: Option<u32>,
|
|
|
|
pub(crate) attach_btf_id: Option<u32>,
|
|
|
|
pub(crate) attach_prog_fd: Option<RawFd>,
|
|
|
|
pub(crate) attach_prog_fd: Option<RawFd>,
|
|
|
|
pub(crate) func_info_rec_size: usize,
|
|
|
|
pub(crate) func_info_rec_size: usize,
|
|
|
@ -181,7 +181,7 @@ pub(crate) fn bpf_load_program(
|
|
|
|
u.log_size = log_buf.len() as u32;
|
|
|
|
u.log_size = log_buf.len() as u32;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if let Some(v) = aya_attr.attach_btf_obj_fd {
|
|
|
|
if let Some(v) = aya_attr.attach_btf_obj_fd {
|
|
|
|
u.__bindgen_anon_1.attach_btf_obj_fd = v;
|
|
|
|
u.__bindgen_anon_1.attach_btf_obj_fd = v.as_raw_fd() as _;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if let Some(v) = aya_attr.attach_prog_fd {
|
|
|
|
if let Some(v) = aya_attr.attach_prog_fd {
|
|
|
|
u.__bindgen_anon_1.attach_prog_fd = v as u32;
|
|
|
|
u.__bindgen_anon_1.attach_prog_fd = v as u32;
|
|
|
@ -539,10 +539,9 @@ pub(crate) fn bpf_link_get_info_by_fd(fd: BorrowedFd<'_>) -> Result<bpf_link_inf
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub(crate) fn btf_obj_get_info_by_fd(
|
|
|
|
pub(crate) fn btf_obj_get_info_by_fd(
|
|
|
|
fd: RawFd,
|
|
|
|
fd: BorrowedFd<'_>,
|
|
|
|
buf: &mut [u8],
|
|
|
|
buf: &mut [u8],
|
|
|
|
) -> Result<bpf_btf_info, SyscallError> {
|
|
|
|
) -> Result<bpf_btf_info, SyscallError> {
|
|
|
|
let fd = unsafe { BorrowedFd::borrow_raw(fd) };
|
|
|
|
|
|
|
|
bpf_obj_get_info_by_fd(fd, |info: &mut bpf_btf_info| {
|
|
|
|
bpf_obj_get_info_by_fd(fd, |info: &mut bpf_btf_info| {
|
|
|
|
info.btf = buf.as_mut_ptr() as _;
|
|
|
|
info.btf = buf.as_mut_ptr() as _;
|
|
|
|
info.btf_size = buf.len() as _;
|
|
|
|
info.btf_size = buf.len() as _;
|
|
|
@ -595,14 +594,18 @@ unsafe fn fd_sys_bpf(cmd: bpf_cmd, attr: &mut bpf_attr) -> SysResult<OwnedFd> {
|
|
|
|
Ok(OwnedFd::from_raw_fd(fd))
|
|
|
|
Ok(OwnedFd::from_raw_fd(fd))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub(crate) fn bpf_btf_get_fd_by_id(id: u32) -> Result<RawFd, io::Error> {
|
|
|
|
pub(crate) fn bpf_btf_get_fd_by_id(id: u32) -> Result<OwnedFd, SyscallError> {
|
|
|
|
let mut attr = unsafe { mem::zeroed::<bpf_attr>() };
|
|
|
|
let mut attr = unsafe { mem::zeroed::<bpf_attr>() };
|
|
|
|
attr.__bindgen_anon_6.__bindgen_anon_1.btf_id = id;
|
|
|
|
attr.__bindgen_anon_6.__bindgen_anon_1.btf_id = id;
|
|
|
|
|
|
|
|
|
|
|
|
match sys_bpf(bpf_cmd::BPF_BTF_GET_FD_BY_ID, &mut attr) {
|
|
|
|
// SAFETY: BPF_BTF_GET_FD_BY_ID returns a new file descriptor.
|
|
|
|
Ok(v) => Ok(v as RawFd),
|
|
|
|
unsafe { fd_sys_bpf(bpf_cmd::BPF_BTF_GET_FD_BY_ID, &mut attr) }.map_err(|(code, io_error)| {
|
|
|
|
Err((_, err)) => Err(err),
|
|
|
|
assert_eq!(code, -1);
|
|
|
|
|
|
|
|
SyscallError {
|
|
|
|
|
|
|
|
call: "bpf_btf_get_fd_by_id",
|
|
|
|
|
|
|
|
io_error,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub(crate) fn is_prog_name_supported() -> bool {
|
|
|
|
pub(crate) fn is_prog_name_supported() -> bool {
|
|
|
|