From 2fb00c7d85f2eee6caa0bc742afd496a6ef7f33c Mon Sep 17 00:00:00 2001 From: Jorge Aparicio Date: Thu, 13 Apr 2017 22:57:06 -0500 Subject: fix memory safety hole around `borrow` --- tests/cfail/borrow.rs | 27 ++++++++++++++++++--------- 1 file changed, 18 insertions(+), 9 deletions(-) (limited to 'tests/cfail/borrow.rs') diff --git a/tests/cfail/borrow.rs b/tests/cfail/borrow.rs index fc8638f..6d8ab2a 100644 --- a/tests/cfail/borrow.rs +++ b/tests/cfail/borrow.rs @@ -1,22 +1,31 @@ extern crate cortex_m_srp; -use cortex_m_srp::{C2, C3, C4, P1, Resource}; +use cortex_m_srp::{C1, C2, C3, C4, C5, P2, Resource}; -static R1: Resource = Resource::new(0); -static R2: Resource = Resource::new(0); -static R3: Resource = Resource::new(0); -static R4: Resource = Resource::new(0); +static R1: Resource = Resource::new(0); +static R2: Resource = Resource::new(0); +static R3: Resource = Resource::new(0); +static R4: Resource = Resource::new(0); +static R5: Resource = Resource::new(0); +static R6: Resource = Resource::new(0); -fn j1(prio: P1) { +fn j1(prio: P2) { R1.lock(&prio, |r1, c3| { // CAN borrow a resource with ceiling C when the system ceiling SC > C - let r2 = R2.borrow(&c3); + let r2 = R2.borrow(&prio, &c3); // CAN borrow a resource with ceiling C when the system ceiling SC == C - let r3 = R3.borrow(&c3); + let r3 = R3.borrow(&prio, &c3); // CAN'T borrow a resource with ceiling C when the system ceiling SC < C - let r4 = R4.borrow(&c3); + let r4 = R4.borrow(&prio, &c3); //~^ error + + // CAN'T borrow a resource with ceiling C < P (task priority) + let r5 = R5.borrow(&prio, &c3); + //~^ error + + // CAN borrow a resource with ceiling C == P (task priority) + let r6 = R6.borrow(&prio, &c3); }); } -- cgit v1.2.3