Misplaced Pages

Stack resource policy

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.
(Redirected from Stack Resource Policy) Resource allocation policy used in real-time computing
This article may require cleanup to meet Misplaced Pages's quality standards. The specific problem is: Little information with informal speak. Please help improve this article if you can. (May 2012) (Learn how and when to remove this message)

The Stack Resource Policy (SRP) is a resource allocation policy used in real-time computing, used for accessing shared resources when using earliest deadline first scheduling. It was defined by T. P. Baker. SRP is not the same as the Priority ceiling protocol which is for fixed priority tasks (FP).

Function

Each task is assigned a preemption level based upon the following formula where D ( T i ) {\displaystyle D(T_{i})} denotes the deadline of task i {\displaystyle i} and π i ( T i ) {\displaystyle \pi _{i}(T_{i})} denotes the preemption level of task i:

D ( T i ) < D ( T j ) π i ( T i ) > π i ( T j ) {\displaystyle D(T_{i})<D(T_{j})\iff \pi _{i}(T_{i})>\pi _{i}(T_{j})}

Each resource R has a current ceiling C R ( V R ) {\displaystyle C_{R}(V_{R})} that represents the maximum of the preemption levels of the tasks that may be blocked, when there are V {\displaystyle V} units of R {\displaystyle R} available and μ R ( J ) {\displaystyle \mu _{R}(J)} is the maximum units of R {\displaystyle R} that T i {\displaystyle T_{i}} may require at any one time. C R ( V R ) {\displaystyle C_{R}(V_{R})} is assigned as follows:

C R ( V R ) = m a x ( { 0 } { π ( J ) | V R < μ R ( J ) } ) {\displaystyle C_{R}(V_{R})=max(\{0\}\cup \{\pi (J)|V_{R}<\mu _{R}(J)\})}

There is also a system ceiling π {\displaystyle \pi '} which is the maximum of all current ceilings of the resources.

π = m a x ( { C R ( i ) | i = 1 , . . . , m } { π ( J c ) } ) {\displaystyle \pi '=max(\{C_{R}(i)|i=1,...,m\}\cup \{\pi (J_{c})\})}

Any task T i {\displaystyle T_{i}} that wishes to preempt the system must first satisfy the following constraint:

π < P i ( T i ) {\displaystyle \pi '<P_{i}(T_{i})}

This can be refined for Operating System implementation (as in MarteOS) by removing the multi-unit resources and defining the stack resource policy as follows

  • All tasks are assigned a preemption level, in order to preserve the ordering of tasks in relation to each other when locking resources. The lowest relative deadline tasks are assigned the highest preemption level.
  • Each shared resource has an associated ceiling level, which is the maximum preemption level of all the tasks that access this protected object.
  • The system ceiling, at any instant in time, is the maximum active priority of all the tasks that are currently executing within the system.
  • A task is only allowed to preempt the system when its absolute deadline is less than the currently executing task and its preemption level is higher than the current system ceiling.

Relevancy

The 2011 book Hard Real-Time Computing Systems: Predictable Scheduling Algorithms and Applications by Giorgio C. Buttazzo featured a dedicated section to reviewing SRP from Baker 1991 work.

References

  1. Baker, T. P. (1990). "A Stack-Based Resource Allocation Policy for Realtime Processes". IEEE Real-Time Systems Symposium: 191–200.
  2. Hard Real-Time Computing Systems: Predictable Scheduling Algorithms and Applications, Giorgio C. Buttazzo, 2011
  3. T.P. Baker, "Stack-Based Scheduling of Realtime Processes", The Real-Time Systems Journal 3,1 (March 1991)67-100
Category: