Struct capsules_extra::sdcard::SDCardDriver

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

Application driver for SD Card capsule, layers on top of SD Card capsule This is used if the SDCard is going to be attached directly to userspace syscalls. SDCardDriver can be ignored if another capsule is going to build off of the SDCard instead

Implementations§

source§

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

Functions for SDCardDriver

source

pub fn new( sdcard: &'a SDCard<'a, A>, kernel_buf: &'static mut [u8; 512], grants: Grant<App, UpcallCount<1>, AllowRoCount<{ ro_allow::COUNT }>, AllowRwCount<{ rw_allow::COUNT }>>, ) -> SDCardDriver<'a, A>

Create new SD card userland interface

sdcard - SDCard interface to provide application access to kernel_buf - buffer used to hold SD card blocks, must be at least 512 bytes in length

Trait Implementations§

source§

impl<'a, A: Alarm<'a>> SDCardClient for SDCardDriver<'a, A>

Handle callbacks from SDCard

source§

fn card_detection_changed(&self, installed: bool)

source§

fn init_done(&self, block_size: u32, total_size: u64)

source§

fn read_done(&self, data: &'static mut [u8], len: usize)

source§

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

source§

fn error(&self, error: u32)

source§

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

Connections to userspace syscalls

source§

fn command( &self, command_num: usize, data: usize, _: usize, process_id: ProcessId, ) -> CommandReturn

System call for a process to perform a short synchronous operation or start a long-running split-phase operation (whose completion is signaled with an upcall). Command 0 is a reserved command to detect if a peripheral system call driver is installed and must always return a CommandReturn::success.
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 SDCardDriver<'a, A>

§

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

§

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

§

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

§

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

§

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

§

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.