pub struct NonvolatileStorage<'a> { /* private fields */ }
Implementations§
Source§impl<'a> NonvolatileStorage<'a>
impl<'a> NonvolatileStorage<'a>
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>
impl<'a> NonvolatileStorage<'a> for NonvolatileStorage<'a>
Provide an interface for the kernel.
fn set_client(&self, client: &'a dyn NonvolatileStorageClient)
Source§impl NonvolatileStorageClient for NonvolatileStorage<'_>
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)
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)
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<'_>
impl SyscallDriver for NonvolatileStorage<'_>
Provide an interface for userland.
Source§fn command(
&self,
command_num: usize,
offset: usize,
length: usize,
processid: ProcessId,
) -> CommandReturn
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>
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)>
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 moreAuto 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> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more