mirror of
https://github.com/rtic-rs/rtic.git
synced 2025-12-18 22:05:37 +01:00
make idle optional
This commit is contained in:
parent
b1abd52be2
commit
dbb4ca6c33
15 changed files with 173 additions and 192 deletions
|
|
@ -4,14 +4,12 @@
|
|||
#![no_main]
|
||||
#![no_std]
|
||||
|
||||
extern crate cortex_m;
|
||||
#[macro_use]
|
||||
extern crate cortex_m_rt as rt;
|
||||
extern crate cortex_m_rtfm as rtfm;
|
||||
extern crate panic_abort;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
||||
|
|
@ -30,13 +28,6 @@ fn init(mut _ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources {}
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn exti0(_ctxt: exti0::Context) {}
|
||||
|
||||
exception!(HardFault, hard_fault);
|
||||
|
|
|
|||
48
examples/idle.rs
Normal file
48
examples/idle.rs
Normal file
|
|
@ -0,0 +1,48 @@
|
|||
#![deny(unsafe_code)]
|
||||
#![deny(warnings)]
|
||||
#![feature(proc_macro)]
|
||||
#![no_main]
|
||||
#![no_std]
|
||||
|
||||
extern crate cortex_m;
|
||||
#[macro_use]
|
||||
extern crate cortex_m_rt;
|
||||
extern crate cortex_m_rtfm as rtfm;
|
||||
extern crate panic_semihosting;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use cortex_m_rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
||||
app! {
|
||||
device: stm32f103xx,
|
||||
|
||||
idle: {},
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn init(_ctxt: init::Context) -> init::LateResources {
|
||||
init::LateResources {}
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
exception!(HardFault, hard_fault);
|
||||
|
||||
#[inline(always)]
|
||||
fn hard_fault(ef: &ExceptionFrame) -> ! {
|
||||
panic!("HardFault at {:#?}", ef);
|
||||
}
|
||||
|
||||
exception!(*, default_handler);
|
||||
|
||||
#[inline(always)]
|
||||
fn default_handler(irqn: i16) {
|
||||
panic!("Unhandled exception (IRQn = {})", irqn);
|
||||
}
|
||||
|
|
@ -4,14 +4,12 @@
|
|||
#![no_main]
|
||||
#![no_std]
|
||||
|
||||
extern crate cortex_m;
|
||||
#[macro_use]
|
||||
extern crate cortex_m_rt;
|
||||
extern crate cortex_m_rtfm as rtfm;
|
||||
extern crate panic_semihosting;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use cortex_m_rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
||||
|
|
@ -24,13 +22,6 @@ fn init(_ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources {}
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
exception!(HardFault, hard_fault);
|
||||
|
||||
#[inline(always)]
|
||||
|
|
|
|||
|
|
@ -46,7 +46,6 @@ extern crate cortex_m_rtfm as rtfm;
|
|||
extern crate panic_abort;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use cortex_m::peripheral::{DWT, ITM};
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
|
@ -85,13 +84,6 @@ fn init(mut ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources { ITM: ctxt.core.ITM }
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn a(mut ctxt: a::Context) {
|
||||
let now = DWT::get_cycle_count();
|
||||
let input = ctxt.input;
|
||||
|
|
|
|||
|
|
@ -75,10 +75,9 @@ extern crate cortex_m_rtfm as rtfm;
|
|||
extern crate panic_abort;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use cortex_m::peripheral::{DWT, ITM};
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::{app, Resource};
|
||||
use rtfm::app;
|
||||
|
||||
app! {
|
||||
device: stm32f103xx,
|
||||
|
|
@ -122,13 +121,6 @@ fn init(mut ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources { ITM: ctxt.core.ITM }
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn a(mut ctxt: a::Context) {
|
||||
let now = DWT::get_cycle_count();
|
||||
|
||||
|
|
|
|||
|
|
@ -76,7 +76,6 @@ extern crate cortex_m_rtfm as rtfm;
|
|||
extern crate panic_abort;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use cortex_m::peripheral::{DWT, ITM};
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::{app, Resource};
|
||||
|
|
@ -121,13 +120,6 @@ fn init(mut ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources { ITM: ctxt.core.ITM }
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn a(mut ctxt: a::Context) {
|
||||
let now = DWT::get_cycle_count();
|
||||
|
||||
|
|
|
|||
|
|
@ -42,10 +42,8 @@ extern crate cortex_m;
|
|||
extern crate cortex_m_rt as rt;
|
||||
extern crate cortex_m_rtfm as rtfm;
|
||||
extern crate panic_abort;
|
||||
// extern crate panic_itm;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use cortex_m::peripheral::{DWT, ITM};
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
|
@ -83,13 +81,6 @@ fn init(mut ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources { ITM: ctxt.core.ITM }
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn a(mut ctxt: a::Context) {
|
||||
let now = DWT::get_cycle_count();
|
||||
|
||||
|
|
|
|||
|
|
@ -11,7 +11,6 @@ extern crate cortex_m_rtfm as rtfm;
|
|||
extern crate panic_abort;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use cortex_m::peripheral::{DWT, ITM};
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
|
@ -47,13 +46,6 @@ fn init(ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources { ITM: ctxt.core.ITM }
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn exti0(mut ctxt: exti0::Context) {
|
||||
let now = DWT::get_cycle_count();
|
||||
iprintln!(
|
||||
|
|
|
|||
|
|
@ -11,7 +11,6 @@ extern crate cortex_m_rtfm as rtfm;
|
|||
extern crate panic_abort;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
||||
|
|
@ -37,20 +36,11 @@ fn init(_ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources {}
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn exti0(mut ctxt: exti0::Context) {
|
||||
ctxt.tasks.a.schedule_after(&mut ctxt.priority, 1 * S).ok();
|
||||
}
|
||||
|
||||
fn a(_ctxt: a::Context) {
|
||||
asm::bkpt();
|
||||
}
|
||||
fn a(_ctxt: a::Context) {}
|
||||
|
||||
exception!(HardFault, hard_fault);
|
||||
|
||||
|
|
|
|||
|
|
@ -11,7 +11,6 @@ extern crate cortex_m_rtfm as rtfm;
|
|||
extern crate panic_abort;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use cortex_m::peripheral::{DWT, ITM};
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
|
@ -45,13 +44,6 @@ fn init(ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources { ITM: ctxt.core.ITM }
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn exti0(mut ctxt: exti0::Context) {
|
||||
let now = DWT::get_cycle_count();
|
||||
iprintln!(
|
||||
|
|
|
|||
|
|
@ -49,15 +49,8 @@ fn init(mut ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources {}
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn exti0(mut ctxt: exti0::Context) {
|
||||
ctxt.tasks.a.schedule_now(&mut ctxt.priority).ok();
|
||||
ctxt.tasks.a.schedule_now(&mut ctxt.priority).unwrap();
|
||||
}
|
||||
|
||||
fn a(_ctxt: a::Context) {
|
||||
|
|
|
|||
|
|
@ -4,14 +4,12 @@
|
|||
#![no_main]
|
||||
#![no_std]
|
||||
|
||||
extern crate cortex_m;
|
||||
#[macro_use]
|
||||
extern crate cortex_m_rt as rt;
|
||||
extern crate cortex_m_rtfm as rtfm;
|
||||
extern crate panic_abort;
|
||||
extern crate stm32f103xx;
|
||||
|
||||
use cortex_m::asm;
|
||||
use rt::ExceptionFrame;
|
||||
use rtfm::app;
|
||||
|
||||
|
|
@ -48,13 +46,6 @@ fn init(_ctxt: init::Context) -> init::LateResources {
|
|||
init::LateResources { BAR: Foo(0) }
|
||||
}
|
||||
|
||||
#[inline(always)]
|
||||
fn idle(_ctxt: idle::Context) -> ! {
|
||||
loop {
|
||||
asm::wfi();
|
||||
}
|
||||
}
|
||||
|
||||
fn a(_ctxt: a::Context) {}
|
||||
|
||||
fn b(_ctxt: b::Context) {}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue