aboutsummaryrefslogtreecommitdiff
path: root/tests/cfail/race-2.rs
diff options
context:
space:
mode:
authorJorge Aparicio <jorge@japaric.io>2017-04-21 15:31:02 -0500
committerJorge Aparicio <jorge@japaric.io>2017-04-21 15:31:02 -0500
commit3e165f2a42b8f3c66e3e77742a54feb875ec4bd6 (patch)
tree40fed29e8d94ac1d3b678ad3617a8e957e679f3c /tests/cfail/race-2.rs
parent854939fc6b523479a7540d8ac9d0933d9c3dcb78 (diff)
drop `lock` methods, add `raise_to` function
Diffstat (limited to 'tests/cfail/race-2.rs')
-rw-r--r--tests/cfail/race-2.rs12
1 files changed, 9 insertions, 3 deletions
diff --git a/tests/cfail/race-2.rs b/tests/cfail/race-2.rs
index 23d7dd4..7f3504d 100644
--- a/tests/cfail/race-2.rs
+++ b/tests/cfail/race-2.rs
@@ -6,17 +6,23 @@ static R1: Resource<i32, C2> = Resource::new(0);
static R2: Resource<i32, C4> = Resource::new(0);
fn j1(prio: P1) {
- R1.lock(&prio, |r1, _| {
+ let ceil = prio.as_ceiling();
+
+ rtfm::raise_to(ceil, &R1, |ceil| {
+ let r1 = R1.borrow(&prio, ceil);
+
// Would preempt this critical section
// rtfm::request(j2);
});
}
fn j2(prio: P3) {
- R2.lock(&prio, |r2, c4| {
+ let ceil = prio.as_ceiling();
+
+ rtfm::raise_to(ceil, &R2, |ceil| {
// OK C2 (R1's ceiling) <= C4 (system ceiling)
// BAD C2 (R1's ceiling) < P3 (j2's priority)
- let r1 = R1.borrow(&prio, &c4);
+ let r1 = R1.borrow(&prio, ceil);
//~^ error
});
}