diff options
| author | homunkulus <homunkulus@gmx.com> | 2017-12-09 14:26:38 +0000 |
|---|---|---|
| committer | homunkulus <homunkulus@gmx.com> | 2017-12-09 14:26:38 +0000 |
| commit | 40ebb93cc6ec8533d4532853c3fd01693af09d8e (patch) | |
| tree | 2a452f6e7d7d02bc9d17494554f04afcab8efd63 /tests/cfail/resource-not-send.rs | |
| parent | 0a0e0e2b382d826ac7b423c91f39d2abf91a010f (diff) | |
| parent | d6c240f9743067c81e68adcf35c60304573db8b9 (diff) | |
Auto merge of #56 - japaric:not-send, r=japaric
make resource proxies !Send
None
Diffstat (limited to 'tests/cfail/resource-not-send.rs')
| -rw-r--r-- | tests/cfail/resource-not-send.rs | 53 |
1 files changed, 53 insertions, 0 deletions
diff --git a/tests/cfail/resource-not-send.rs b/tests/cfail/resource-not-send.rs new file mode 100644 index 0000000..c89c3d3 --- /dev/null +++ b/tests/cfail/resource-not-send.rs @@ -0,0 +1,53 @@ +#![deny(unsafe_code)] +#![deny(warnings)] +#![feature(const_fn)] +#![feature(proc_macro)] +#![no_std] + +extern crate cortex_m_rtfm as rtfm; +extern crate stm32f103xx; + +use rtfm::{app, Resource, Threshold}; + +app! { + device: stm32f103xx, + + resources: { + static SHARED: bool = false; + }, + + tasks: { + EXTI0: { + path: exti0, + priority: 1, + resources: [SHARED], + }, + + EXTI1: { + path: exti1, + priority: 2, + resources: [SHARED], + }, + }, +} + +fn init(_p: init::Peripherals, _r: init::Resources) {} + +fn idle() -> ! { + loop {} +} + +fn is_send<T>(_: &T) where T: Send {} +fn is_sync<T>(_: &T) where T: Sync {} + +fn exti0(_t: &mut Threshold, r: EXTI0::Resources) { + // OK + is_sync(&r.SHARED); + + // ERROR resource proxies are not `Send`able across tasks + is_send(&r.SHARED); + //~^ error the trait bound `*const (): core::marker::Send` is not satisfied +} + +fn exti1(_t: &mut Threshold, _r: EXTI1::Resources) { +} |
