aboutsummaryrefslogtreecommitdiff
path: root/examples/t-schedule.rs
diff options
context:
space:
mode:
authorbors[bot] <26634292+bors[bot]@users.noreply.github.com>2023-03-04 21:10:24 +0000
committerGitHub <noreply@github.com>2023-03-04 21:10:24 +0000
commit7c7d6558f6d9c50fbb4d2487c98c9a5be15f2f7b (patch)
tree80a47f0dc40059014e9448c4c2eb34c54dff45fe /examples/t-schedule.rs
parent1c5db277e4161470136dbd2a11e914ff1d383581 (diff)
parent98c5490d94950608d31cd5ad9dd260f2f853735c (diff)
Merge #694
694: RTIC 2 r=AfoHT a=korken89 Co-authored-by: Emil Fresk <emil.fresk@gmail.com> Co-authored-by: Per Lindgren <per.lindgren@ltu.se>
Diffstat (limited to 'examples/t-schedule.rs')
-rw-r--r--examples/t-schedule.rs137
1 files changed, 0 insertions, 137 deletions
diff --git a/examples/t-schedule.rs b/examples/t-schedule.rs
deleted file mode 100644
index f3979dd..0000000
--- a/examples/t-schedule.rs
+++ /dev/null
@@ -1,137 +0,0 @@
-//! [compile-pass] Check `schedule` code generation
-
-#![deny(unsafe_code)]
-#![deny(warnings)]
-#![deny(missing_docs)]
-#![no_main]
-#![no_std]
-
-use panic_semihosting as _;
-
-#[rtic::app(device = lm3s6965, dispatchers = [SSI0])]
-mod app {
- use cortex_m_semihosting::debug;
- use systick_monotonic::*;
-
- #[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 (SysTick rate in QEMU is 12 MHz)
- let mono = Systick::new(systick, 12_000_000);
-
- debug::exit(debug::EXIT_SUCCESS); // Exit QEMU simulator
-
- (Shared {}, Local {}, init::Monotonics(mono))
- }
-
- #[idle]
- fn idle(_: idle::Context) -> ! {
- // Task without message passing
-
- // Not default
- let _: Result<foo::MyMono::SpawnHandle, ()> =
- foo::MyMono::spawn_at(monotonics::MyMono::now());
- let handle: Result<foo::MyMono::SpawnHandle, ()> = foo::MyMono::spawn_after(1.secs());
- let _: Result<foo::MyMono::SpawnHandle, ()> = handle.unwrap().reschedule_after(1.secs());
-
- let handle: Result<foo::MyMono::SpawnHandle, ()> = foo::MyMono::spawn_after(1.secs());
- let _: Result<foo::MyMono::SpawnHandle, ()> =
- handle.unwrap().reschedule_at(monotonics::MyMono::now());
-
- let handle: Result<foo::MyMono::SpawnHandle, ()> = foo::MyMono::spawn_after(1.secs());
- let _: Result<(), ()> = handle.unwrap().cancel();
-
- // Using default
- let _: Result<foo::SpawnHandle, ()> = foo::spawn_at(monotonics::now());
- let handle: Result<foo::SpawnHandle, ()> = foo::spawn_after(1.secs());
- let _: Result<foo::SpawnHandle, ()> = handle.unwrap().reschedule_after(1.secs());
-
- let handle: Result<foo::SpawnHandle, ()> = foo::spawn_after(1.secs());
- let _: Result<foo::SpawnHandle, ()> =
- handle.unwrap().reschedule_at(monotonics::MyMono::now());
-
- let handle: Result<foo::SpawnHandle, ()> = foo::spawn_after(1.secs());
- let _: Result<(), ()> = handle.unwrap().cancel();
-
- // Task with single message passing
-
- // Not default
- let _: Result<bar::MyMono::SpawnHandle, u32> =
- bar::MyMono::spawn_at(monotonics::MyMono::now(), 0);
- let handle: Result<bar::MyMono::SpawnHandle, u32> = bar::MyMono::spawn_after(1.secs(), 1);
- let _: Result<bar::MyMono::SpawnHandle, ()> = handle.unwrap().reschedule_after(1.secs());
-
- let handle: Result<bar::MyMono::SpawnHandle, u32> = bar::MyMono::spawn_after(1.secs(), 1);
- let _: Result<bar::MyMono::SpawnHandle, ()> =
- handle.unwrap().reschedule_at(monotonics::MyMono::now());
-
- let handle: Result<bar::MyMono::SpawnHandle, u32> = bar::MyMono::spawn_after(1.secs(), 1);
- let _: Result<u32, ()> = handle.unwrap().cancel();
-
- // Using default
- let _: Result<bar::SpawnHandle, u32> = bar::spawn_at(monotonics::MyMono::now(), 0);
- let handle: Result<bar::SpawnHandle, u32> = bar::spawn_after(1.secs(), 1);
- let _: Result<bar::SpawnHandle, ()> = handle.unwrap().reschedule_after(1.secs());
-
- let handle: Result<bar::SpawnHandle, u32> = bar::spawn_after(1.secs(), 1);
- let _: Result<bar::SpawnHandle, ()> =
- handle.unwrap().reschedule_at(monotonics::MyMono::now());
-
- let handle: Result<bar::SpawnHandle, u32> = bar::spawn_after(1.secs(), 1);
- let _: Result<u32, ()> = handle.unwrap().cancel();
-
- // Task with multiple message passing
-
- // Not default
- let _: Result<baz::MyMono::SpawnHandle, (u32, u32)> =
- baz::MyMono::spawn_at(monotonics::MyMono::now(), 0, 1);
- let handle: Result<baz::MyMono::SpawnHandle, (u32, u32)> =
- baz::MyMono::spawn_after(1.secs(), 1, 2);
- let _: Result<baz::MyMono::SpawnHandle, ()> = handle.unwrap().reschedule_after(1.secs());
-
- let handle: Result<baz::MyMono::SpawnHandle, (u32, u32)> =
- baz::MyMono::spawn_after(1.secs(), 1, 2);
- let _: Result<baz::MyMono::SpawnHandle, ()> =
- handle.unwrap().reschedule_at(monotonics::MyMono::now());
-
- let handle: Result<baz::MyMono::SpawnHandle, (u32, u32)> =
- baz::MyMono::spawn_after(1.secs(), 1, 2);
- let _: Result<(u32, u32), ()> = handle.unwrap().cancel();
-
- // Using default
- let _: Result<baz::SpawnHandle, (u32, u32)> =
- baz::spawn_at(monotonics::MyMono::now(), 0, 1);
- let handle: Result<baz::SpawnHandle, (u32, u32)> = baz::spawn_after(1.secs(), 1, 2);
- let _: Result<baz::SpawnHandle, ()> = handle.unwrap().reschedule_after(1.secs());
-
- let handle: Result<baz::SpawnHandle, (u32, u32)> = baz::spawn_after(1.secs(), 1, 2);
- let _: Result<baz::SpawnHandle, ()> =
- handle.unwrap().reschedule_at(monotonics::MyMono::now());
-
- let handle: Result<baz::SpawnHandle, (u32, u32)> = baz::spawn_after(1.secs(), 1, 2);
- let _: Result<(u32, u32), ()> = handle.unwrap().cancel();
-
- loop {
- cortex_m::asm::nop();
- }
- }
-
- #[task]
- fn foo(_: foo::Context) {}
-
- #[task]
- fn bar(_: bar::Context, _x: u32) {}
-
- #[task]
- fn baz(_: baz::Context, _x: u32, _y: u32) {}
-}