Type Alias IsolatedNonvolatileStorageComponentType

Source
pub type IsolatedNonvolatileStorageComponentType<const APP_REGION_SIZE: usize> = IsolatedNonvolatileStorage<'static, APP_REGION_SIZE>;

Aliased Type§

struct IsolatedNonvolatileStorageComponentType<const APP_REGION_SIZE: usize> { /* private fields */ }

Implementations

Source§

impl<'a, const APP_REGION_SIZE: usize> IsolatedNonvolatileStorage<'a, APP_REGION_SIZE>

Source

pub fn new( driver: &'a dyn NonvolatileStorage<'a>, grant: Grant<App, UpcallCount<capsules_extra::::isolated_nonvolatile_storage_driver::{impl#2}::new::{constant#0}>, AllowRoCount<capsules_extra::::isolated_nonvolatile_storage_driver::{impl#2}::new::{constant#1}>, AllowRwCount<capsules_extra::::isolated_nonvolatile_storage_driver::{impl#2}::new::{constant#2}>>, userspace_start_address: usize, userspace_length: usize, buffer: &'static mut [u8], ) -> IsolatedNonvolatileStorage<'a, APP_REGION_SIZE>

Trait Implementations

Source§

impl<const APP_REGION_SIZE: usize> NonvolatileStorageClient for IsolatedNonvolatileStorage<'_, APP_REGION_SIZE>

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<const APP_REGION_SIZE: usize> SyscallDriver for IsolatedNonvolatileStorage<'_, APP_REGION_SIZE>

Provide an interface for userland.

Source§

fn command( &self, command_num: usize, offset_lo: usize, offset_hi: 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 each app.
  • 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