From be1a27ccf98e68c5994ed7a4ccb4379ba27b134a Mon Sep 17 00:00:00 2001 From: Jonas Schievink Date: Fri, 22 Sep 2017 18:21:12 +0200 Subject: [PATCH] Add cfail test for late resources --- tests/cfail/late-resource-init.rs | 49 +++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 tests/cfail/late-resource-init.rs diff --git a/tests/cfail/late-resource-init.rs b/tests/cfail/late-resource-init.rs new file mode 100644 index 0000000000..a997b5c232 --- /dev/null +++ b/tests/cfail/late-resource-init.rs @@ -0,0 +1,49 @@ +#![deny(warnings)] +#![feature(proc_macro)] +#![no_std] + +extern crate cortex_m_rtfm as rtfm; +extern crate stm32f103xx; + +use rtfm::{app, Threshold}; + +app! { + device: stm32f103xx, + + resources: { + static A: u8 = 0; + static LATE: u8; + }, + + tasks: { + EXTI0: { + path: exti0, + priority: 1, + resources: [A, LATE], + }, + + EXTI1: { + path: exti1, + priority: 2, + resources: [A, LATE], + }, + }, +} + +fn init(_p: init::Peripherals, r: init::Resources) -> init::LateResourceValues { + // Try to use a resource that's not yet initialized: + r.LATE; + //~^ error: no field `LATE` + + init::LateResourceValues { + LATE: 0, + } +} + +fn idle() -> ! { + loop {} +} + +fn exti0(_t: &mut Threshold, _r: EXTI0::Resources) {} + +fn exti1(_t: &mut Threshold, _r: EXTI1::Resources) {}