Enum DsoKey

Source
pub enum DsoKey {
    Kernel,
    GuestKernel,
    Vdso32,
    VdsoX32,
    Vdso64,
    Vsyscall,
    KernelModule {
        name: String,
    },
    User {
        file_name: String,
        full_path: Vec<u8>,
    },
}
Expand description

A canonicalized key which can be used to cross-reference an Mmap record with an entry in the perf file’s build ID list.

This is needed because the entries sometimes don’t have matching path strings.

Examples:

  • Mmap path “[kernel.kallsyms]_text” + build ID map entry path “[kernel.kallsyms]”
  • Mmap path “[kernel.kallsyms]_text” + build ID map entry path “/full/path/to/vmlinux”

Variants§

§

Kernel

§

GuestKernel

§

Vdso32

§

VdsoX32

§

Vdso64

§

Vsyscall

§

KernelModule

Fields

§name: String

The name of the kernel module, without file extension, e.g. “snd-seq-device”.

We don’t store the full path in the key because the name is enough to uniquely identify the kernel module.

§

User

Fields

§file_name: String

The file name of the user-space DSO.

§full_path: Vec<u8>

The full path of the user-space DSO. This must be part of the key because there could be multiple DSOs with the same file name at different paths.

Implementations§

Source§

impl DsoKey

Source

pub fn detect(path: &[u8], cpu_mode: CpuMode) -> Option<Self>

Make a DsoKey from a path and a CpuMode (which usually comes from a misc field).

Returns None for things which cannot be detected as a DSO, such as //anon mappings.

Source

pub fn name(&self) -> &str

The name string for this DSO. This is a short string that you’d want to see in a profiler UI, for example.

Trait Implementations§

Source§

impl Clone for DsoKey

Source§

fn clone(&self) -> DsoKey

Returns a duplicate of the value. Read more
1.0.0 · Source§

const fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for DsoKey

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Hash for DsoKey

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for DsoKey

Source§

fn eq(&self, other: &DsoKey) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

const fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for DsoKey

Source§

impl StructuralPartialEq for DsoKey

Auto Trait Implementations§

§

impl Freeze for DsoKey

§

impl RefUnwindSafe for DsoKey

§

impl Send for DsoKey

§

impl Sync for DsoKey

§

impl Unpin for DsoKey

§

impl UnwindSafe for DsoKey

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.