diff options
| author | Emil Fresk <emil.fresk@gmail.com> | 2021-09-22 13:22:45 +0200 |
|---|---|---|
| committer | Emil Fresk <emil.fresk@gmail.com> | 2021-09-23 16:11:04 +0200 |
| commit | b71df58f2fb4ed85d4c8cf806d5837ce63c73f31 (patch) | |
| tree | de4cbe4b43d399d4dcf2021c33225ccd00627434 /book/en/src/by-example/app_idle.md | |
| parent | c8621d78b9b1c0c67dff31404ade873a9d7b426e (diff) | |
The great docs update
Diffstat (limited to 'book/en/src/by-example/app_idle.md')
| -rw-r--r-- | book/en/src/by-example/app_idle.md | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/book/en/src/by-example/app_idle.md b/book/en/src/by-example/app_idle.md new file mode 100644 index 0000000..1eb1472 --- /dev/null +++ b/book/en/src/by-example/app_idle.md @@ -0,0 +1,27 @@ +# The background task `#[idle]` + +A function marked with the `idle` attribute can optionally appear in the +module. This function is used as the special *idle task* and must have +signature `fn(idle::Context) -> !`. + +When present, the runtime will execute the `idle` task after `init`. Unlike +`init`, `idle` will run *with interrupts enabled* and it's not allowed to return +so it must run forever. + +When no `idle` function is declared, the runtime sets the [SLEEPONEXIT] bit and +then sends the microcontroller to sleep after running `init`. + +[SLEEPONEXIT]: https://developer.arm.com/docs/100737/0100/power-management/sleep-mode/sleep-on-exit-bit + +Like in `init`, locally declared resources will have `'static` lifetimes that are safe to access. + +The example below shows that `idle` runs after `init`. + +``` rust +{{#include ../../../../examples/idle.rs}} +``` + +``` console +$ cargo run --target thumbv7m-none-eabi --example idle +{{#include ../../../../ci/expected/idle.run}} +``` |
