|
|
@ -5,9 +5,8 @@ const RESULT_BUF_LEN: usize = 1024;
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
#[derive(Copy, Clone)]
|
|
|
|
#[repr(C)]
|
|
|
|
#[repr(C)]
|
|
|
|
struct TestResult {
|
|
|
|
struct TestResult {
|
|
|
|
did_error: u64,
|
|
|
|
|
|
|
|
len: usize,
|
|
|
|
|
|
|
|
buf: [u8; RESULT_BUF_LEN],
|
|
|
|
buf: [u8; RESULT_BUF_LEN],
|
|
|
|
|
|
|
|
len: Option<Result<usize, i64>>,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
unsafe impl aya::Pod for TestResult {}
|
|
|
|
unsafe impl aya::Pod for TestResult {}
|
|
|
@ -96,11 +95,12 @@ fn set_kernel_buffer_element(bpf: &mut Bpf, bytes: &[u8]) {
|
|
|
|
#[track_caller]
|
|
|
|
#[track_caller]
|
|
|
|
fn result_bytes(bpf: &Bpf) -> Vec<u8> {
|
|
|
|
fn result_bytes(bpf: &Bpf) -> Vec<u8> {
|
|
|
|
let m = Array::<_, TestResult>::try_from(bpf.map("RESULT").unwrap()).unwrap();
|
|
|
|
let m = Array::<_, TestResult>::try_from(bpf.map("RESULT").unwrap()).unwrap();
|
|
|
|
let result = m.get(&0, 0).unwrap();
|
|
|
|
let TestResult { buf, len } = m.get(&0, 0).unwrap();
|
|
|
|
assert_eq!(result.did_error, 0);
|
|
|
|
let len = len.unwrap();
|
|
|
|
|
|
|
|
let len = len.unwrap();
|
|
|
|
// assert that the buffer is always null terminated
|
|
|
|
// assert that the buffer is always null terminated
|
|
|
|
assert_eq!(result.buf[result.len], 0);
|
|
|
|
assert_eq!(buf[len], 0);
|
|
|
|
result.buf[..result.len].to_vec()
|
|
|
|
buf[..len].to_vec()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn load_and_attach_uprobe(prog_name: &str, func_name: &str, bytes: &[u8]) -> Bpf {
|
|
|
|
fn load_and_attach_uprobe(prog_name: &str, func_name: &str, bytes: &[u8]) -> Bpf {
|
|
|
|