aya/programs/lsm: pass Btf by reference instead of loading new Btf in Lsm::load

pull/85/head
William Findlay 3 years ago
parent 6539cbb555
commit 6b6d4af932
No known key found for this signature in database
GPG Key ID: 7162B44E9E560373

@ -32,16 +32,19 @@ use crate::{
/// # #[error(transparent)] /// # #[error(transparent)]
/// # LsmLoad(#[from] aya::programs::LsmLoadError), /// # LsmLoad(#[from] aya::programs::LsmLoadError),
/// # #[error(transparent)] /// # #[error(transparent)]
/// # BtfError(#[from] aya::BtfError),
/// # #[error(transparent)]
/// # Program(#[from] aya::programs::ProgramError), /// # Program(#[from] aya::programs::ProgramError),
/// # #[error(transparent)] /// # #[error(transparent)]
/// # Bpf(#[from] aya::BpfError), /// # Bpf(#[from] aya::BpfError),
/// # } /// # }
/// # let mut bpf = Bpf::load_file("ebpf_programs.o")?; /// # let mut bpf = Bpf::load_file("ebpf_programs.o")?;
/// use aya::{Bpf, programs::Lsm}; /// use aya::{Bpf, programs::Lsm, BtfError, Btf};
/// use std::convert::TryInto; /// use std::convert::TryInto;
/// ///
/// let btf = Btf::from_sys_fs()?;
/// let program: &mut Lsm = bpf.program_mut("lsm_prog")?.try_into()?; /// let program: &mut Lsm = bpf.program_mut("lsm_prog")?.try_into()?;
/// program.load("security_bprm_exec")?; /// program.load("security_bprm_exec", &btf)?;
/// program.attach()?; /// program.attach()?;
/// # Ok::<(), LsmError>(()) /// # Ok::<(), LsmError>(())
/// ``` /// ```
@ -72,8 +75,7 @@ impl Lsm {
/// ///
/// * `lsm_hook_name` - full name of the LSM hook that the program should /// * `lsm_hook_name` - full name of the LSM hook that the program should
/// be attached to /// be attached to
pub fn load(&mut self, lsm_hook_name: &str) -> Result<(), LsmLoadError> { pub fn load(&mut self, lsm_hook_name: &str, btf: &Btf) -> Result<(), LsmLoadError> {
let btf = &Btf::from_sys_fs()?;
self.data.expected_attach_type = Some(BPF_LSM_MAC); self.data.expected_attach_type = Some(BPF_LSM_MAC);
let type_name = format!("bpf_lsm_{}", lsm_hook_name); let type_name = format!("bpf_lsm_{}", lsm_hook_name);
self.data.attach_btf_id = self.data.attach_btf_id =

Loading…
Cancel
Save