Struct capsules_extra::date_time::DateTimeCapsule
source · pub struct DateTimeCapsule<'a, DateTime: DateTime<'a>> { /* private fields */ }
Implementations§
source§impl<'a, DateTime: DateTime<'a>> DateTimeCapsule<'a, DateTime>
impl<'a, DateTime: DateTime<'a>> DateTimeCapsule<'a, DateTime>
pub fn new( date_time: &'a DateTime, grant: Grant<AppData, UpcallCount<1>, AllowRoCount<0>, AllowRwCount<0>>, ) -> DateTimeCapsule<'a, DateTime>
Trait Implementations§
source§impl<'a, DateTime: DateTime<'a>> DateTimeClient for DateTimeCapsule<'a, DateTime>
impl<'a, DateTime: DateTime<'a>> DateTimeClient for DateTimeCapsule<'a, DateTime>
source§fn get_date_time_done(&self, datetime: Result<DateTimeValues, ErrorCode>)
fn get_date_time_done(&self, datetime: Result<DateTimeValues, ErrorCode>)
Called when a date time reading has completed.
Takes
Ok(DateTime)
of current date and passes it when scheduling an upcall.
If an error is encountered it takes an Err(ErrorCode)
source§impl<'a, DateTime: DateTime<'a>> SyscallDriver for DateTimeCapsule<'a, DateTime>
impl<'a, DateTime: DateTime<'a>> SyscallDriver for DateTimeCapsule<'a, DateTime>
source§fn command(
&self,
command_number: usize,
r2: usize,
r3: usize,
process_id: ProcessId,
) -> CommandReturn
fn command( &self, command_number: usize, r2: usize, r3: 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>
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, DateTime> !Freeze for DateTimeCapsule<'a, DateTime>
impl<'a, DateTime> !RefUnwindSafe for DateTimeCapsule<'a, DateTime>
impl<'a, DateTime> !Send for DateTimeCapsule<'a, DateTime>
impl<'a, DateTime> !Sync for DateTimeCapsule<'a, DateTime>
impl<'a, DateTime> Unpin for DateTimeCapsule<'a, DateTime>
impl<'a, DateTime> !UnwindSafe for DateTimeCapsule<'a, DateTime>
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