rtic/examples/schedule.no_rs

65 lines
1.5 KiB
Text
Raw Normal View History

2018-11-03 17:02:41 +01:00
//! examples/schedule.rs
#![deny(unsafe_code)]
2018-11-03 17:02:41 +01:00
#![deny(warnings)]
#![no_main]
#![no_std]
2021-03-03 08:53:03 +01:00
use panic_semihosting as _;
2018-11-03 17:02:41 +01:00
2021-02-20 19:22:45 +01:00
#[rtic::app(device = lm3s6965, dispatchers = [SSI0])]
2020-05-19 20:00:13 +02:00
mod app {
2021-09-22 13:22:45 +02:00
use cortex_m_semihosting::{debug, hprintln};
2021-10-31 10:09:40 +01:00
use systick_monotonic::*;
2021-05-23 14:11:51 +02:00
#[monotonic(binds = SysTick, default = true)]
2021-09-22 13:22:45 +02:00
type MyMono = Systick<100>; // 100 Hz / 10 ms granularity
2020-10-15 18:50:17 +02:00
2021-07-07 22:50:59 +02:00
#[shared]
struct Shared {}
#[local]
struct Local {}
#[init]
fn init(cx: init::Context) -> (Shared, Local, init::Monotonics) {
let systick = cx.core.SYST;
// Initialize the monotonic (SysTick rate in QEMU is 12 MHz)
2021-09-22 13:22:45 +02:00
let mono = Systick::new(systick, 12_000_000);
2018-11-03 17:02:41 +01:00
2023-01-02 14:34:05 +01:00
hprintln!("init").ok();
2018-11-03 17:02:41 +01:00
// Schedule `foo` to run 1 second in the future
2021-10-31 10:09:40 +01:00
foo::spawn_after(1.secs()).unwrap();
2020-10-01 19:38:49 +02:00
2021-09-22 13:22:45 +02:00
(
Shared {},
Local {},
init::Monotonics(mono), // Give the monotonic to RTIC
)
2018-11-03 17:02:41 +01:00
}
#[task]
2019-04-21 20:10:40 +02:00
fn foo(_: foo::Context) {
2023-01-02 14:34:05 +01:00
hprintln!("foo").ok();
2021-09-22 13:22:45 +02:00
// Schedule `bar` to run 2 seconds in the future (1 second after foo runs)
2021-10-31 10:09:40 +01:00
bar::spawn_after(1.secs()).unwrap();
2018-11-03 17:02:41 +01:00
}
#[task]
2019-04-21 20:10:40 +02:00
fn bar(_: bar::Context) {
2023-01-02 14:34:05 +01:00
hprintln!("bar").ok();
2021-09-22 13:22:45 +02:00
// Schedule `baz` to run 1 seconds from now, but with a specific time instant.
2021-10-31 10:09:40 +01:00
baz::spawn_at(monotonics::now() + 1.secs()).unwrap();
2021-09-22 13:22:45 +02:00
}
#[task]
fn baz(_: baz::Context) {
2023-01-02 14:34:05 +01:00
hprintln!("baz").ok();
2021-09-22 13:22:45 +02:00
debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator
2018-11-03 17:02:41 +01:00
}
2020-04-22 12:58:14 +02:00
}