capsules_core::console_ordered

Struct ConsoleOrdered

Source
pub struct ConsoleOrdered<'a, A: Alarm<'a>> { /* private fields */ }

Implementations§

Source§

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

Source

pub fn new( uart: &'a dyn Receive<'a>, alarm: &'a A, rx_buffer: &'static mut [u8], grant: Grant<App, UpcallCount<3>, AllowRoCount<{ ro_allow::COUNT }>, AllowRwCount<{ rw_allow::COUNT }>>, atomic_size: usize, retry_timer: u32, write_timer: u32, ) -> ConsoleOrdered<'a, A>

Trait Implementations§

Source§

impl<'a, A: Alarm<'a>> AlarmClient for ConsoleOrdered<'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>> ReceiveClient for ConsoleOrdered<'a, A>

Source§

fn received_buffer( &self, buffer: &'static mut [u8], rx_len: usize, rcode: Result<(), ErrorCode>, error: Error, )

A call to Receive::receive_buffer completed. Read more
Source§

fn received_word(&self, _word: u32, _rval: Result<(), ErrorCode>, _error: Error)

A call to Receive::receive_word completed. Read more
Source§

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

Source§

fn command( &self, cmd_num: usize, arg1: usize, _: usize, appid: ProcessId, ) -> CommandReturn

Setup shared buffers.

§allow_num
  • 0: Readonly buffer for write buffer Initiate serial transfers
§command_num
  • 0: Driver existence check.
  • 1: Transmits a buffer passed via allow, up to the length passed in arg1
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 ConsoleOrdered<'a, A>

§

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

§

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

§

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

§

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

§

impl<'a, A> !UnwindSafe for ConsoleOrdered<'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, 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.