stack_trace.rs 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. use core::{cell::UnsafeCell, mem};
  2. use crate::{
  3. bindings::{bpf_map_def, bpf_map_type::BPF_MAP_TYPE_STACK_TRACE},
  4. helpers::bpf_get_stackid,
  5. maps::PinningType,
  6. EbpfContext,
  7. };
  8. #[repr(transparent)]
  9. pub struct StackTrace {
  10. def: UnsafeCell<bpf_map_def>,
  11. }
  12. unsafe impl Sync for StackTrace {}
  13. const PERF_MAX_STACK_DEPTH: u32 = 127;
  14. impl StackTrace {
  15. pub const fn with_max_entries(max_entries: u32, flags: u32) -> StackTrace {
  16. StackTrace {
  17. def: UnsafeCell::new(bpf_map_def {
  18. type_: BPF_MAP_TYPE_STACK_TRACE,
  19. key_size: mem::size_of::<u32>() as u32,
  20. value_size: mem::size_of::<u64>() as u32 * PERF_MAX_STACK_DEPTH,
  21. max_entries,
  22. map_flags: flags,
  23. id: 0,
  24. pinning: PinningType::None as u32,
  25. }),
  26. }
  27. }
  28. pub const fn pinned(max_entries: u32, flags: u32) -> StackTrace {
  29. StackTrace {
  30. def: UnsafeCell::new(bpf_map_def {
  31. type_: BPF_MAP_TYPE_STACK_TRACE,
  32. key_size: mem::size_of::<u32>() as u32,
  33. value_size: mem::size_of::<u64>() as u32 * PERF_MAX_STACK_DEPTH,
  34. max_entries,
  35. map_flags: flags,
  36. id: 0,
  37. pinning: PinningType::ByName as u32,
  38. }),
  39. }
  40. }
  41. pub unsafe fn get_stackid<C: EbpfContext>(&self, ctx: &C, flags: u64) -> Result<i64, i64> {
  42. let ret = bpf_get_stackid(ctx.as_ptr(), self.def.get() as *mut _, flags);
  43. if ret < 0 {
  44. Err(ret)
  45. } else {
  46. Ok(ret)
  47. }
  48. }
  49. }