mirror of
https://github.com/rtic-rs/rtic.git
synced 2025-01-10 03:09:03 +01:00
75 lines
1.9 KiB
Rust
75 lines
1.9 KiB
Rust
|
//! examples/cancel-reschedule.rs
|
||
|
|
||
|
#![deny(unsafe_code)]
|
||
|
#![deny(warnings)]
|
||
|
#![no_main]
|
||
|
#![no_std]
|
||
|
|
||
|
use panic_semihosting as _;
|
||
|
|
||
|
#[rtic::app(device = lm3s6965, dispatchers = [SSI0])]
|
||
|
mod app {
|
||
|
use cortex_m_semihosting::{debug, hprintln};
|
||
|
use rtic::time::duration::*;
|
||
|
use systick_monotonic::Systick;
|
||
|
|
||
|
#[monotonic(binds = SysTick, default = true)]
|
||
|
type MyMono = Systick<100>; // 100 Hz / 10 ms granularity
|
||
|
|
||
|
#[shared]
|
||
|
struct Shared {}
|
||
|
|
||
|
#[local]
|
||
|
struct Local {}
|
||
|
|
||
|
#[init]
|
||
|
fn init(cx: init::Context) -> (Shared, Local, init::Monotonics) {
|
||
|
let systick = cx.core.SYST;
|
||
|
|
||
|
// Initialize the monotonic
|
||
|
let mono = Systick::new(systick, 12_000_000);
|
||
|
|
||
|
hprintln!("init").ok();
|
||
|
|
||
|
// Schedule `foo` to run 1 second in the future
|
||
|
foo::spawn_after(1.seconds()).unwrap();
|
||
|
|
||
|
(
|
||
|
Shared {},
|
||
|
Local {},
|
||
|
init::Monotonics(mono), // Give the monotonic to RTIC
|
||
|
)
|
||
|
}
|
||
|
|
||
|
#[task]
|
||
|
fn foo(_: foo::Context) {
|
||
|
hprintln!("foo").ok();
|
||
|
|
||
|
// Schedule `bar` to run 2 seconds in the future (1 second after foo runs)
|
||
|
let spawn_handle = baz::spawn_after(2.seconds()).unwrap();
|
||
|
bar::spawn_after(1.seconds(), spawn_handle, false).unwrap(); // Change to true
|
||
|
}
|
||
|
|
||
|
#[task]
|
||
|
fn bar(_: bar::Context, baz_handle: baz::SpawnHandle, do_reschedule: bool) {
|
||
|
hprintln!("bar").ok();
|
||
|
|
||
|
if do_reschedule {
|
||
|
// Reschedule baz 2 seconds from now, instead of the original 1 second
|
||
|
// from now.
|
||
|
baz_handle.reschedule_after(2.seconds()).unwrap();
|
||
|
// Or baz_handle.reschedule_at(/* time */)
|
||
|
} else {
|
||
|
// Or cancel it
|
||
|
baz_handle.cancel().unwrap();
|
||
|
debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#[task]
|
||
|
fn baz(_: baz::Context) {
|
||
|
hprintln!("baz").ok();
|
||
|
debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator
|
||
|
}
|
||
|
}
|