capsules_extra::nonvolatile_storage_driver

Struct NonvolatileStorage

Source
pub struct NonvolatileStorage<'a> { /* private fields */ }

Implementations§

Source§

impl<'a> NonvolatileStorage<'a>

Source

pub fn new( driver: &'a dyn NonvolatileStorage<'a>, grant: Grant<App, UpcallCount<{ upcall::COUNT }>, AllowRoCount<{ ro_allow::COUNT }>, AllowRwCount<{ rw_allow::COUNT }>>, userspace_start_address: usize, userspace_length: usize, kernel_start_address: usize, kernel_length: usize, buffer: &'static mut [u8], ) -> NonvolatileStorage<'a>

Trait Implementations§

Source§

impl<'a> NonvolatileStorage<'a> for NonvolatileStorage<'a>

Provide an interface for the kernel.

Source§

fn set_client(&self, client: &'a dyn NonvolatileStorageClient)

Source§

fn read( &self, buffer: &'static mut [u8], address: usize, length: usize, ) -> Result<(), ErrorCode>

Read length bytes starting at address address in to the provided buffer. The buffer must be at least length bytes long. The address must be in the address space of the physical storage.
Source§

fn write( &self, buffer: &'static mut [u8], address: usize, length: usize, ) -> Result<(), ErrorCode>

Write length bytes starting at address address from the provided buffer. The buffer must be at least length bytes long. This address must be in the address space of the physical storage.
Source§

impl NonvolatileStorageClient for NonvolatileStorage<'_>

This is the callback client for the underlying physical storage driver.

Source§

fn read_done(&self, buffer: &'static mut [u8], length: usize)

read_done is called when the implementor is finished reading in to the buffer. The callback returns the buffer and the number of bytes that were actually read.
Source§

fn write_done(&self, buffer: &'static mut [u8], length: usize)

write_done is called when the implementor is finished writing from the buffer. The callback returns the buffer and the number of bytes that were actually written.
Source§

impl SyscallDriver for NonvolatileStorage<'_>

Provide an interface for userland.

Source§

fn command( &self, command_num: usize, offset: usize, length: usize, processid: ProcessId, ) -> CommandReturn

Command interface.

Commands are selected by the lowest 8 bits of the first argument.

§command_num
  • 0: Return Ok(()) if this driver is included on the platform.
  • 1: Return the number of bytes available to userspace.
  • 2: Start a read from the nonvolatile storage.
  • 3: Start a write to the nonvolatile_storage.
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> !Freeze for NonvolatileStorage<'a>

§

impl<'a> !RefUnwindSafe for NonvolatileStorage<'a>

§

impl<'a> !Send for NonvolatileStorage<'a>

§

impl<'a> !Sync for NonvolatileStorage<'a>

§

impl<'a> Unpin for NonvolatileStorage<'a>

§

impl<'a> !UnwindSafe for NonvolatileStorage<'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.