Struct kernel::process_checker::basic::AppIdAssignerNames

source ·
pub struct AppIdAssignerNames<'a, F: Fn(&'static str) -> u32> { /* private fields */ }
Expand description

A sample AppID Assignment tool that assigns pseudo-unique AppIDs and ShortIds based on the process name.

ShortIds are assigned as a non-secure hash of the process name.

§Usage

let assigner = static_init!(
    kernel::process_checker::basic::AppIdAssignerNames<fn(&'static str) -> u32>,
    kernel::process_checker::basic::AppIdAssignerNames::new(
        &((|s| { kernel::utilities::helpers::crc32_posix(s.as_bytes()) })
        as fn(&'static str) -> u32)
    )
);

Implementations§

source§

impl<'a, F: Fn(&'static str) -> u32> AppIdAssignerNames<'a, F>

source

pub fn new(hasher: &'a F) -> Self

Trait Implementations§

source§

impl<'a, F: Fn(&'static str) -> u32> AppUniqueness for AppIdAssignerNames<'a, F>

source§

fn different_identifier( &self, process_a: &ProcessBinary, process_b: &ProcessBinary ) -> bool

Returns whether process_a and process_b have a different identifier, and so can run concurrently. If this returns false, the kernel will not run process_a and process_b at the same time.
source§

fn different_identifier_process( &self, process_a: &ProcessBinary, process_b: &dyn Process ) -> bool

Returns whether process_a and process_b have a different identifier, and so can run concurrently. If this returns false, the kernel will not run process_a and process_b at the same time.
source§

fn different_identifier_processes( &self, process_a: &dyn Process, process_b: &dyn Process ) -> bool

Returns whether process_a and process_b have a different identifier, and so can run concurrently. If this returns false, the kernel will not run process_a and process_b at the same time.
source§

impl<'a, F: Fn(&'static str) -> u32> Compress for AppIdAssignerNames<'a, F>

source§

fn to_short_id(&self, process: &ProcessBinary) -> ShortId

Create a ShortId for process.

Auto Trait Implementations§

§

impl<'a, F> Freeze for AppIdAssignerNames<'a, F>

§

impl<'a, F> RefUnwindSafe for AppIdAssignerNames<'a, F>
where F: RefUnwindSafe,

§

impl<'a, F> Send for AppIdAssignerNames<'a, F>
where F: Sync,

§

impl<'a, F> Sync for AppIdAssignerNames<'a, F>
where F: Sync,

§

impl<'a, F> Unpin for AppIdAssignerNames<'a, F>

§

impl<'a, F> UnwindSafe for AppIdAssignerNames<'a, F>
where F: RefUnwindSafe,

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> 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> SizedTypeProperties for T

source§

#[doc(hidden)] const IS_ZST: bool = _

🔬This is a nightly-only experimental API. (sized_type_properties)
true if this type requires no storage. false if its size is greater than zero. Read more
source§

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

§

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>,

§

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.
source§

impl<T> AppIdPolicy for T