-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit ec8a75f
Showing
45 changed files
with
10,206 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
/build/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
MIT License | ||
|
||
Copyright (c) 2021 Mark Bronsfeld | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy | ||
of this software and associated documentation files (the "Software"), to deal | ||
in the Software without restriction, including without limitation the rights | ||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
copies of the Software, and to permit persons to whom the Software is | ||
furnished to do so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in all | ||
copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
SOFTWARE. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
# Taskuler - Simple "Bare-Metal" Task Scheduling Framework | ||
|
||
This framework employs a simple and tiny | ||
|
||
*cyclic executive, non-preemtive, cooperative scheduler* | ||
|
||
to manage task execution. | ||
|
||
## Requirements specification | ||
|
||
The following loosely lists requirements, constraints, features and goals. | ||
|
||
* Cyclic executive, cooperative (non-preemptive/run-to-completion), monotonic | ||
(fixed priorities) scheduling of multiple tasks in embedded systems for | ||
real-time applications | ||
* Pre-emption can be achieved through hardware interrupts | ||
* Timing of tasks (via task lists) is pre-defined at compile time | ||
* Switch between multiple task lists at run time | ||
* Tasks within a task list can individually be enabled and disabled at run time | ||
* Each task can individually be scheduled by its period and its offset to other | ||
tasks | ||
* Task deadline overrun detection/indication with (single) counter | ||
* Deadline of each task can individually be defined at compile time | ||
* Disabled tasks are not run but their last run indication is still updated to | ||
maintain schedulability | ||
* To eliminate drift in task invocation over time, tasks update their last run | ||
to the "ideal" invocation time (that is, the beginning of their period/time | ||
slot) | ||
* If a task--for whatever reason--is not executed within its period, it will | ||
run "normally" within its next period (without impact on the schedule of | ||
other tasks) | ||
* Works flawlessly on rollover of its relative system time tick source with | ||
type `unsigned integer` that it is connected to | ||
|
||
* Framework design | ||
* Deployment in embedded systems | ||
* Code implementation in the C programming language ("C99", ISO/IEC 9899:1999) | ||
* Interfaces with the application software through task lists and with the MCU | ||
hardware (for the relative system time tick) through a pointer to | ||
function--both user-provided | ||
|
||
* Low impact on technical budgets | ||
* Low CPU utilization | ||
* Small memory footprint in ROM (text, data) and RAM (data, heap, stack) | ||
* Runs (also) well on "small" MCUs (e.g., AVR ATmega328P/Arduino Uno) | ||
* Quality model | ||
* "Simple" (low complexity of software architecture and detailed design, | ||
essential features only) | ||
* Modular | ||
* Re-usable | ||
* Portable | ||
* Unit tested with 100 % coverage (LOC executed, branches taken, functions | ||
called) | ||
* MISRA-C:2012 compliant | ||
* Static code analysis pass | ||
* No dynamic memory allocation (via `malloc()` or similar) | ||
* SCM via Git with semantic versioning | ||
* Well documented (from requirements over architecture to detailed design), | ||
using Doxygen, Markdown, custom diagrams, UML | ||
* Traceability from requirements specification to implementation by | ||
transitivity | ||
|
||
## Architecture | ||
|
||
data:image/s3,"s3://crabby-images/31e1f/31e1f25afeee8fb623f3329f560cfe5a6e30409d" alt="UML class diagram" | ||
|
||
data:image/s3,"s3://crabby-images/4fdfa/4fdfaa8931c747bc3454c44e027b273644caae2a" alt="Scheduling algorithm" | ||
|
||
data:image/s3,"s3://crabby-images/0c1df/0c1df55f2228df0d297da5c8178e81ae80c41e5c" alt="Exemplary task schedule" | ||
|
||
data:image/s3,"s3://crabby-images/bb18c/bb18c6bcefd861ef87e8cfcd17962533744b9a0f" alt="Flow of control" | ||
|
||
data:image/s3,"s3://crabby-images/26a31/26a318f17847af576007fd794a953c86f8d3cf4d" alt="Layered architecture" | ||
|
||
data:image/s3,"s3://crabby-images/ee9b6/ee9b61535b16f71c944f14cc3b27b0341c6838be" alt="UML package diagram" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,208 @@ | ||
# CPU utilization and schedulability | ||
|
||
The key points of the schedulability analysis are the computation of the CPU | ||
utilization (load) and the assessment of the schedulability via deadline | ||
overrun detection, which are explained here. | ||
Preemption, that is preemptive tasks, are typically implemented using the MCU’s | ||
nested (prioritized) interrupts. | ||
|
||
## Model assumptions of the schedulability analysis algorithm | ||
|
||
The deadline-monotonic scheduling (DMS) scheme is employed, so the typical | ||
definitions for this scheduling scheme apply, with the exception that only a | ||
few tasks are preemptive: | ||
|
||
* All tasks have deadlines less than or equal to their periods, | ||
* all tasks do not block each other’s execution (e.g., by accessing mutually | ||
exclusive shared resources), | ||
* static priorities are assigned according to the deadline-monotonic | ||
conventions (tasks with shorter periods/deadlines are given higher | ||
priorities), | ||
* context switch times and other thread operations introduce no overhead and so | ||
have no impact on the model, | ||
* all tasks have zero invocation jitter (the time from the task arriving to it | ||
becoming ready to execute). | ||
|
||
The task set consists of preemptive and cooperative tasks. | ||
Therefore, task preemption is excluded from the above model. | ||
That is, the task with the highest static priority that is due to run may not | ||
immediately preempt all other tasks. | ||
|
||
The upper bounds (e.g., least upper bound, hyperbolic bound) assessments on CPU | ||
utilization typically used with rate-monotonic scheduling (RMS) do not apply to | ||
the DMS (of a preemptive and cooperative task set mix), as it is used with the | ||
Taskuler. | ||
While for RMS, these upper bounds provide sufficient conditions, they do not | ||
provide sufficient nor necessary conditions for DMS (of a preemptive and | ||
cooperative task set mix). | ||
They provide no information about the schedulability or the boundaries of the | ||
system. | ||
Therefore, upper bounds assessments on CPU utilization are not further | ||
discussed. | ||
|
||
## The algorithm | ||
|
||
The goal of the schedulability analysis is to assess whether a given task set | ||
(tasks within a task list) can be scheduled, i.e., whether its schedulability | ||
is feasable. | ||
|
||
For that, the two main objectives are: | ||
|
||
* Objective 1 - Assert that the total CPU load is below the target limit | ||
* Objective 2 - Assert that each task’s WCRT is less than or equal to its | ||
deadline | ||
|
||
### Inputs | ||
|
||
To reach the above mentioned objectives, the algorithm needs the time (in | ||
seconds) equal to one (relative system) time tick and the timing table with the | ||
following information for each task: | ||
|
||
* Task name | ||
* schedule type (preemptive/cooperative) | ||
* Frequency | ||
* Deadline | ||
* WCET | ||
|
||
Sporadic tasks must be converted to periodic tasks, assuming the worst-case | ||
inter-arrival time as their periods. | ||
|
||
### Preprocessing | ||
|
||
The timing table must be sorted according to the deadline-monotonic | ||
conventions, i.e., tasks (the rows of the table) must be ordered by their | ||
priority (tasks with shorter deadlines are given higher, ascending priorities). | ||
|
||
The task period, needed in the following sections, is simply the reciprocal of | ||
the frequency. | ||
|
||
### Objective 1 - Calculate total CPU load | ||
|
||
The CPU utilization factor per task is simply its WCET divided by its period. | ||
The total CPU load is then the sum of all task’s CPU utilization factors. | ||
See [1]. | ||
|
||
The total CPU load can then be compared to the total CPU load target limit. | ||
|
||
### Objective 2 - Calculate WCRT | ||
|
||
#### WCET | ||
|
||
The worst-case execution time (WCET) is the assumed uninterrupted processing | ||
time a SW unit (e.g., a task) consumes in a worst-case scenario. | ||
The processing time is not exactly deterministic, hence it may vary with | ||
different invocations. | ||
From this task invocations data set, the sample with the longest processing | ||
time is assumed to be the WCET of that task. | ||
|
||
However, with multipe tasks scheduled, this WCET cannot be assumed to be the | ||
worst-case time span between a task’s ideal invocation (when its ready to run) | ||
and its completion. | ||
|
||
#### WCRT of a purely preemptive task set scheduled by nested (prioritized) interrupts | ||
|
||
In a preemptive scheduling scheme, a task’s invocation might be delayed or its | ||
execution interrupted (preempted) by another task with higher priority, in | ||
which case its WCET is stretched and becomes its worst-case response time | ||
(WCRT)--the time span from when its due to run to its actual completion. | ||
|
||
The figure a) below shows the schedule as it is supposed to run in that | ||
("critical") time instance. | ||
The figure b) below depicts how this schedule would actually be executed and | ||
the composition of each task’s WCRT. | ||
|
||
data:image/s3,"s3://crabby-images/5be7b/5be7b80c918a3d77f5dc3017cbc2251467a86f39" alt="WCRT explanation for preemptive task set" | ||
|
||
The equations in the above figure are recursive and must be solved iteratively | ||
(see step 2 of the employed algorithm below). | ||
For more detailed information, see [2] (the equation applied here is eq. | ||
(1)). | ||
|
||
#### WCRT of a purely cooperative task set scheduled by the cyclic executive, cooperative scheduler | ||
|
||
With a cooperative scheduling scheme, a task cannot be preempted--it has to | ||
yield and give back control to the scheduler voluntarily. | ||
However, its invocation can still be delayed by either (a) higher priority | ||
tasks that are due to run at the same time or (c) by a not yet finished, lower | ||
priority task that was started at a previous time instance--or (b) even by a | ||
combination of both. | ||
Both cases of delay contribute to a task’s WCRT, prolonging its WCET. | ||
|
||
The figure below shows such worst-case scenarios for an exemplary task set, | ||
constituting its tasks’ WCRTs for above mentioned scenarios a) to c). | ||
|
||
data:image/s3,"s3://crabby-images/eb5d9/eb5d96614f28231eb03f374bd63bee8453619326" alt="WCRT explanation for cooperative task set" | ||
|
||
#### Combined WCRT of a preemptive and cooperative task set mix | ||
|
||
Ultimately, the Taskuler is used to schedule most tasks cooperatively but is | ||
augmented by (nested) interrupts for the scheduling of some high priority | ||
tasks. | ||
Thus, the system consists of a preemptive and cooperative task set mix and the | ||
calculation of the resulting WCRT is a combination of the WCRT of both task | ||
types. | ||
|
||
The algorithm consists of Steps 1--4.3. | ||
|
||
**Step 1** | ||
|
||
Divide timing table in two separate tables, one with all preemptive and one | ||
with all cooperative tasks. | ||
|
||
**Step 2** | ||
|
||
Calculate the WCRT for each task in the preemptive timing table as per [2], | ||
eq. (1). | ||
(The WCRT of the highest priority preemptive task is its WCET.) | ||
|
||
This equation is recursive and must be solved iteratively. | ||
The calculation is finished, once the result converged. | ||
A WCRT calculation iteration limit must be defined after which no convergence | ||
is assumed. | ||
|
||
These are now the final WCRTs for each preemptive task, including interruptions | ||
by other, higher priority preemptive tasks. | ||
|
||
**Step 3** | ||
|
||
Calculate the WCRT' for each task in the cooperative timing table. | ||
|
||
Here, WCRT' denotes the resulting WCRT of a cooperative task caused by | ||
preempting tasks, with the effect of other cooperative tasks not yet included. | ||
|
||
This is done by appending each cooperative task separately (as the lowest | ||
priority task) to the preemptive timing table and calculate this cooperative | ||
task’s WCRT' as per [2], eq. (1). | ||
|
||
Again, this equation is recursive and must be solved iteratively (see step 2). | ||
|
||
**Step 4** | ||
|
||
Calculate the final WCRT for each cooperative task by performing the following | ||
steps for the WCRT' for each task in the cooperative timing table: | ||
|
||
* Step 4.1: Add the sum of all higher priority cooperative task’s WCRT'. | ||
|
||
If it is not the lowest priority task: | ||
|
||
* Step 4.2: Find and add the one longest WCRT' out of all lower priority | ||
cooperative tasks. | ||
* Step 4.3: Substract the time of 1 time tick. | ||
|
||
These are now the final WCRTs for each cooperative task, including | ||
interruptions by preemptive tasks and delays by preemptive and cooperative | ||
tasks. | ||
|
||
Finally, both separate timing tables, the preemptive and the cooperative timing | ||
table, can be joined again (and sorted again by deadline). | ||
|
||
The so calculated WCRTs can then be compared to their task’s deadlines to | ||
detect deadline overruns and assert that the schedulability is feasible. | ||
|
||
## References | ||
|
||
* [1] *Scheduling Algorithms for Multiprogramming in a Hard-Real-Time | ||
Environment* (Journal of the Association for Computing Machinery, Vol. | ||
20, No. 1, 1973-01-01, pp. 46--61; C. L. Liu, J. W. Layland) | ||
* [2] *Finding Response Times in a Real-Time System* (The Computer Journal, | ||
Vol. 29, No. 5, 1986; M. Joseph, P. Pandya) |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Oops, something went wrong.