rtic/tests/cfail/lock.rs

51 lines
1.1 KiB
Rust
Raw Normal View History

extern crate cortex_m_rtfm as rtfm;
2017-04-10 05:42:17 +02:00
use rtfm::{C16, C2, P1, P16, P2, P3, Resource};
2017-04-10 05:42:17 +02:00
static R1: Resource<i32, C2> = Resource::new(0);
// You CAN'T use `raise` to lower the system ceiling
2017-04-10 05:42:17 +02:00
fn j1(prio: P3) {
let ceil = prio.as_ceiling();
ceil.raise(&R1, |ceil| {});
//~^ error
2017-04-10 05:42:17 +02:00
}
// You don't need to raise the ceiling to access a resource with ceiling equal
// to the task priority.
2017-04-10 05:42:17 +02:00
fn j2(prio: P2) {
let ceil = prio.as_ceiling();
2017-04-21 22:41:03 +02:00
ceil.raise(&R1, |_| {});
2017-04-10 05:42:17 +02:00
//~^ error
// OK
let r1 = R1.borrow(&prio, ceil);
2017-04-10 05:42:17 +02:00
}
// You CAN access a resource with ceiling C from a task with priority P if C > P
// and you raise the ceiling first
2017-04-10 05:42:17 +02:00
fn j3(prio: P1) {
let ceil = prio.as_ceiling();
2017-04-10 05:42:17 +02:00
// OK
ceil.raise(&R1, |ceil| { let r1 = R1.borrow(&prio, ceil); })
2017-04-10 05:42:17 +02:00
}
static R2: Resource<i32, C16> = Resource::new(0);
// Tasks with priority less than P16 can't access a resource with ceiling C16
2017-04-10 05:42:17 +02:00
fn j4(prio: P1) {
let ceil = prio.as_ceiling();
ceil.raise(&R2, |ceil| {});
//~^ error
2017-04-10 05:42:17 +02:00
}
// Only tasks with priority P16 can access a resource with ceiling C16
2017-04-10 05:42:17 +02:00
fn j5(prio: P16) {
// OK
2017-04-20 00:21:13 +02:00
let r2 = R2.borrow(&prio, prio.as_ceiling());
2017-04-10 05:42:17 +02:00
}