mirror of
https://github.com/rtic-rs/rtic.git
synced 2024-11-23 20:22:51 +01:00
add binds
example and make it work
This commit is contained in:
parent
a233808280
commit
11f795aaf6
4 changed files with 55 additions and 2 deletions
4
ci/expected/binds.run
Normal file
4
ci/expected/binds.run
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
init
|
||||||
|
foo called 1 time
|
||||||
|
idle
|
||||||
|
foo called 2 times
|
|
@ -93,6 +93,7 @@ main() {
|
||||||
idle
|
idle
|
||||||
init
|
init
|
||||||
interrupt
|
interrupt
|
||||||
|
binds
|
||||||
|
|
||||||
resource
|
resource
|
||||||
lock
|
lock
|
||||||
|
|
48
examples/binds.rs
Normal file
48
examples/binds.rs
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
//! examples/binds.rs
|
||||||
|
|
||||||
|
#![deny(unsafe_code)]
|
||||||
|
#![deny(warnings)]
|
||||||
|
#![no_main]
|
||||||
|
#![no_std]
|
||||||
|
|
||||||
|
extern crate panic_semihosting;
|
||||||
|
|
||||||
|
use cortex_m_semihosting::{debug, hprintln};
|
||||||
|
use lm3s6965::Interrupt;
|
||||||
|
use rtfm::app;
|
||||||
|
|
||||||
|
// `examples/interrupt.rs` rewritten to use `binds`
|
||||||
|
#[app(device = lm3s6965)]
|
||||||
|
const APP: () = {
|
||||||
|
#[init]
|
||||||
|
fn init() {
|
||||||
|
rtfm::pend(Interrupt::UART0);
|
||||||
|
|
||||||
|
hprintln!("init").unwrap();
|
||||||
|
}
|
||||||
|
|
||||||
|
#[idle]
|
||||||
|
fn idle() -> ! {
|
||||||
|
hprintln!("idle").unwrap();
|
||||||
|
|
||||||
|
rtfm::pend(Interrupt::UART0);
|
||||||
|
|
||||||
|
debug::exit(debug::EXIT_SUCCESS);
|
||||||
|
|
||||||
|
loop {}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[interrupt(binds = UART0)]
|
||||||
|
fn foo() {
|
||||||
|
static mut TIMES: u32 = 0;
|
||||||
|
|
||||||
|
*TIMES += 1;
|
||||||
|
|
||||||
|
hprintln!(
|
||||||
|
"foo called {} time{}",
|
||||||
|
*TIMES,
|
||||||
|
if *TIMES > 1 { "s" } else { "" }
|
||||||
|
)
|
||||||
|
.unwrap();
|
||||||
|
}
|
||||||
|
};
|
|
@ -1128,7 +1128,7 @@ fn exceptions(ctxt: &mut Context, app: &App, analysis: &Analysis) -> Vec<proc_ma
|
||||||
};
|
};
|
||||||
|
|
||||||
let locals = mk_locals(&exception.statics, false);
|
let locals = mk_locals(&exception.statics, false);
|
||||||
let symbol = ident.to_string();
|
let symbol = exception.args.binds.as_ref().unwrap_or(ident).to_string();
|
||||||
let alias = ctxt.ident_gen.mk_ident(None, false);
|
let alias = ctxt.ident_gen.mk_ident(None, false);
|
||||||
let unsafety = &exception.unsafety;
|
let unsafety = &exception.unsafety;
|
||||||
quote!(
|
quote!(
|
||||||
|
@ -1214,7 +1214,7 @@ fn interrupts(
|
||||||
|
|
||||||
let locals = mk_locals(&interrupt.statics, false);
|
let locals = mk_locals(&interrupt.statics, false);
|
||||||
let alias = ctxt.ident_gen.mk_ident(None, false);
|
let alias = ctxt.ident_gen.mk_ident(None, false);
|
||||||
let symbol = ident.to_string();
|
let symbol = interrupt.args.binds.as_ref().unwrap_or(ident).to_string();
|
||||||
let unsafety = &interrupt.unsafety;
|
let unsafety = &interrupt.unsafety;
|
||||||
scoped.push(quote!(
|
scoped.push(quote!(
|
||||||
// unsafe trampoline to deter end-users from calling this non-reentrant function
|
// unsafe trampoline to deter end-users from calling this non-reentrant function
|
||||||
|
|
Loading…
Reference in a new issue