rtic/tests/cfail/lock.rs

37 lines
978 B
Rust
Raw Normal View History

extern crate cortex_m_rtfm as rtfm;
2017-04-10 05:42:17 +02:00
use rtfm::{CMax, C2, P1, P2, P3, PMax, Resource, T1, T2, T3, TMax};
2017-04-10 05:42:17 +02:00
static R1: Resource<i32, C2> = Resource::new(0);
// You don't need to raise the ceiling to access a resource with ceiling equal
// to the task priority.
fn j1(prio: P2, thr: T2) {
thr.raise(&R1, |_| {});
2017-04-10 05:42:17 +02:00
//~^ error
// OK
let r1 = R1.access(&prio, &thr);
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
// if you raise the preemption threshold first
fn j2(prio: P1, thr: T1) {
2017-04-10 05:42:17 +02:00
// OK
thr.raise(&R1, |thr| { let r1 = R1.access(&prio, thr); })
2017-04-10 05:42:17 +02:00
}
static R2: Resource<i32, CMax> = Resource::new(0);
2017-04-10 05:42:17 +02:00
// Tasks with priority less than P16 can't access a resource with ceiling CMax
fn j4(prio: P1, thr: T1) {
thr.raise(&R2, |thr| {});
//~^ error
2017-04-10 05:42:17 +02:00
}
// Only tasks with priority P16 can directly access a resource with ceiling CMax
fn j5(prio: PMax, thr: TMax) {
2017-04-10 05:42:17 +02:00
// OK
let r2 = R2.access(&prio, &thr);
2017-04-10 05:42:17 +02:00
}