kernel::grant

Struct Grant

Source
pub struct Grant<T: Default, Upcalls: UpcallSize, AllowROs: AllowRoSize, AllowRWs: AllowRwSize> { /* private fields */ }
Expand description

Type for storing an object of type T in process memory that is only accessible by the kernel.

A single Grant can allocate space for one object of type T for each process on the board. Each allocated object will reside in the grant region belonging to the process that the object is allocated for. The Grant type is used to get access to ProcessGrants, which are tied to a specific process and provide access to the memory object allocated for that process.

Implementations§

Source§

impl<T: Default, Upcalls: UpcallSize, AllowROs: AllowRoSize, AllowRWs: AllowRwSize> Grant<T, Upcalls, AllowROs, AllowRWs>

Source

pub fn enter<F, R>(&self, processid: ProcessId, fun: F) -> Result<R, Error>
where F: FnOnce(&mut GrantData<'_, T>, &GrantKernelData<'_>) -> R,

Enter the grant for a specific process.

This creates a ProcessGrant which is a handle for a grant allocated for a specific process. Then, that ProcessGrant is entered and the provided closure is run with access to the memory in the grant region.

Source

pub fn enter_with_allocator<F, R>( &self, processid: ProcessId, fun: F, ) -> Result<R, Error>
where F: FnOnce(&mut GrantData<'_, T>, &GrantKernelData<'_>, &mut GrantRegionAllocator) -> R,

Enter the grant for a specific process with access to an allocator.

This creates an ProcessGrant which is a handle for a grant allocated for a specific process. Then, that ProcessGrant is entered and the provided closure is run with access to the memory in the grant region.

The allocator allows the caller to dynamically allocate additional memory in the process’s grant region.

Source

pub fn each<F>(&self, fun: F)
where F: FnMut(ProcessId, &mut GrantData<'_, T>, &GrantKernelData<'_>),

Run a function on the grant for each active process if the grant has been allocated for that process.

This will silently skip any process where the grant has not previously been allocated. This will also silently skip any invalid processes.

Calling this function when an ProcessGrant for a process is currently entered will result in a panic.

Source

pub fn iter(&self) -> Iter<'_, T, Upcalls, AllowROs, AllowRWs>

Get an iterator over all processes and their active grant regions for this particular grant.

Calling this function when an ProcessGrant for a process is currently entered will result in a panic.

Auto Trait Implementations§

§

impl<T, Upcalls, AllowROs, AllowRWs> Freeze for Grant<T, Upcalls, AllowROs, AllowRWs>

§

impl<T, Upcalls, AllowROs, AllowRWs> !RefUnwindSafe for Grant<T, Upcalls, AllowROs, AllowRWs>

§

impl<T, Upcalls, AllowROs, AllowRWs> !Send for Grant<T, Upcalls, AllowROs, AllowRWs>

§

impl<T, Upcalls, AllowROs, AllowRWs> !Sync for Grant<T, Upcalls, AllowROs, AllowRWs>

§

impl<T, Upcalls, AllowROs, AllowRWs> Unpin for Grant<T, Upcalls, AllowROs, AllowRWs>
where T: Unpin, Upcalls: Unpin, AllowROs: Unpin, AllowRWs: Unpin,

§

impl<T, Upcalls, AllowROs, AllowRWs> !UnwindSafe for Grant<T, Upcalls, AllowROs, AllowRWs>

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