diff options
| author | homunkulus <homunkulus@gmx.com> | 2017-12-23 10:36:08 +0000 |
|---|---|---|
| committer | homunkulus <homunkulus@gmx.com> | 2017-12-23 10:36:08 +0000 |
| commit | 8a396c51f2caaeca7ee0f81ef2f3c4f2f73d8df1 (patch) | |
| tree | fa6538343f2d524be574285c2bb68057edc11420 /examples/custom-type.rs | |
| parent | 0f5784c2401d4b12004f34345e721598fa21219a (diff) | |
| parent | a238fd5dc783f57f8fa61795690e6069b1becd32 (diff) | |
Auto merge of #58 - japaric:init-resources, r=japaric
safe `&'static mut` references via init.resources
see RFC #59 for details
Diffstat (limited to 'examples/custom-type.rs')
| -rw-r--r-- | examples/custom-type.rs | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/examples/custom-type.rs b/examples/custom-type.rs new file mode 100644 index 0000000..79d6cc4 --- /dev/null +++ b/examples/custom-type.rs @@ -0,0 +1,50 @@ +#![deny(unsafe_code)] +#![deny(warnings)] +#![feature(proc_macro)] +#![no_std] + +extern crate cortex_m_rtfm as rtfm; +extern crate stm32f103xx; + +use rtfm::{app, Threshold}; + +pub struct Foo; + +app! { + device: stm32f103xx, + + resources: { + static CO_OWNED: Foo = Foo; + static ON: Foo = Foo; + static OWNED: Foo = Foo; + static SHARED: Foo = Foo; + }, + + idle: { + resources: [OWNED, SHARED], + }, + + tasks: { + SYS_TICK: { + path: sys_tick, + resources: [CO_OWNED, ON, SHARED], + }, + + TIM2: { + enabled: false, + path: tim2, + priority: 1, + resources: [CO_OWNED], + }, + }, +} + +fn init(_p: ::init::Peripherals, _r: ::init::Resources) {} + +fn idle(_t: &mut Threshold, _r: ::idle::Resources) -> ! { + loop {} +} + +fn sys_tick(_t: &mut Threshold, _r: SYS_TICK::Resources) {} + +fn tim2(_t: &mut Threshold, _r: TIM2::Resources) {} |
