This application claims priority to European Application No. 16189369 filed on Sep. 18, 2016, which is incorporated herein by reference in its entirety and made a part thereof.
The present invention concerns a method and apparatus for executing a plurality of tasks under real-time constraints.
A program specifies a computation.
A real-time program specifies a computation of one or more tasks that have real-time constraints.
A task is a portion of a computation of a program.
A real-time constraint specifies that the computation of a task must have progressed up to a certain point, which could for example be the end of the task, within a predefined duration in wall clock time. The predefined duration in time is also known as the time between the activation of a task and a deadline of a task.
When the real-time program is executed, a plurality of tasks specified by the program may execute concurrently.
One or more real-time tasks may execute concurrently with tasks that do not have real-time constraints. The latter tasks are also referred to as non-real-time tasks (non-RT tasks).
A real-time task (RT-task) typically executes on the same execution unit from the start of said task to the end of said task.
When a plurality of tasks execute on the same execution unit, concurrent execution means that the plurality of tasks use the execution unit in a time sharing manner. Time sharing refers to the allocation of each task of the concurrent tasks to the execution unit. Time sharing is controlled by a scheduler. The scheduler may be a hardware or software scheduler or a combination thereof. Preferably the scheduler is controlled by the operating system. The operating system is preferably a real-time operating system.
When referring to “time” in the context of real-time computations, two different concepts are distinguished: The first concept of “time” concerns “execution time,” sometimes also referred to as “CPU time,” which refers to the time that a task actually makes use of an execution unit. The second concept of “time” concerns “wall clock time.” Likewise, the term “duration” refers to wall clock time, which is the difference between an end point and a start point in wall clock time. For example, the start of a task and the deadline of a task are typically specified as absolute or relative points in wall clock time, i.e., in wall clock times. The wall clock time between the activation time of a task and its end is also referred to as “response time”. When the execution unit is not shared among a plurality of tasks, only a single task is allocated to the execution unit, the concepts of “wall clock time” and “execution time” are identical under the assumption that the single task is always active. A task is active if it is ready to execute, i.e., if it is not waiting, e.g., for input which may, e.g., be provided by other tasks. When it is clear from the context, the wording in the following uses the term “time”, otherwise it is explicitly distinguished between “execution time” and “wall clock time”.
Similar to sharing of the execution unit, other resources may be shared among concurrent tasks wherein sharing is likewise controlled by a resource allocator which may be a unit of an operating system. The present disclosure and the techniques presented herein primarily relate to the sharing of the execution units wherein the resource allocator is a scheduler. When sharing concerns resources other than an execution unit, this is explicitly mentioned herein. The following terms are typically used in the real-time theory: “active resource” refers, e.g., to an execution unit or communication bus; “passive resource” refers, e.g., to variables or memory shared among different OS threads.
An execution unit is typically a processor core. Modem processors typically include a plurality of cores and are thus called multi-core or many-core processors. The architecture of such processors is commonly such that the cores share common resources on the processor, for example a cache, a communication bus, and a memory interface. This type of sharing due to the architecture of a multicore-processor has the effect that the execution of a first task on a first core may affect the timing of an execution of a second task on a second execution core.
For real-time programs, this type of resource sharing based on the processor architecture affects the prediction of the worst-case execution time. Specifically, the worst case execution time, WCET, which is an execution time in the above sense and which is predicted by conventional methods that take into account any possible and specifically also extremely unlikely interactions among processor cores through their sharing of architectural resources, may lead to extremely pessimistic WCET predictions that are much above realistic common case execution times. This large discrepancy makes the prediction results of WCET determined by conventional methods of little use on multicore architecture, since, when provided as input to a scheduler, lead to very pessimistic real-time schedules that do not achieve efficient resource utilization. While the problem is particularly relevant for multicore architectures as described, resource sharing also occurs when multiple concurrent tasks execute in a time-sharing manner on a processor with a single execution unit, which is e.g. a processor core, since, for example, the cache memory associated with the execution unit is shared among the concurrent tasks.
Claire Pagetti, Christine Rochange: “Runtime monitoring of time-critical tasks in multicore systems” (available at http://materials.dagstuhl.de/files/15/15121/15121.ClairePagetti.ExtendedAbstract.pdf) describe a method which monitors critical tasks at run time, wherein in case of a delay and thus a possible violation of real-time properties, other less critical tasks are interrupted to allow the critical task to continue its execution in a timely and efficient manner, without sharing resources of the execution unit with other tasks.
Michael Paulitsch: “Challenges for the Use of Multicore Processors in Mixed-Criticality Systems with Focus on Temporal Aspects”, RTAS 2014 (available at: http://2014.rtas.org/wp-content/uploads/Paulitsch.pdf). Slide number 11: “WCET for Multi-Core Computers Combined with Monitoring” describes the possibility to execute tasks with real-time constraints on multicore processors.
To summarize the aforementioned problem, the high discrepancy between predicted WCET and common case execution times on modern processor architectures makes conventional techniques of WCET inefficient to control real-time execution and scheduling decisions on such architectures. The present disclosure addresses this problem.
The present invention is concerned with a method for executing a program including a plurality of tasks, wherein one or more tasks of the plurality of tasks have real-time constraints, the method comprising the following steps for each task Tx with real-time constraints: (a) determining a real-time reference model, wherein the real-time reference model of task Tx includes a plurality of micro tasks μTxi, i ε {1, . . . , n} which are a partitioning of task Tx, and an order among the micro tasks μTxi according to all possible execution paths of task Tx, wherein for each micro task μTxi, i ε {1, . . . , n}, a micro budget μBxi which is smaller than the worst case execution time, WCET, of micro task μTxi is determined; and wherein, for each micro task μTxi, i ε {1, . . . , n}, based on the micro budgets μBxk, k ε {1, . . . , n}, a reference timing is determined that specifies an estimated timing of micro task μTxi in any possible execution of task Tx, such that all possible continuations of executions of task Tx from micro task μTxi onward meet the real-time constraints of task Tx with a probability above a tolerance boundary, wherein the real-time constraints of task Tx are met with a probability above the tolerance boundary if the execution of task Tx completes before a deadline of task Tx with a probability lower than 100% and above a certain minimum service guarantee; (b) executing the plurality of tasks and (b1) determining after execution of micro task μTxi an actual timing; (b2) comparing the actual timing to the reference timing; (b3) based on the comparing, if it is determined that the real-time constraints of task Tx are not met with a probability above the tolerance boundary, increasing the priority of task Tx.
This has the technical effect and advantage that the priority of real-time tasks can be adjusted according to the actual timing of the task, wherein the priority of delayed tasks may be increased. Hence a situation can be avoided where a task that has progressed sufficiently uses the execution unit, while other tasks remain delayed since they are not scheduled to run.
According to an embodiment, the micro tasks μTxi i ε {1, . . . , xLast} form a lattice with μTx1 as an initial micro task of Tx and μTxLast as a final micro task of Tx, the micro budget μBxi specifies an execution time to complete execution of micro task μTxi with a probability lower than 100% and above a predetermined probability threshold, and the micro budget μBxi of a micro task μTxi is preferably determined on the basis of static analysis and/or abstract interpretation of a program of μTxi and/or statistical analysis of executions of μTxi.
This has the technical effect and advantage that the micro budgets and correspondingly the budgets of tasks are less conservative than budgets estimated by conventional WCET analyses. If budgets determined according to the embodiment are used for resource allocation through a scheduler, the risk of resource over provisioning can be reduced and thus efficiency of resource allocation and resource use can be improved.
According to an embodiment, the reference timing of micro task μTxi includes a micro deadline μDxi, which specifies a response time up to which an execution of micro task μTxi should be finished, wherein the response time is a duration relative to an activation time ATTx of the task Tx; the micro task μTxi should preferably be finished until each of the micro tasks μTxk k ε {1, . . . , i} on a critical path from an initial micro task μTx1 to a micro task μTxi has finished execution, wherein the execution time of each micro task μTxk is estimated by its micro budget μBxk; the real-time constraints of task Tx are not met with a probability above the tolerance boundary if the actual timing at the end of micro task μTxi exceeds the time by which micro task μTxi should have preferably been finished; and the critical path to micro task μTxi is a path among all possible execution paths of Tx from the initial micro task μTx1 to micro task μTxi which has the longest predicted execution time.
According to an embodiment, the micro deadline μDxi is at least the sum of micro budgets μBxi of micro tasks μTxk, k ε {1, . . . , i} on the critical path to micro task μTxi.
According to an embodiment, the reference timing of micro task μTxi includes a planned activation budget BWCETxi which specifies an execution time budget that is sufficient to complete the execution of task Tx starting from micro task μTxi such that its real-time constraints are met with a probability above the tolerance boundary; the execution time budget is determined based on the micro budgets μBxk of the each of the micro tasks μTxk, k ε {i, . . . , xLast} on an active critical path within Tx starting at micro task μTxi; the active critical path starting at micro task μTxi is a path among all possible execution paths of Tx from μTxi to a final micro task μTxLast which has the longest predicted execution time; the real-time constraints of task Tx are not met with a probability above the tolerance boundary if, before execution of micro task μTxi, the actual response time of micro task μTxi−1 is larger than the micro deadline μDxi−1.
According to an embodiment, the micro tasks in an execution of task Tx are categorized into soft real-time micro tasks μTxi, i ε {1, . . . , xrt−1} and hard real-time micro tasks μTxi, i ε {xrt, . . . , xLast}, wherein an execution time of a soft real-time micro task μTxi is estimated by its micro budget μBxi; and wherein an execution time of a hard real-time micro task μTxi is estimated by its micro budget μBxi plus a buffer time BT(μTxi), the buffer time being an additional time to guarantee that μTxi finishes with 100% certainty within the time estimated; and wherein the execution time budget is determined further based on a sum of the estimated execution times of soft real-time and hard real-time micro task μTxi.
According to an embodiment, the method comprises the following additional step: adding one or more instructions to a program of task Tx, the instructions causing the emission of a trace event Exi, at the end of the execution of micro task μTxi, the trace event comprising a unique identifier of a portion of the execution of task Tx, wherein the unique identifier preferably comprises an identifier of a hardware unit which executes task Tx, an identifier of task Tx, and an identifier of the trace event Exi.
According to an embodiment, step (b1) of the method further comprises the steps of: determining, for an execution unit that executes the plurality of tasks, a partial actual real-time state comprising, for each task Tx, the most recently emitted trace event Exi including a point in time CTExi when the trace event Exi was emitted; and determining a difference ΔSμTxi=CTExi−1−μDxi−1 between an actual activation time CTExi−1 of micro task μTxi and a planned activation time of micro task μTxi, wherein the planned activation time of micro task μTxi is the micro deadline μDxi−1 of the preceding micro task μTxi−1.
According to an embodiment, step (b2) further comprises determining an actual activation budget of micro task μTxi which is the planned activation budget BWCET,xi corrected by ΔSμTxi.
According to an embodiment, in step (b3), the priority of a task Tx is increased such that the smaller the difference Dx−CT−BWCETxi the higher the priority of Tx wherein Dx specifies the deadline of task Tx in wall clock time, CT specifies the current wall clock time, and BWCETxi is the actual activation budget in execution time of micro task μTxi, when trace event Exi is the most recently emitted trace event of task Tx.
According to an embodiment, the sequence of steps (b1), (b2), and (b3) is repeated in predetermined intervals until the execution of the plurality of real-time tasks is terminated, and the predetermined intervals are preferably regular.
According to an embodiment, determining the real-time reference model of task Tx comprises determining possible executions of Tx using methods of Worst Case Execution Time, WCET, analysis of a program of Tx, wherein methods of WCET analysis preferably comprise: determining a control-flow graph of the program of task Tx, determining feasible value ranges for variables of task Tx, determining a maximum number of loop iterations, modelling cache and memory access, and determining critical paths in the control flow graph, and wherein the control flow graph includes all possible execution paths of task Tx.
According to an embodiment, each task of the plurality of tasks is allocated to a fix execution unit during a planning period and the fix execution unit is preferably a core of a plurality of cores of a multi-core processor, and execution time is reserved on the fix execution unit according to estimated execution times of all micro tasks μTxi of all real-time tasks Tx allocated to the fix execution unit, wherein reserving is preferably done by a scheduler which is an OS scheduler.
According to an embodiment, the budget BWCETx of task Tx is the planned activation budget BWCETxi of the initial micro task μTx1 of task Tx, wherein a plurality of tasks may be allocated on a same execution unit as long as the following constraints are met: the sum of estimated execution times for the hard real-time micro tasks of each task of the plurality of tasks does not exceed a certain first portion of a maximum utilization of the execution unit during the planning period; and the sum of the budgets of real-time tasks allocated to the same execution unit does not exceed a certain second portion of the maximum utilization of the execution unit during the planning period.
According to an embodiment, if a difference between an actual activation time of micro task μTxi and a planned activation time of micro task μTxi is negative, a portion of the execution time within the planning period reserved on the execution unit for execution of task Tx with real-time constraints is released and thus available for execution of other tasks, wherein the planned activation time of micro task μTxi is the micro deadline μDxi−1 of the preceding micro task μTxi−1, and wherein the amount of released time is lower or equal to a difference between the actual time remaining until the deadline of Tx and the planned activation budget BWCETxi.
The present invention is further concerned with a method for executing a plurality of tasks, wherein one or more tasks have real-time constraints, based on a reference model of each task with real-time constraints, wherein the reference model is determined according to step (a) according to one of the embodiments specified previously, wherein the method comprises the steps (b1), (b2), and (b3) according to one of the embodiments specified previously.
The present invention is further concerned with a method for determining a real-time reference model of a task Tx, wherein said task has real-time constraints, the method comprising step (a) according to one of the embodiments specified previously.
The present invention is further concerned with an apparatus for executing a program including a plurality of tasks, wherein one or more tasks of the plurality of tasks have real-time constraints, the apparatus comprising the following hardware units: one or more execution units adapted to execute the plurality of tasks; a calibration unit adapted to determine a real-time reference model, wherein the real-time reference model of task Tx includes a plurality of micro tasks μTxi, i ε {1, . . . , n} which are a partitioning of task Tx, and an order among the micro tasks μTxi according to all possible execution paths of task Tx, wherein, for each micro task μTxi, i ε {1, . . . , n}, a micro budget μBxi which is smaller than the worst case execution time, WCET, of micro task μTxi determined; and wherein, for each micro task μTxi, i ε {1, . . . , n}, based on the micro budgets μBxk, k ε {1, . . . , n}, a reference timing is determined that specifies an estimated timing of micro task μTxi in any possible execution of task Tx, such that all possible continuations of executions of task Tx from micro task μTxi onward meet the real-time constraints of task Tx with a probability above a tolerance boundary, wherein the real-time constraints of task Tx are met with a probability above the tolerance boundary if the execution of task Tx completes before a deadline of task Tx with a probability lower than 100% and above a certain minimum service guarantee; an event monitoring unit adapted to determine after execution of micro task μTxi an actual timing; a budget time monitoring unit adapted to compare the actual timing to the reference timing; a hardware scheduling unit adapted to increase the priority of task Tx based on a comparison result of the budget time monitoring unit, if it is determined that the real-time constraints of task Tx are not met with a probability above the tolerance boundary.
According to an embodiment, the event monitoring unit is further adapted to maintain, for each real-time task Tx, a most recently emitted trace event Exi including a point in time CTExi when the trace event Exi was emitted; the apparatus further comprises a deadline monitoring unit adapted to estimate a difference ΔSμTxi=CTExi−1−μDxi−1 between an actual activation time CTExi−1 of micro task μTxi and a planned activation time of micro task μTxi, and/or to detect if an execution of a micro task μTxi finishes after micro deadline μDxi; the budget time monitoring unit is further adapted to determine, for each real-time task Tx, a deviation between a planned timing of task Tx and an actual timing of task Tx, wherein the planned timing of task Tx before execution of micro task μTxi is the planned activation budget BWCETxi, and wherein the actual timing of task Tx is estimated based on an amount of CPU time used by task Tx up to the response time CTExi−1 and the difference ΔSμTxi; and the hardware scheduling unit is further adapted generate a real-time control value for a real-time task Tx based on a deviation of the planned timing of Tx from the actual timing of task Tx, and wherein the real-time control value is signaled to an OS scheduler.
According to an embodiment, the calibration unit is further adapted to carry out measurements of execution time of a micro task; based on the measurements, to determine information about the execution time of the micro task; and to store the information in the real-time reference model.
According to an embodiment, the information about the execution time of a micro task is a probability distribution of an execution time between a trace event marking a start of the micro task and a subsequent trace marking an end of the micro task.
The present invention is further concerned with an apparatus for executing a program including a plurality of tasks, wherein one or more tasks of the plurality of tasks have real-time constraints, the apparatus comprising: a plurality of execution units adapted to execute the plurality of tasks; a real-time scheduling unit holding a real-time reference model which includes a planned core budget BCOREy for each execution unit COREy of the plurality of execution units, wherein the planned core budget BCOREy of an execution unit COREy specifies an upper bound for the execution time that is required to complete all active RT tasks in time with the minimum service guarantee, wherein the planned core budget may be estimated as a maximum utilization of an execution unit during each planning period for micro tasks in the hard-RT or soft-RT category respectively over all planning periods considered during the calibration phase of a program including the real-time tasks, wherein a real-time task Tx is active if the following two conditions are met: first, the execution of task Tx has already started, i.e., the trace event Ex0 has been emitted and second the last emitted event is not ExLast, i.e., the task Tx has not yet finished; alternatively, BCOREy may also be determined using conventional methods of schedulability analysis based on micro bugets; a budget time monitoring unit adapted to determine, for each COREy of the plurality of execution units, an actual core budget, being a reservation of execution time for real-time tasks allocated to COREy, and possible deviations between said actual core budget and the planned core budget BCOREy, wherein the actual core budget is the execution time on COREy that is reserved at a certain point of time within the planning period, which is preferably estimated, for example, based on the micro budgets μBxi of all micro tasks μTxi of real-time tasks Tx allocated to COREy that are active at any point in time within the planning period; and a core interference manager adapted to send core penalty signals if the actual core budget for COREy exceeds the planned core budget BCOREy, wherein the core penalty signals are sent to one or more other execution units COREz for which a planned core budget BCOREz exceeds an actual core budget for COREz, the core penalty signals causing, when received by the one or more other execution units, the one or more other execution units to be de-prioritized for a predefined period of wall clock time.
According to an embodiment, de-prioritizing an execution unit includes halting the execution unit for a predefined period of wall clock time.
This has the effect and advantage that an execution unit which is temporarily halted does not contend for shared resources, e.g. on chip resources shared among execution units on the same chip, so that other execution units can access and use such shared resources with less delay.
According to an embodiment, the planned core budget BCOREy includes a planned core budget for hard real-time micro tasks HardBCOREy on COREy and a planned core budget for soft real-time micro tasks SoftBCOREy on COREy, wherein HardBCOREy is estimated based on planned budgets of micro task μTxi in the hard real-time category for all active real-time tasks Tx allocated to COREy, and wherein SoftBCOREy is estimated based on planned budgets of micro task μTxi in soft real-time category for all active real-time tasks Tx allocated to COREy.
According to an embodiment, a core penalty signal targeted to an execution unit of the one or more other execution units is sent only at a point in time which is non-critical for the execution unit.
This has the advantage and effect that execution units that execute real-time tasks that are themselves delayed are not penalized, i.e., de-prioritized.
According to an embodiment, a point in wall clock time at an execution unit to which the core penalty signal is targeted is non-critical if said execution unit is not reserved for execution of hard real-time micro tasks from said point in wall clock time for the predefined period of wall clock time.
According to an embodiment, the hardware scheduling unit is further adapted to, if a difference between the actual activation time of micro task μTxi and a planned activation time of micro task μTxi is negative, release a portion of the execution time, reserved within the planning period on the execution unit for the execution of a task Tx with real-time-constraints, and thus make available the portion for execution of other tasks, wherein the planned activation time of micro task μTxi is the micro deadline μDxi−1 of the preceding micro task μTxi−1, and wherein the amount of released time is lower or equal to a difference between the actual time remaining until the deadline of Tx and the planned activation budget BWCETxi.
This has the technical effect and advantage that execution time which has been reserved but not used by real-time tasks may be released in a timely manner even before the real-time task terminates so that other tasks may make use of the resource. Overall, this leads to an improved resource utilization.
The present invention is further concerned with a method for executing a program including a plurality of tasks, wherein one or more tasks of the plurality of tasks have real-time constraints, wherein the plurality of tasks are executed on a plurality of execution units, the method comprising the following steps: maintaining a real-time reference model including a planned core budget BCOREy for each execution unit COREy of plurality of execution units, wherein the planned core budget BCOREy of an execution unit COREy specifies an upper bound for the execution time that is required to complete all active RT tasks in time with the minimum service guarantee, wherein the planned core budget may be determined as a maximum utilization of an execution unit during each planning period for micro tasks in the hard-RT or soft-RT category respectively over all planning periods considered during the calibration phase of a program including the real-time tasks; determine, for each COREy of the plurality of execution units, an actual core budget, being a reservation of execution time for real-time tasks allocated to COREy, and possible deviations between said actual core budget and the planned core budget BCOREy, wherein the actual core budget is the execution time on COREy that is reserved at a certain point of time within the planning period, which is preferably estimated, for example, based on the micro budgets μBxi of all micro tasks μTxi of real-time tasks Tx allocated to COREy that are active at any point in time within the planning period; and sending core penalty signals if the actual core budget for COREy exceeds the planned core budget BCOREy, wherein the core penalty signals are sent to one or more other execution units COREz for which a planned core budget BCOREz exceeds an actual core budget for COREz, the core penalty signals causing, when received by the one or more other execution units, the one or more other execution units to be de-prioritized for a predefined period of wall clock time.
The features provided herein have at least the following advantages:
The techniques presented herein enable that the timing of an execution of a task can be controlled, even on a multicore CPU.
Furthermore, the techniques presented herein enable to implement hard real-time applications on modern CPU architectures with shared resources and multiple cores, wherein hard real-time application require certain minimum service guarantees.
Furthermore, the techniques presented herein enable to combine the execution of real-time and non-real-time tasks without compromising on real-time properties due to negative effects of sharing resources in modern hardware and processor platforms. It may further be possible to use non-real-time operating systems, such as Windows or Linux, for executing real-time applications.
Furthermore, the techniques presented herein enable new possibilities for implementing safety, security and isolation policies in real-time systems.
The techniques disclosed here within concern the timely execution of real-time programs, preferably on modern processor architectures.
The method according to the present disclosure has two principal phases shown in
A real-time program may execute on a system with a multicore processor. An example of such system is illustrated in
These additional steps are executed alongside the steps for carrying out the computation according to the program of the real-time task; these additional steps should preferably not negatively affect, i.e., delay the computation according to the program of the real-time task. For that reason, efficient support for carrying out these additional steps, for example by additional hardware units of the RTSU, is provided in order not to negatively affect or delay the operation of units known from the system without extensions as illustrated in
The calibration unit supports the creation of the real-time reference model according to the first phase 100 of
The event monitoring unit supports determining the occurrence of so called trace events, or simply called events, during the execution of a real-time task. A trace event, event for short, is emitted by a certain instruction in the program of a task.
To emit events during the execution of a task Tx, one or more instructions are added to the program of task Tx, the instructions causing the emission of a trace event Exi, at the end of the execution of a micro task μTxi, the trace event comprising a unique identifier of a portion of the execution of task Tx. Thereby, the unique identifier preferably comprises an identifier of a hardware unit which executes task Tx, an identifier of task Tx, and an identifier of the trace event Exi.
When an event occurs, i.e., when an event is emitted during the execution of a task Tx, information about the event, which includes the wall-clock time at which the event is emitted, may first be written to an efficient storage within a processor, which could e.g. be a register. The information may then be obtained from such register by the event monitoring unit, e.g. to perform updating of the global actual timing model (GATM). Furthermore, the event monitoring unit may maintain for each task Tx one or more of an actual execution path and response times of micro tasks μTxi, which completed on the actual execution path based on a partial actual real-time state comprising, for each task Tx, a most recently emitted trace event Exi including a point in time CTExi when the trace event was emitted.
The deadline monitoring unit detects if an execution of a micro task μTxi finishes after micro deadline μDxi. Furthermore, the deadline monitoring unit may determine for each task, based on the most recent trace event of the task, which specifies the progress the task has made up to a certain point in wall-clock time, a reference time obtained from the global reference timing model (GRTM) of the task, and the actual remaining wall clock time until the deadline, whether the priority of the task is to be increased, which is effected by the hardware scheduling unit. In other words, the deadline monitoring unit is designed to estimate a difference ΔSμTxi=CTExi−1−μDxi−1 between an actual activation time CTExi−1 of micro task μTxi and a planned activation time of micro task μTxi, and/or to detect if an execution of a micro task μTxi finishes after micro deadline μDxi.
A core interference manager may increase the priority of the execution unit or priority of hardware resources shared by the execution unit on which the task is allocated. Thereby the reference time may be a planned remaining execution time of a task, which is expressed as the activation budget of the task. For determining whether the priority of a task is to be increased, a difference between said reference time and the remaining wall-clock duration to the deadline of the task may be determined. For example, if it is determined that the wall-clock duration until the deadline of the task is only slightly higher or equal to the activation budget, which is a predicted execution time until the end of the task according to the real-time reference model, then the priority of this task vs. other concurrent tasks on the same execution unit is likely increased. The reasons for such a scenario can be as follows: the actual execution time required by the task is high and for soft-RT tasks possibly higher than estimated in the real-time reference model and/or the execution of the task is delayed in wall-clock time due to intermittent execution of other concurrent tasks on the same execution unit.
The budget time monitoring unit manages budget times for real-time tasks on all execution units, wherein the budget, as will be explained later, falls into the categories of budget reserved for hard-RT micro tasks and soft-RT micro tasks. The budget time monitoring unit determines for each execution unit and each task allocated to this execution unit, a difference between the execution time used by task Tx up to the most recent trace event Exi of Tx and the planned execution time reserved on the execution unit for Tx up to the end of micro task μTxi, which is included in the real-time reference model and which is also called the micro deadline μDxi of micro task μTxi. In other words, the budget time monitoring unit is designed to determine for each task Tx, a deviation between a planned timing of task Tx and an actual timing of task Tx, wherein the planned timing of task Tx before execution of micro task μTxi being the planned activation budget BWCETxi, and wherein the actual timing of task Tx is estimated based on an amount of CPU time used by the task Tx up to the response time CTExi'1 and the difference ΔSμTxi. If more time has been reserved than used by the actual execution of Tx up to that point, i.e., the real-time task Tx took less execution time than planned, so that excess budget reserved on the execution unit may be released and made available to other tasks (e.g. non-RT) on the same execution unit. On the other hand, if the execution time used by a task up to Exi is larger than what has been reserved as budget on that execution unit, measures are taken to ensure that the operation the execution unit may be prioritized over other execution units, e.g., that one core is prioritized over another core in a multicore CPU system. Such prioritization is effected by the core interference manager unit. It should be noted that the situation that more execution time is taken by a task than actually planned and reserved may only arise while the task is executing micro tasks in the soft-RT category as will be explained later in more detail. For tasks in the hard-RT category, the planned budget is always sufficiently high, since it is calculated based on the WCET of micro tasks.
For further illustration, the following scenario is described: The deadline monitoring unit may determine for a task Tx that, based on the wall-clock timing of the task which is given as the actual progress based on the most recently emitted trace event, the estimated remaining execution time of the task, and the wall clock duration remaining to the deadline of the task that the task is to be prioritized over other concurrent tasks. On the other hand, for the same task, the budget time monitoring unit may determine that the task required less execution time than estimated and thus release reserved budget on the CPU.
The hardware scheduling unit, HW scheduling unit, notifies an operating system scheduler to adjust the priority of a real-time task. The HW scheduling unit bases its decision to issue said notification based on information obtained from the deadline monitoring unit and/or the budget time monitoring unit.
Furthermore, the RTSU includes a core interference manager, which provides hints for prioritizing certain execution units on the multicore CPU for use of shared processor resources such as such as shared caches or interconnect bandwidth. The hints are provided on the basis of information from the deadline monitoring unit or the budget time monitoring unit. Since each task is pinned, i.e., fixed, to a certain execution unit, the core interference manager hints at prioritizing resource use for execution units, which are for example processor cores, that execute tasks for which higher priority is requested by the HW scheduling unit.
The method for executing a program including a plurality of tasks with real-time constraints, which steps are supported in part by the RTSU and its units as described above, is described in more detail based on
Thus, the real-time reference model of task Tx includes a plurality micro tasks μTxi, i ε {1, . . . , n}, which are a partitioning of task Tx, and an order among the micro tasks μTxi according to all possible execution paths of task Tx. Thereby, for each micro task μTxi, i ε {1, . . . , n}, a micro budget μBxi is determined which is smaller than the worst case execution time, WCET, of micro task μTxi. The micro budget μBxi specifies an execution time to complete execution of micro task μTxi with a probability lower than 100% and above a predetermined probability threshold. Furthermore, for each micro task μTxi, i ε {1, . . . , n}, based on the micro budgets μBxk, k ε {1, . . . , n}, a reference timing is determined that specifies an estimated timing of micro task μTxi in any possible execution of task Tx, such that all possible continuations of executions of task Tx from micro task μTxi onward meet the real-time constraints of task Tx with a probability above a tolerance boundary, wherein the real-time constraints of task Tx are met with a probability above the tolerance boundary if the execution of task Tx completes before a deadline of task Tx with a probability lower than 100% and above a certain minimum service guarantee.
Back to
Back to
The following terminology and identifiers are defined and used in
Back to
As will be described in the following, task allocation occurs before the calibration step 130. This is because information about which tasks are allocated on the same execution unit, which is also referred to as task colocation, may affect the timing behavior of each micro task, and thus also each task due to the sharing of resources on an execution unit and also among different execution units within the same execution unit. For example multiple tasks that execute on the same execution unit, which could for example be a processor core, may share the L1 cache. Tasks allocated on different execution units may share the L2 cache. Timing behavior refers to a statistical model that considers a statistical distribution of execution times observed for repeated test executions of each micro task in a specific allocation of tasks to execution units determined at step 120.
Referring to
Calibration requires execution models of all tasks that are allocated in step 120. The execution models of these tasks are determined in step 110. Furthermore, the calibration is controlled by a statistical threshold value, for example 75%, which is predetermined, for example, by a software developer, and which serves to determine an estimated execution time for each micro task based on a probability distribution of the execution duration of the micro task. Accordingly, for a threshold value of Pthr, the estimated execution duration of micro task μTxi is the duration to complete execution with a probability lower than 100% and above the threshold value Pthr. This estimated execution duration is also referred to as micro budget μBxi of a task μTxi.
Step 130 is further detailed in
Further, in a second step 132, for each micro task μTxi, i ε {1, . . . , n}, based on the micro budgets μBxk, k ε {1, . . . , n}, a reference timing is determined that specifies an estimated timing of micro task μTxi in any possible execution of task Tx up to the end of micro task μTxi, such that all possible continuations of executions of task Tx according to the execution model of the task Tx meet the real-time constraints of task Tx with a probability above the tolerance boundary.
In one example of step 132, the reference timing may be a micro deadline. Hence the reference timing of micro task μTxi includes a micro deadline μDxi, which specifies a response time up to which an execution of micro task μTxi should be finished, wherein the response time is a duration relative to an activation time ATTx of the task Tx. Based on the determined micro budgets, micro deadlines μDxi, are determined as shown in
Hence micro task μTxi should preferably be finished until each micro task μTxk k ε {1, . . . , i} on a critical path from an initial micro task μTx1 to micro task μTxi has finished execution, wherein the execution time of each micro task μTxk is preferably estimated by its micro budget μBxk, wherein the real-time constraints of task Tx are not met with a probability above the tolerance boundary if the actual timing at the end of micro task μTxi exceeds the time by which micro task μTxi should have preferably been finished, wherein the critical path to micro task μTxi is a path among all possible execution paths of Tx from an initial micro task to micro task μTxi which has the longest predicted execution time. Specifically, according to the above formula, the micro deadline μDxi is at least the sum of micro budgets μBxi of micro tasks μTxk, k ε {1, . . . , i} on the critical path to micro task μTxi.
The start of task Tx, may thereby be specified as a start time Sx, which is the time at which event Ex0 is emitted. Alternatively, the start time of a task may be specified as the activation time of Tx, which is ATTx. In both cases, times are specified as wall clock times. The activation time ATTx specifies a time at which task Tx is ready to execute, which is, for example, the time at which possible dependences of the task to other tasks are fulfilled. The start time STx specifies the time when the task Tx actually starts execution, i.e., the time at which it is actively executing. The start time may thus be a later point in time than the activation time ATTx, wherein the delay of the start is also referred to as jitter JTx, such that STx=ATTx+JTx.
For the purpose of the model described herein, it may be assumed that the deadlines of a task Tx, including micro deadlines μDxi, are specified relative to the activation time ATTx. Alternatively or in addition, if the system, for example the OS scheduler, guarantee that there is an upper bound for the jitter JTx and that after starting Tx, event Ex0 is emitted in any case before the scheduler chooses another task on the same execution unit for execution, the deadlines of a task Tx, including micro deadlines μDxi, may be specified relative to the start time STx.
In another example of step 132, the reference timing is a planned activation budget BWCET,xi for micro task μTxi. A planned activation budget specifies a duration, in the sense of CPU time—not wall clock time, that is sufficient to complete the execution of task Tx starting from micro task μTxi onwards such that its real-time constraints are met with a probability above the tolerance boundary. This planned activation budget is determined by the sum of durations of each of the micro tasks μTxk, k ε {i, . . . , xLast} on the active critical path within Tx starting at micro task μTxi. This determination is described in detail in the following with reference to
Prob(CTExLast>Dx)=(1−Pthr)#Events
Conversely, if few micro tasks remain, the probability of not meeting the deadline of the task may by larger and even may become larger than the tolerated risk of not meeting the deadline, which has correspondence to a minimum service guarantee. These probabilities are shown in
An execution time of a soft real-time micro task μTxi is estimated by its micro budget μBxi. An execution time of a hard real-time micro task μTxi is estimated by its micro budget μBxi plus a buffer time BT(μTxi), the buffer time being an additional time to guarantee that μTxi finishes with 100% certainty within the time estimated. For determining a planned activation budget BWCETxi, the execution time budget is based on a sum of the estimated execution times of soft real-time and hard real-time micro task μTxi. This is also expressed in the formula below.
The following terminology and identifiers are defined and used
The required CPU budget of task Tx is thus calculated as follows:
B
WCETx=Σk=0#CP events
The worst case CPU budget for a micro task is calculated as follows:
Hence, for a micro task μTxi, the worst case CPU budget BWCETxi has two components namely a soft real-time and a hard real-time component according to the above.
Accordingly, for a task Tx, the required CPU budget can also be split into hard and soft real-time components corresponding to the above calculation for each micro task, so that:
B
WCETx=SoftBWCETx+HardBWCETx
Both examples of step 132 may also be combined, i.e., the reference timing information includes micro deadlines according to the first example and also budgets and buffer times according to the second example. The reference timing information determined in step 132 is associated with the respective micro task μTxi in the execution model of task Tx to obtain the real-time reference model for task Tx.
In summary, step 130 achieves that for each micro task μTxi, i ε {1, . . . , n} a micro budget μBxi is determined which is smaller than the worst case execution time, WCET, of micro task μTxi. Finally, the calibration should be renewed, i.e., step 130 is to be repeated, whenever the program of a task is changed. The calibration step 130 may also be repeated when the task allocation determined in step 120 is changed, since such change could impact the resource sharing and possibly lead to changes in the statistical execution times which are a basis for determining micro budgets, micro deadlines etc.
Referring to step 140 in
The selection of tasks to allocate on a specific execution unit COREy may be determined through varying the allocated real-time tasks and maximizing the time reserved for real-time tasks on COREy, i.e., to determine MAX(BCOREy) under the following constraint, which must be met for a permissible allocation:
Hence, assuming that the budget BWCETx of task Tx is the planned activation budget BWCETx1 of the initial micro task μTx1 of task Tx, a plurality of tasks may be allocated on the a same execution unit as long as the following constraints are met: the sum of estimated execution times for the hard-RT micro tasks of each task of the plurality of tasks does not exceed a certain first portion of the a maximum utilization of the execution unit during the planning period; and the sum of the budgets of the RT-tasks allocated to the same execution unit does not exceed a certain second portion of the maximum utilization of the execution unit during the planning period. In
In one example, the planned core budget BCOREy includes a planned core budget for hard real-time micro tasks HardBCOREy on COREy and a planned core budget for soft real-time micro tasks SoftBCOREy on COREy, wherein HardBCOREy is the sum of planned budgets of micro task μTxi in the hard real-time category for all active real-time tasks Tx allocated to COREy, and wherein SoftBCOREy is the sum of planned budgets of micro task μTxi in soft real-time category for all active real-time tasks Tx allocated to COREy.
A real-time task Tx is active if the following two conditions are met: First, the execution of task Tx has already started, i.e., the trace event Ex0 has been emitted, and second the last emitted event is not ExLast, i.e., the task Tx has not yet finished. Some of the tasks allocated to an execution unit may not be active in that sense, for example, if their synchronization or communication dependences with other tasks are not yet fulfilled. For example in
The planned core budgets provide an upper bound for the execution time that is required to complete all active RT tasks in time with the minimum service guarantee.
In the following the method according to the second phase 200 of
The concepts and the method of step 200 are illustrated on an example real-time task and execution which is specified in
At step 201, the real-time scheduling unit is initialized, wherein the real-time reference model of task Tx is provided to the target hardware and stored in the “GRTM/GATM” storage unit which enables efficient access to the real-time reference model of task Tx by the real-time scheduling unit. In step 201, the execution of task Tx starts at the first micro task μTx1. At the beginning of μTx1 a start trace event Ex0 is issued. Emission of an event leads to an update of the partial actual timing state (PATS) comprising, for each task Tx, a most recently emitted trace event Exi including a point in time CTExi when the trace event is emitted. Hence, after execution of micro task μTxi, an actual timing is determined, which may be a response time from the activation of task Tx to the end of micro task μTxi.
The event monitoring unit is responsible to create and update the CPU wide global actual timing model (GATM). Specifically, the event monitoring unit obtains in the most events recorded in the partial actual timing state (PATS), preferably in regular intervals. Specifically, for each task Tx and each execution unit COREy, the budget values Bx and BCOREy are kept current based on progress observed via the events issued by the tasks and obtained by the event monitoring unit. In one example, the execution time reserved by a scheduler on an execution unit is the sum of HardBWCETk and SoftBWCETk of all active tasks allocated to this execution unit. Correspondingly, the reserved execution time BCOREy for execution unit COREy falls into a component for hard-RT and soft-RT micro tasks. As micro tasks are executed and complete, the event monitoring unit determines the execution times taken for each micro task. If the actual execution time of a micro task has been less than the budget reserved for the micro task, the excess budget can be released, which means that the scheduler releases the reservation and hence can make additional execution time available to other tasks. The hard-RT and soft RT component of BCOREy, depending on whether the micro task is in the hard-RT or soft-RT category, is reduced correspondingly based on the determined execution time of the micro task used and/or the released time.
Hence in one embodiment, if a difference between an actual activation time of micro task μTxi and a planned activation time of micro task μTxi is negative, a portion of the execution time within the planning period reserved on the execution unit for the execution of a task Tx with real time constraints is released and thus available for the execution of other tasks, wherein the planned activation time of micro task μTxi is the micro deadline μDxi−1 of the preceding micro task μTxi−1, and wherein the amount of released time is lower or equal to the difference between the actual time remaining until the deadline of Tx and the planned activation budget BWCETxi.
The global actual timing model (GATM) is preferably managed and updated by the event monitoring unit. The GATM includes, for each task Tx and each execution unit COREy, current values of Bx and BCOREy, which aare maintained current, hence “global” actual timing model.
Furthermore, the event monitoring unit “accumulates” the values of all partial actual timing states (PATS) that are observed since the system start. The value of Bx specifies initially, i.e., before execution of Tx starts, BWCETx as determined during phase I in step 100.
On the example task and execution which is considered here for illustration, the initial reserved budget value is shown in
ΔSμTxi=CTE
Furthermore, an actual activation budget of micro task μTxi is the planned activation budget BWCET,xi preferably corrected by ΔSμTxi. This is shown also in
As soon as the event monitoring unit has updated the GATM, the deadline monitoring unit, the budget time monitoring unit, and the core interference manager are informed. In response, these units may for example cause increase of the priority of a task as has been mentioned above and as will be discussed in more detail below.
In step 202, a micro task is executed, so that the respective trace event at the end of the micro task is issued.
In step 203, an actual timing, including the used execution time of the task and respectively its micro tasks, and a duration remaining to the deadline of the task, is determined after execution of micro task μTxi. The actual timing may also include a response time from the activation and/or start of task Tx to the end of micro task μTxi. The event Exi includes a current timestamp that specifies the time at which the end of μTxi is reached, information about the start of task Tx is included in the GATM based on the accumulated partial real-time states.
In step 204, an actual timing is compared to a reference timing. In one embodiment, in step 204, the actual timing obtained in step 203 and which led to an update of the GATM, is compared to the reference timing included in the global reference timing model GRTM. This comparison is done by the deadline monitoring unit which preferably has very efficient access to the GRTM/GATM storage unit. Specifically the operation of the deadline monitoring unit and the access to the GRTM/GATM storage should preferably not negatively affect or delay the normal operation of the processor, e.g. by sharing resources with execution units that execute real-time tasks. To perform the comparison, the deadline monitoring unit obtains from the GRTM a reference timing value, which could be according to the above, a micro deadline, or an activation budget value of a micro task or combinations thereof. The reference time may, for example, be a planned remaining execution time of a task starting at micro task μTxi, which is expressed as activation budget BWCETxi. For determining whether the priority of a task is to be increased, a difference between said reference time and the remaining wall-clock duration Dx−CT to the deadline Dx of the task may be determined, wherein CT is the current wall clock time, e.g. specified relative to the start of the task. For example, if it is determined that the wall clock duration until the deadline of the task is only slightly higher or equal to the activation budget, which is a predicted execution time until the end of the task according to the real-time reference model, then the priority of this task vs. other concurrent tasks on the same execution unit is likely to be increased as discussed in the following.
In step 205, on the basis of this reference timing value and of deviations between the planned values and the actual values obtained from the GATM and determined by the comparing in step 204, the deadline monitoring unit informs the HW scheduling unit, for example to increase the priority of a task. Specifically, based on the comparing, if it is determined that the real-time constraints of task Tx are not met with a probability above the tolerance boundary, the priority of task Tx is increased. In one example, the HW scheduling unit is designed to generate a real-time control value for a task Tx based on a deviation of the planned timing of Tx from the actual timing of task Tx on the execution unit, specifically the actual timing of a most recently finished micro task μTxi of Tx. The HW scheduling unit is further designed to signal the real-time control value to an OS scheduler.
In another example, the budget time monitoring unit is further designed to determine, for each COREy of the one or more execution units, an actual core budget, being a reservation of execution time for all real-time tasks allocated to COREy, and possible deviations between said actual core budget and a planned core budget BCOREy, wherein the actual core budget is the execution time on COREy that is reserved at a certain point of time within the planning period.
For the purpose of determining the actual core budget, an activation budget of a real-time task is an estimated timing of the real-time task such that all possible continuations of executions of the real-time task meet the real-time constraints of the real-time task with a probability above a tolerance boundary during a planning period. Thereby the actual core budget is determined as the execution time on COREy that is reserved at a certain point in time within the planning period, which is preferably estimated, for example, based on the micro budgets μBxi of all micro tasks μTxi of all active real-time tasks Tx allocated to COREy at any in point in time within the planning period.
For the purpose of determining the planned core budget BCOREy, the planned budget of real-time tasks may be the execution time allocated by a task scheduler, e.g. in the OS, for the active real-time tasks on COREy during a planning period. Thereby the planned core budget BCOREy of an execution unit COREy specifies an upper bound for the execution time that is required to complete all active real-time tasks in time with the minimum service guarantee, wherein the planned core budget may be determined as a maximum utilization of an execution unit during each planning period for micro tasks in the hard-RT or soft-RT category respectively over all planning periods considered during the calibration phase of a program including the real-time tasks. In some examples, the planned core budget BCOREy of an execution unit COREy may be estimated as a maximum utilization of an execution unit during each planning period for micro tasks in the hard-RT or soft-RT category respectively over all planning periods considered during the calibration phase of a program including the real-time tasks. Alternatively, BCOREy may also be determined using conventional methods of schedulability analysis based on micro bugets. In another example, the planned core budget may be the maximum CPU time reserved within a planning period, considering any of the planning periods during a calibration run. In some examples, the planned core budget BCOREy may be estimated based on the micro budgets μBxi of all micro tasks μTxi of all active real-time tasks Tx allocated to COREy during a planning period.
Furthermore in another example, also in step 205, the core interference manager, for example may adjust processor internal priorities of using shared resources such as L2 cache or interconnect or may temporarily suspend the operation of specific execution units, for which all allocated tasks have made sufficient progress. For example the core interference manager may send core penalty signals to execution units other than COREy if the actual use of execution time for real-time tasks on COREy exceeds the planned budget BCOREy. In other words, the core interference manager may send core penalty signals if the actual core budget for COREy exceeds the planned core budget BCOREy, wherein the core penalty signals are sent to one or more other execution units COREz for which a planned core budget BCOREz exceeds an actual core budget for COREz, the core penalty signals causing, when received by the one or more other execution units, the one or more other execution units to be de-prioritized for a predefined period of wall clock time. Thereby de-prioritizing may include halting the execution unit for a predefined period of wall clock time. In some examples, the core penalty signal targeted to an execution unit of the one or more other execution units is sent only at a point in time which is non-critical for the target execution unit, wherein a point in wall clock time at an execution unit to which the core penalty signal is targeted is non-critical if said execution unit is not reserved for execution of hard real-time micro tasks from said point in wall clock time for the predefined period of wall clock time.
The core penalty signals cause, when received by the other execution units, the other execution units to be de-prioritized, preferably for a predefined period of wall clock time. The purpose of such core penalties is to avoid core delay or starvations for shared chip-resources (e.g. interconnect bandwidth). As a result of a core penalty the software execution on the affected core is halted preferably for the predefined period of time. Thereby, a core penalty signal is only sent to other execution units COREz at points in time that that are non-critical for COREz. A non-critical point of time is a world clock time value, wherein, for the duration of the penalty, the real-time behavior on that core is not affected, e.g. when no hard-real-time micro task is running, scheduled, or activated during the penalty period. In some cases, this also means that a planned budget BCOREz exceeds an actual use of execution time for real-time tasks on COREz.
Furthermore in another example, also in step 205, a portion of the execution time within the planning period reserved on the execution unit for the execution of a task Tx with real time constraints may be released according to the above.
When the hardware scheduling component is informed to increase priority of task, it may be decided by how much the priority is to be increased. The goal of step 205 and the method overall is to cause adjustments of the scheduling in a way that makes the actual timing behavior of tasks as close as possible to the planned behavior specified in the global reference timing model (GRTM). Hence the hardware scheduling unit decides based on a difference, which is determined according to the above, which tasks are to be executed with higher priority. For this decision, a scheduling method with dynamic priorities, such as, for example, earliest deadline first (EDF) or least lexity first (LLF) may be used. The control values generated by the hardware scheduling unit are communicated, for example, to the operating system scheduler.
The scheduler ensures that, for every active real-time task Tx, the following conditions are met at any time:
Finally, referring to the method illustrated in
When executing the program under real-time constraints and when it is determined that a task completes one of its micro task ahead of the micro deadline of said micro task, then a corresponding reservation of excess execution time for said micro task may be released accordingly and thus made available by the scheduler to the execution of other tasks. Correspondingly, when a micro task in the hard-RT category finishes ahead of its deadline, reserved buffer time for that micro task may successively be released, and thus available by the scheduler for execution of non RT workloads.
On the example of
Embodiments according this disclosure do also include a method and an apparatus that is only concerned with aspects of the first phase according to 100 of
It will be understood by the skilled person that the embodiments described hereinbefore may be implemented by hardware, by software, or by a combination of software and hardware. The modules and functions described in connection with embodiments of the invention may be as a whole or in part implemented by microprocessors, computers, or special purpose hardware circuits which are suitably programmed such as to act in accordance with the methods explained in connection with embodiments of the invention.
Number | Date | Country | Kind |
---|---|---|---|
16189369 | Sep 2016 | EP | regional |