|
|
@ -7,12 +7,8 @@ mod macros;
|
|
|
|
use core::{cmp, mem, ptr};
|
|
|
|
use core::{cmp, mem, ptr};
|
|
|
|
|
|
|
|
|
|
|
|
use aya_bpf::{
|
|
|
|
use aya_bpf::{
|
|
|
|
bindings::{bpf_map_def, bpf_map_type::BPF_MAP_TYPE_PERF_EVENT_ARRAY, BPF_F_CURRENT_CPU},
|
|
|
|
|
|
|
|
cty::c_long,
|
|
|
|
|
|
|
|
helpers::bpf_perf_event_output,
|
|
|
|
|
|
|
|
macros::map,
|
|
|
|
macros::map,
|
|
|
|
maps::PerCpuArray,
|
|
|
|
maps::{PerCpuArray, PerfEventByteArray},
|
|
|
|
BpfContext,
|
|
|
|
|
|
|
|
};
|
|
|
|
};
|
|
|
|
pub use aya_log_common::Level;
|
|
|
|
pub use aya_log_common::Level;
|
|
|
|
use aya_log_common::{RecordField, LOG_BUF_CAPACITY};
|
|
|
|
use aya_log_common::{RecordField, LOG_BUF_CAPACITY};
|
|
|
@ -29,7 +25,7 @@ pub static mut AYA_LOG_BUF: PerCpuArray<LogBuf> = PerCpuArray::with_max_entries(
|
|
|
|
|
|
|
|
|
|
|
|
#[doc(hidden)]
|
|
|
|
#[doc(hidden)]
|
|
|
|
#[map]
|
|
|
|
#[map]
|
|
|
|
pub static mut AYA_LOGS: LogEventArray = LogEventArray::with_max_entries(1024, 0);
|
|
|
|
pub static mut AYA_LOGS: PerfEventByteArray = PerfEventByteArray::with_max_entries(1024, 0);
|
|
|
|
|
|
|
|
|
|
|
|
#[doc(hidden)]
|
|
|
|
#[doc(hidden)]
|
|
|
|
pub struct LogBufWriter<'a> {
|
|
|
|
pub struct LogBufWriter<'a> {
|
|
|
@ -125,48 +121,3 @@ pub fn write_record_header(
|
|
|
|
|
|
|
|
|
|
|
|
Ok(size)
|
|
|
|
Ok(size)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[doc(hidden)]
|
|
|
|
|
|
|
|
#[repr(transparent)]
|
|
|
|
|
|
|
|
pub struct LogEventArray {
|
|
|
|
|
|
|
|
def: bpf_map_def,
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
impl LogEventArray {
|
|
|
|
|
|
|
|
const fn with_max_entries(max_entries: u32, flags: u32) -> LogEventArray {
|
|
|
|
|
|
|
|
LogEventArray {
|
|
|
|
|
|
|
|
def: bpf_map_def {
|
|
|
|
|
|
|
|
type_: BPF_MAP_TYPE_PERF_EVENT_ARRAY,
|
|
|
|
|
|
|
|
key_size: mem::size_of::<u32>() as u32,
|
|
|
|
|
|
|
|
value_size: mem::size_of::<u32>() as u32,
|
|
|
|
|
|
|
|
max_entries,
|
|
|
|
|
|
|
|
map_flags: flags,
|
|
|
|
|
|
|
|
id: 0,
|
|
|
|
|
|
|
|
pinning: 0,
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#[inline(always)]
|
|
|
|
|
|
|
|
pub fn output<C: BpfContext>(
|
|
|
|
|
|
|
|
&mut self,
|
|
|
|
|
|
|
|
ctx: &C,
|
|
|
|
|
|
|
|
buf: &mut LogBuf,
|
|
|
|
|
|
|
|
len: usize,
|
|
|
|
|
|
|
|
) -> Result<(), c_long> {
|
|
|
|
|
|
|
|
let ret = unsafe {
|
|
|
|
|
|
|
|
bpf_perf_event_output(
|
|
|
|
|
|
|
|
ctx.as_ptr(),
|
|
|
|
|
|
|
|
&mut self.def as *mut _ as *mut _,
|
|
|
|
|
|
|
|
BPF_F_CURRENT_CPU,
|
|
|
|
|
|
|
|
buf.buf.as_mut_ptr() as *mut _,
|
|
|
|
|
|
|
|
len as u64,
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
if ret < 0 {
|
|
|
|
|
|
|
|
Err(ret)
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
Ok(())
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|