aboutsummaryrefslogtreecommitdiff
path: root/examples/hardware.rs
diff options
context:
space:
mode:
Diffstat (limited to 'examples/hardware.rs')
-rw-r--r--examples/hardware.rs61
1 files changed, 61 insertions, 0 deletions
diff --git a/examples/hardware.rs b/examples/hardware.rs
new file mode 100644
index 00000000..b8060021
--- /dev/null
+++ b/examples/hardware.rs
@@ -0,0 +1,61 @@
+//! examples/hardware.rs
+
+#![deny(unsafe_code)]
+#![deny(warnings)]
+#![no_main]
+#![no_std]
+
+use panic_semihosting as _;
+
+#[rtic::app(device = lm3s6965)]
+mod app {
+ use cortex_m_semihosting::{debug, hprintln};
+ use lm3s6965::Interrupt;
+
+ #[resources]
+ struct Resources {
+ #[task_local]
+ #[init(0)]
+ times: u32,
+ }
+
+ #[init]
+ fn init(_: init::Context) -> (init::LateResources, init::Monotonics) {
+ // Pends the UART0 interrupt but its handler won't run until *after*
+ // `init` returns because interrupts are disabled
+ rtic::pend(Interrupt::UART0); // equivalent to NVIC::pend
+
+ hprintln!("init").unwrap();
+
+ (init::LateResources {}, init::Monotonics())
+ }
+
+ #[idle]
+ fn idle(_: idle::Context) -> ! {
+ // interrupts are enabled again; the `UART0` handler runs at this point
+
+ hprintln!("idle").unwrap();
+
+ rtic::pend(Interrupt::UART0);
+
+ debug::exit(debug::EXIT_SUCCESS);
+
+ loop {
+ cortex_m::asm::nop();
+ }
+ }
+
+ #[task(binds = UART0, resources = [times])]
+ fn uart0(cx: uart0::Context) {
+ let times = cx.resources.times;
+ // Safe access to local `static mut` variable
+ *times += 1;
+
+ hprintln!(
+ "UART0 called {} time{}",
+ *times,
+ if *times > 1 { "s" } else { "" }
+ )
+ .unwrap();
+ }
+}