2017-04-22 04:38:39 +02:00
|
|
|
extern crate cortex_m_rtfm as rtfm;
|
|
|
|
|
2017-05-08 19:05:42 +02:00
|
|
|
use rtfm::{C1, C2, C3, C4, C5, P2, Resource, T2};
|
2017-04-22 04:38:39 +02:00
|
|
|
|
|
|
|
static R1: Resource<i32, C4> = Resource::new(0);
|
|
|
|
static R2: Resource<i32, C3> = Resource::new(0);
|
|
|
|
static R3: Resource<i32, C4> = Resource::new(0);
|
|
|
|
static R4: Resource<i32, C5> = Resource::new(0);
|
|
|
|
static R5: Resource<i32, C1> = Resource::new(0);
|
|
|
|
static R6: Resource<i32, C2> = Resource::new(0);
|
|
|
|
|
2017-05-08 19:05:42 +02:00
|
|
|
fn j1(prio: P2, thr: T2) {
|
|
|
|
thr.raise(
|
|
|
|
&R1, |thr| {
|
|
|
|
// NOTE PT = Preemption Threshold, TP = Task Priority
|
2017-04-22 04:38:39 +02:00
|
|
|
|
2017-05-08 19:05:42 +02:00
|
|
|
// CAN access a resource with ceiling RC when PT > RC
|
|
|
|
let r2 = R2.access(&prio, thr);
|
2017-04-22 04:38:39 +02:00
|
|
|
|
2017-05-08 19:05:42 +02:00
|
|
|
// CAN access a resource with ceiling RC when PT == RC
|
|
|
|
let r3 = R3.access(&prio, thr);
|
2017-04-22 04:38:39 +02:00
|
|
|
|
2017-05-08 19:05:42 +02:00
|
|
|
// CAN'T access a resource with ceiling RC when PT < RC
|
|
|
|
let r4 = R4.access(&prio, thr);
|
2017-04-22 04:38:39 +02:00
|
|
|
//~^ error
|
|
|
|
|
2017-05-08 19:05:42 +02:00
|
|
|
// CAN'T access a resource with ceiling RC when RC < TP
|
|
|
|
let r5 = R5.access(&prio, thr);
|
2017-04-22 04:38:39 +02:00
|
|
|
//~^ error
|
|
|
|
|
2017-05-08 19:05:42 +02:00
|
|
|
// CAN access a resource with ceiling RC when RC == tP
|
|
|
|
let r6 = R6.access(&prio, thr);
|
2017-04-22 04:38:39 +02:00
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|