raise_to -> Ceiling.raise

This commit is contained in:
Jorge Aparicio 2017-04-21 15:41:03 -05:00
parent 3e165f2a42
commit 1c82f1b119
6 changed files with 31 additions and 34 deletions

View file

@ -522,31 +522,6 @@ where
r r
} }
/// Raises the system ceiling to match `resource`'s ceiling
#[cfg(not(thumbv6m))]
pub fn raise_to<R, CURRENT, HIGHER, RES, F>(
_current_ceiling: &C<CURRENT>,
_resource: &RES,
f: F,
) -> R
where
F: FnOnce(&C<HIGHER>) -> R,
RES: ResourceLike<Ceiling = HIGHER>,
HIGHER: Cmp<CURRENT, Output = Greater>,
HIGHER: Cmp<UMAX, Output = Less>,
HIGHER: Unsigned,
{
unsafe {
let old_basepri = basepri::read();
basepri_max::write(logical2hw(HIGHER::to_u8()));
barrier!();
let ret = f(&C { _marker: PhantomData });
barrier!();
basepri::write(old_basepri);
ret
}
}
/// Requests the execution of a `task` /// Requests the execution of a `task`
pub fn request<T, PRIORITY>(_task: fn(T, P<PRIORITY>)) pub fn request<T, PRIORITY>(_task: fn(T, P<PRIORITY>))
where where
@ -586,6 +561,28 @@ pub struct C<T> {
_marker: PhantomData<T>, _marker: PhantomData<T>,
} }
impl<CURRENT> C<CURRENT> {
/// Raises the ceiling to match `resource`'s ceiling
pub fn raise<HIGHER, RES, R, F>(&self, _resource: &'static RES, f: F) -> R
where
RES: ResourceLike<Ceiling = HIGHER>,
HIGHER: Cmp<CURRENT, Output = Greater>,
HIGHER: Cmp<UMAX, Output = Less>,
HIGHER: Unsigned,
F: FnOnce(&C<HIGHER>) -> R,
{
unsafe {
let old_basepri = basepri::read();
basepri_max::write(logical2hw(HIGHER::to_u8()));
barrier!();
let ret = f(&C { _marker: PhantomData });
barrier!();
basepri::write(old_basepri);
ret
}
}
}
/// A type-level priority /// A type-level priority
pub struct P<T> { pub struct P<T> {
_marker: PhantomData<T>, _marker: PhantomData<T>,

View file

@ -12,7 +12,7 @@ static R6: Resource<i32, C2> = Resource::new(0);
fn j1(prio: P2) { fn j1(prio: P2) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
rtfm::raise_to(ceil, &R1, |ceil| { ceil.raise(&R1, |ceil| {
// CAN borrow a resource with ceiling C when the current ceiling SC > C // CAN borrow a resource with ceiling C when the current ceiling SC > C
let r2 = R2.borrow(&prio, ceil); let r2 = R2.borrow(&prio, ceil);

View file

@ -7,7 +7,7 @@ static R1: Resource<(), C3> = Resource::new(());
fn j1(prio: P2) { fn j1(prio: P2) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
let c3 = rtfm::raise_to(ceil, &R1, |ceil| { let c3 = ceil.raise(&R1, |ceil| {
// forbidden: ceiling token can't outlive critical section // forbidden: ceiling token can't outlive critical section
ceil //~ error ceil //~ error
}); });

View file

@ -8,7 +8,7 @@ static R1: Resource<i32, C2> = Resource::new(0);
fn j1(prio: P3) { fn j1(prio: P3) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
rtfm::raise_to(ceil, &R1, |ceil| { ceil.raise(&R1, |ceil| {
//~^ error //~^ error
}); });
} }
@ -18,7 +18,7 @@ fn j1(prio: P3) {
fn j2(prio: P2) { fn j2(prio: P2) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
rtfm::raise_to(ceil, &R1, |_| {}); ceil.raise(&R1, |_| {});
//~^ error //~^ error
// OK // OK
@ -30,7 +30,7 @@ fn j3(prio: P1) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
// OK // OK
rtfm::raise_to(ceil, &R1, |ceil| { ceil.raise(&R1, |ceil| {
let r1 = R1.borrow(&prio, ceil); let r1 = R1.borrow(&prio, ceil);
}) })
} }
@ -41,7 +41,7 @@ static R2: Resource<i32, C16> = Resource::new(0);
fn j4(prio: P1) { fn j4(prio: P1) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
rtfm::raise_to(ceil, &R2, |ceil| { ceil.raise(&R2, |ceil| {
//~^ error //~^ error
}); });
} }

View file

@ -7,7 +7,7 @@ static R1: Resource<i32, C2> = Resource::new(0);
fn j1(prio: P1) { fn j1(prio: P1) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
rtfm::raise_to(&ceil, &R1, |ceil| { ceil.raise(&R1, |ceil| {
let r1 = R1.borrow(&prio, ceil); let r1 = R1.borrow(&prio, ceil);
// Would preempt this critical section // Would preempt this critical section

View file

@ -8,7 +8,7 @@ static R2: Resource<i32, C4> = Resource::new(0);
fn j1(prio: P1) { fn j1(prio: P1) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
rtfm::raise_to(ceil, &R1, |ceil| { ceil.raise(&R1, |ceil| {
let r1 = R1.borrow(&prio, ceil); let r1 = R1.borrow(&prio, ceil);
// Would preempt this critical section // Would preempt this critical section
@ -19,7 +19,7 @@ fn j1(prio: P1) {
fn j2(prio: P3) { fn j2(prio: P3) {
let ceil = prio.as_ceiling(); let ceil = prio.as_ceiling();
rtfm::raise_to(ceil, &R2, |ceil| { ceil.raise(&R2, |ceil| {
// OK C2 (R1's ceiling) <= C4 (system ceiling) // OK C2 (R1's ceiling) <= C4 (system ceiling)
// BAD C2 (R1's ceiling) < P3 (j2's priority) // BAD C2 (R1's ceiling) < P3 (j2's priority)
let r1 = R1.borrow(&prio, ceil); let r1 = R1.borrow(&prio, ceil);