Embassy
embassy-executor

Crates

git

Versions

cortex-m

Flavors

pub struct Executor { /* private fields */ }
Expand description

Thread mode executor, using WFE/SEV.

This is the simplest and most common kind of executor. It runs on thread mode (at the lowest priority level), and uses the WFE ARM instruction to sleep when it has no more work to do. When a task is woken, a SEV instruction is executed, to make the WFE exit from sleep and poll the task.

This executor allows for ultra low power consumption for chips where WFE triggers low-power sleep without extra steps. If your chip requires extra steps, you may use raw::Executor directly to program custom behavior.

Implementations§

source§

impl Executor

source

pub fn new() -> Self

Create a new Executor.

source

pub fn run(&'static mut self, init: impl FnOnce(Spawner)) -> !

Run the executor.

The init closure is called with a Spawner that spawns tasks on this executor. Use it to spawn the initial task(s). After init returns, the executor starts running the tasks.

To spawn more tasks later, you may keep copies of the Spawner (it is Copy), for example by passing it as an argument to the initial tasks.

This function requires &'static mut self. This means you have to store the Executor instance in a place where it’ll live forever and grants you mutable access. There’s a few ways to do this:

  • a StaticCell (safe)
  • a static mut (unsafe)
  • a local variable in a function you know never returns (like fn main() -> !), upgrading its lifetime with transmute. (unsafe)

This function never returns.

Auto Trait Implementations§

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.