aboutsummaryrefslogtreecommitdiff
path: root/examples/types.rs
diff options
context:
space:
mode:
authorGravatar Jorge Aparicio <jorge@japaric.io> 2019-09-15 17:09:40 +0000
committerGravatar GitHub <noreply@github.com> 2019-09-15 17:09:40 +0000
commit4ff28e9d13e845abf39c662643ae2ff5df57ec16 (patch)
tree7d9770cd357e584d85ef6ddc32bddd1a937d1020 /examples/types.rs
parentfafeeb27270ef24fc3852711c6032f65aa7dbcc0 (diff)
parent7aa270cb92180abfc9102a69efdde378c3396b5e (diff)
downloadrtic-4ff28e9d13e845abf39c662643ae2ff5df57ec16.tar.gz
rtic-4ff28e9d13e845abf39c662643ae2ff5df57ec16.tar.zst
rtic-4ff28e9d13e845abf39c662643ae2ff5df57ec16.zip
Merge pull request #205 from japaric/heterogeneous
rtfm-syntax refactor + heterogeneous multi-core support
Diffstat (limited to 'examples/types.rs')
-rw-r--r--examples/types.rs61
1 files changed, 32 insertions, 29 deletions
diff --git a/examples/types.rs b/examples/types.rs
index c3dd89ca..fc391d07 100644
--- a/examples/types.rs
+++ b/examples/types.rs
@@ -5,48 +5,51 @@
#![no_main]
#![no_std]
-extern crate panic_semihosting;
-
use cortex_m_semihosting::debug;
-use rtfm::{Exclusive, Instant};
+use panic_semihosting as _;
+use rtfm::cyccnt;
-#[rtfm::app(device = lm3s6965)]
+#[rtfm::app(device = lm3s6965, peripherals = true, monotonic = rtfm::cyccnt::CYCCNT)]
const APP: () = {
- static mut SHARED: u32 = 0;
+ struct Resources {
+ #[init(0)]
+ shared: u32,
+ }
#[init(schedule = [foo], spawn = [foo])]
- fn init(c: init::Context) {
- let _: Instant = c.start;
- let _: rtfm::Peripherals = c.core;
- let _: lm3s6965::Peripherals = c.device;
- let _: init::Schedule = c.schedule;
- let _: init::Spawn = c.spawn;
+ fn init(cx: init::Context) {
+ let _: cyccnt::Instant = cx.start;
+ let _: rtfm::Peripherals = cx.core;
+ let _: lm3s6965::Peripherals = cx.device;
+ let _: init::Schedule = cx.schedule;
+ let _: init::Spawn = cx.spawn;
debug::exit(debug::EXIT_SUCCESS);
}
- #[exception(schedule = [foo], spawn = [foo])]
- fn SVCall(c: SVCall::Context) {
- let _: Instant = c.start;
- let _: SVCall::Schedule = c.schedule;
- let _: SVCall::Spawn = c.spawn;
+ #[idle(schedule = [foo], spawn = [foo])]
+ fn idle(cx: idle::Context) -> ! {
+ let _: idle::Schedule = cx.schedule;
+ let _: idle::Spawn = cx.spawn;
+
+ loop {}
}
- #[interrupt(resources = [SHARED], schedule = [foo], spawn = [foo])]
- fn UART0(c: UART0::Context) {
- let _: Instant = c.start;
- let _: resources::SHARED = c.resources.SHARED;
- let _: UART0::Schedule = c.schedule;
- let _: UART0::Spawn = c.spawn;
+ #[task(binds = UART0, resources = [shared], schedule = [foo], spawn = [foo])]
+ fn uart0(cx: uart0::Context) {
+ let _: cyccnt::Instant = cx.start;
+ let _: resources::shared = cx.resources.shared;
+ let _: uart0::Schedule = cx.schedule;
+ let _: uart0::Spawn = cx.spawn;
}
- #[task(priority = 2, resources = [SHARED], schedule = [foo], spawn = [foo])]
- fn foo(c: foo::Context) {
- let _: Instant = c.scheduled;
- let _: Exclusive<u32> = c.resources.SHARED;
- let _: foo::Resources = c.resources;
- let _: foo::Schedule = c.schedule;
- let _: foo::Spawn = c.spawn;
+ #[task(priority = 2, resources = [shared], schedule = [foo], spawn = [foo])]
+ fn foo(cx: foo::Context) {
+ let _: cyccnt::Instant = cx.scheduled;
+ let _: &mut u32 = cx.resources.shared;
+ let _: foo::Resources = cx.resources;
+ let _: foo::Schedule = cx.schedule;
+ let _: foo::Spawn = cx.spawn;
}
extern "C" {