Struct capsules_core::alarm::AlarmDriver

source ·
pub struct AlarmDriver<'a, A: Alarm<'a>> { /* private fields */ }

Implementations§

source§

impl<'a, A: Alarm<'a>> AlarmDriver<'a, A>

source

pub const fn new( alarm: &'a A, grant: Grant<AlarmData, UpcallCount<NUM_UPCALLS>, AllowRoCount<0>, AllowRwCount<0>> ) -> AlarmDriver<'a, A>

Trait Implementations§

source§

impl<'a, A: Alarm<'a>> AlarmClient for AlarmDriver<'a, A>

source§

fn alarm(&self)

Callback indicating the alarm time has been reached. The alarm MUST be disabled when this is called. If a new alarm is needed, the client can call Alarm::set_alarm.
source§

impl<'a, A: Alarm<'a>> SyscallDriver for AlarmDriver<'a, A>

source§

fn command( &self, cmd_type: usize, data: usize, data2: usize, caller_id: ProcessId ) -> CommandReturn

Setup and read the alarm.

§command_num
  • 0: Driver existence check.
  • 1: Return the clock frequency in Hz.
  • 2: Read the current clock value
  • 3: Stop the alarm if it is outstanding
  • 4: Deprecated
  • 5: Set an alarm to fire at a given clock value time relative to now
  • 6: Set an alarm to fire at a given clock value time relative to a provided reference point.
source§

fn allocate_grant(&self, processid: ProcessId) -> Result<(), Error>

Request to allocate a capsule’s grant for a specific process. Read more
source§

fn allow_userspace_readable( &self, app: ProcessId, which: usize, slice: ReadWriteProcessBuffer ) -> Result<ReadWriteProcessBuffer, (ReadWriteProcessBuffer, ErrorCode)>

System call for a process to pass a buffer (a UserspaceReadableProcessBuffer) to the kernel that the kernel can either read or write. The kernel calls this method only after it checks that the entire buffer is within memory the process can both read and write. Read more

Auto Trait Implementations§

§

impl<'a, A> !Freeze for AlarmDriver<'a, A>

§

impl<'a, A> !RefUnwindSafe for AlarmDriver<'a, A>

§

impl<'a, A> !Send for AlarmDriver<'a, A>

§

impl<'a, A> !Sync for AlarmDriver<'a, A>

§

impl<'a, A> Unpin for AlarmDriver<'a, A>

§

impl<'a, A> !UnwindSafe for AlarmDriver<'a, A>

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.