pub struct SequentialProcessLoaderMachine<'a, C: Chip + 'static, D: ProcessStandardDebug + 'static> { /* private fields */ }
Expand description
A machine for loading processes stored sequentially in a region of flash.
Load processes (stored as TBF objects in flash) into runnable process
structures stored in the procs
array. This machine scans the footers in
the TBF for cryptographic credentials for binary integrity, passing them to
the checker to decide whether the process has sufficient credentials to run.
Implementations§
Source§impl<C: Chip, D: ProcessStandardDebug> SequentialProcessLoaderMachine<'_, C, D>
impl<C: Chip, D: ProcessStandardDebug> SequentialProcessLoaderMachine<'_, C, D>
Sourcepub fn new(
checker: &'static ProcessCheckerMachine,
procs: &'static mut [Option<&'static dyn Process>],
proc_binaries: &'static mut [Option<ProcessBinary>],
kernel: &'static Kernel,
chip: &'static C,
flash: &'static [u8],
app_memory: &'static mut [u8],
fault_policy: &'static dyn ProcessFaultPolicy,
storage_policy: &'static dyn ProcessStandardStoragePermissionsPolicy<C, D>,
policy: &'static dyn AppIdPolicy,
_capability_management: &dyn ProcessManagementCapability,
) -> Self
pub fn new( checker: &'static ProcessCheckerMachine, procs: &'static mut [Option<&'static dyn Process>], proc_binaries: &'static mut [Option<ProcessBinary>], kernel: &'static Kernel, chip: &'static C, flash: &'static [u8], app_memory: &'static mut [u8], fault_policy: &'static dyn ProcessFaultPolicy, storage_policy: &'static dyn ProcessStandardStoragePermissionsPolicy<C, D>, policy: &'static dyn AppIdPolicy, _capability_management: &dyn ProcessManagementCapability, ) -> Self
This function is made pub
so that board files can use it, but loading
processes from slices of flash an memory is fundamentally unsafe.
Therefore, we require the ProcessManagementCapability
to call this
function.
Trait Implementations§
Source§impl<C: Chip, D: ProcessStandardDebug> DeferredCallClient for SequentialProcessLoaderMachine<'_, C, D>
impl<C: Chip, D: ProcessStandardDebug> DeferredCallClient for SequentialProcessLoaderMachine<'_, C, D>
Source§impl<C: Chip, D: ProcessStandardDebug> ProcessCheckerMachineClient for SequentialProcessLoaderMachine<'_, C, D>
impl<C: Chip, D: ProcessStandardDebug> ProcessCheckerMachineClient for SequentialProcessLoaderMachine<'_, C, D>
Source§fn done(
&self,
process_binary: ProcessBinary,
result: Result<Option<AcceptedCredential>, ProcessCheckError>,
)
fn done( &self, process_binary: ProcessBinary, result: Result<Option<AcceptedCredential>, ProcessCheckError>, )
Check is finished, and the check result is in
result
.0 Read moreSource§impl<'a, C: Chip, D: ProcessStandardDebug> ProcessLoadingAsync<'a> for SequentialProcessLoaderMachine<'a, C, D>
impl<'a, C: Chip, D: ProcessStandardDebug> ProcessLoadingAsync<'a> for SequentialProcessLoaderMachine<'a, C, D>
Source§fn set_client(&self, client: &'a dyn ProcessLoadingAsyncClient)
fn set_client(&self, client: &'a dyn ProcessLoadingAsyncClient)
Set the client to receive callbacks about process loading and when
process loading has finished.
Source§fn set_policy(&self, policy: &'a dyn AppIdPolicy)
fn set_policy(&self, policy: &'a dyn AppIdPolicy)
Set the credential checking policy for the loader.
Auto Trait Implementations§
impl<'a, C, D> !Freeze for SequentialProcessLoaderMachine<'a, C, D>
impl<'a, C, D> !RefUnwindSafe for SequentialProcessLoaderMachine<'a, C, D>
impl<'a, C, D> !Send for SequentialProcessLoaderMachine<'a, C, D>
impl<'a, C, D> !Sync for SequentialProcessLoaderMachine<'a, C, D>
impl<'a, C, D> Unpin for SequentialProcessLoaderMachine<'a, C, D>
impl<'a, C, D> !UnwindSafe for SequentialProcessLoaderMachine<'a, C, D>
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