EP1573538A2 - IMPROVEMENTS RELATING TO STACK USAGE IN COMPUTER­RELATED OPERATING SYSTEMS - Google Patents
IMPROVEMENTS RELATING TO STACK USAGE IN COMPUTER­RELATED OPERATING SYSTEMSInfo
- Publication number
- EP1573538A2 EP1573538A2 EP03791005A EP03791005A EP1573538A2 EP 1573538 A2 EP1573538 A2 EP 1573538A2 EP 03791005 A EP03791005 A EP 03791005A EP 03791005 A EP03791005 A EP 03791005A EP 1573538 A2 EP1573538 A2 EP 1573538A2
- Authority
- EP
- European Patent Office
- Prior art keywords
- task
- stack
- processor
- memory
- tasks
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Withdrawn
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
- G06F9/5005—Allocation of resources, e.g. of the central processing unit [CPU] to service a request
- G06F9/5011—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals
- G06F9/5016—Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resources being hardware resources other than CPUs, Servers and Terminals the resource being the memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/46—Multiprogramming arrangements
- G06F9/50—Allocation of resources, e.g. of the central processing unit [CPU]
Definitions
- the present invention relates to methods and systems for reducing memory and processor usage, with particular reference to stack operations, in real-time computing applications.
- the invention is particularly, though not exclusively, directed towards operating systems that make use of static priority-based scheduling but that also permit tasks explicitly to suspend themselves and/or wait for predetermined events.
- Embodiments of the present invention are of particular relevance to the technical field of embedded devices and the control thereof, since these generally use static priority-based scheduling given the limited range of functions required.
- Certain groups of tasks may advantageously be placed into "non-preemption groups" such that their priorities are allocated in such a fashion that when any one of the tasks in a non-preemption group is executing, no other task in that group may preemptively gain control of the central processing unit (CPU) (see Figure 2).
- CPU central processing unit
- Such operating systems may be extended to permit tasks voluntarily to suspend or yield control of the CPU by way of a well-defined application programmer interface (API).
- API application programmer interface
- a task may wait for an event to occur and register an interest in being awakened when that event occurs, or may voluntarily suspend its computations in order co-operatively to permit other tasks to use the CPU.
- Examples of such systems include, but are not limited to, OSEK extended conformance classes ECC1 or ECC2 (see http://www.osek-vdx.org).
- Embodiments of the present invention seek to provide a means of allocating stack usage on a single stack for such mixed preemptive/cooperating systems.
- Embodiments of the present invention seek to provide a means of ensuring that an entire mixed preemptive/cooperating system can run on a single stack, thus saving RAM and reducing context switch overhead, particularly for pre-emptive tasks, as no switching between stacks is required.
- each task is annotated with its worst-case stack usage figures. In the simplest case, this could be a single number for each task; more advanced variants of this approach can take account of shared priorities,, non- preemption between tasks, or transient stack usage (for example during semaphore or interrupt locks), among others.
- off-line analysis of the tasks and their stack usage can be used to determine the worst case stack-usage of all tasks that can run at lower priority than any task that can voluntarily yield control of the CPU.
- Such a task can then be started with its initial stack pointer set to this value and it can be sure that it is not overwriting the stack area of any lower priority task.
- the amount of stack used from the start point to the yield point can be saved into a separate statically allocated area from where it can later be restored when the task regains control.
- a method of reducing memory and processor usage in a computer operating system utilising a processor, a memory and a single stack, the operating system comprising a plurality of tasks divided into predetermined priority categories, including preemptive tasks and at least one task that voluntarily yields control of the processor to tasks of lower priority than itself in predetermined circumstances, wherein each task has associated therewith a stack pointer, and wherein the at least one task, when started, has its stack pointer set to a precalculated worst-case value guaranteed to leave sufficient space in the stack beneath the stack pointer for any preemptive tasks of lower priority, and wherein the at least one task has allocated to it an area of memory into which its stack contents is saved, a size of the area of memory being determined by a declared precalculated worst-case stack usage of the at least one task at any point at which the at least one task may yield control of the processor.
- a configuration tool for reducing memory and processor usage in a computer operating system utilising a processor, a memory and a single stack, the operating system comprising a plurality of tasks divided into predetermined priority categories, including preemptive tasks and at least one task that voluntarily yields control of the processor to tasks of lower priority than itself in predetermined circumstances, wherein each task has associated therewith a stack pointer, and wherein the tool is adapted to calculate a worst-case stack pointer value for the at least one task guaranteed to leave sufficient space in the stack beneath the stack pointer for any preemptive tasks of lower priority than the at least one task, and wherein the tool is adapted to allocate to the at least one task an area of memory into which the stack contents of the at least one task is saved, a size of the area of memory being determined by a declared worst-case stack usage, calculated by the tool, of the at least one task at any point at which the at least one task may yield control of the processor.
- a computing device programmed with a configuration tool for reducing memory and processor usage in a computer operating system utilising a processor, a memory and a single stack, the operating system comprising a plurality of tasks divided into predetermined priority categories, including preemptive tasks and at least one task that voluntarily yields control of the processor to tasks of lower priority than itself in predetermined circumstances, wherein each task has associated therewith a stack pointer, and wherein the tool is adapted to calculate a worst-case stack pointer value for the at least one task guaranteed to leave sufficient space in the stack beneath the stack pointer for any preemptive tasks of lower priority than the at least one task, and wherein the tool is adapted to allocate to the at least one task an area of memory into which the stack contents of the at least one task is saved, a size of the area of memory being determined by a declared worst-case stack usage, calculated by the tool, of the at least one task at any point at which the at least one task may yield control of the processor.
- the configuration tool may be in the form of a software product.
- the software product may be in any appropriate form or language, and may be stored on a data carrier such as a floppy disk, optical disk, flash memory device or any other type of data carrier.
- a computer operating system utilising a processor, a memory and a single stack, the operating system comprising a plurality of tasks divided into predetermined priority categories, including preemptive tasks and at least one task that voluntarily yields control of the processor to tasks of lower priority than itself in predetermined circumstances, wherein each task has associated therewith a stack pointer, and wherein the at least one task, when started, has its stack pointer set to a precalculated worst-case value guaranteed to leave sufficient space in the stack beneath the stack pointer for any preemptive tasks of lower priority, and wherein the at least one task has allocated to it an area of memory into which its stack contents is saved, a size of the area of memory being determined by a declared precalculated worst-case stack usage of the at least one task at any point at which the at least one task may yield control of the processor.
- a computing device programmed with an operating system utilising a processor, a memory and a single stack, the operating system comprising a plurality of tasks divided into predetermined priority categories, including preemptive tasks and at least one task that voluntarily yields control of the processor to tasks of lower priority than itself in predetermined circumstances, wherein each task has associated therewith a stack pointer, and wherein the at least one task, when running, has its stack pointer set to a precalculated worst-case value guaranteed to leave sufficient space in the stack beneath the stack pointer for any preemptive tasks of lower priority, and wherein the at least one task has allocated to it an area of memory into which its stack contents is saved, a size of the area of memory being determined by a declared precalculated worst-case stack usage of the at least one task at any point at which the at least one task may yield control of the processor.
- any operating system functions that may cause a task voluntarily to yield control of the processor must be implemented in such a way that on detecting the need to yield they cause the current stack pointer and stack between the task's known base stack pointer and the current stack pointer value to be saved into this area, and on returning control to the task cause the stack to be restored from the "save area" and the stack pointer to be set to its previous value. It is also to be noted that when suspending a cooperative task and resuming a preemptive task, the stack pointer from the purely preemptive tasks running at lower priorities than the cooperative task must be restored.
- embodiments of the present invention find particular utility in the technical field of embedded devices and the control thereof, since these generally use static priority-based scheduling given the limited range of functions required.
- the various tasks and their characteristics can be predefined statically and off-line in embedded device applications, since these are generally predictable, closed systems rather than large systems requiring dynamic task definitions.
- the configuration process to calculate stack characteristics for the cooperative tasks can be carried out according to the following pseudo code, which is set forth by way of example only.
- the existence is assumed of a function to calculate the worst-case stack usage for a given set of tasks running up to a given priority level, since this is established technology.
- start_stac (t) orst_case_stack (preempt_set , priority (t) ) reserve_save_area (t , stack_on_suspend (t) ) else need_stack_adjustment (t , false) end if end for
- FIGURE 1 shows how, in a preemptive system with "single-shot” tasks, a single stack can be used:
- FIGURE 2 shows how, in such a system, information about non-preemption between tasks can be used to minimise the amount of stack needed
- FIGURE 3 shows how, for two tasks that voluntarily yield control of the processor (cooperative), each has its stack pointer uniquely determined
- FIGURE 4 shows how a task saves its stack area into its "save area”, other tasks running instead
- FIGURE 5 illustrates an embodiment of the invention in which two tasks that may yield control of the CPU exist in mutual exclusion.
- Figure 1 shows a conventional arrangement in which three single-shot tasks (Task 1, Task 2 and Task 3) are each provided with an independent stack 1, 2, 3.
- Each stack 1, 2, 3 must include enough memory to store its respective task and also to store any associated context when that task is preempted. It is possible to run all three tasks on a single stack 4 by reserving enough memory in the stack 4 for each task and its associated context to be stored one on top of the other.
- the stack 4 must reserve more RAM than will generally be required in real-life applications, because this scenario assumes a simple "worst case" scenario.
- Figure 2 shows an alternative conventional arrangement in which tasks are grouped into non-preemption groups each having a given priority. Specifically, there is a non- preemption group 5 of tasks having priority 1 ; a non-preemption group 6 of tasks having priority 2; and a non-preemption group 7 of tasks having priority 3. Because no task may preempt any other task within the same non-preemption group 5, 6 or 7, it is possible to run all of the tasks on a single stack 8 by reserving enough space for the largest task (and its associated context) in each non-preemption group 5, 6 and 7 in the stack 8 as shown.
- FIG. 3 illustrates an embodiment of the present invention where two tasks (T_ECC_1 and T_ECC_2) that voluntarily yield control of the processor (cooperative), may have their stack pointers uniquely determined.
- the calculated single stack is shown at 10, and is built up as follows. Firstly, the maximum usage of any tasks with priority lower than task T_ECC_1 is determined and space 11 is reserved therefor in the stack 10. Secondly, the stack usage for task T_ECC_1 is determined and space 12 reserved in the stack 10 on top of space 11. Thirdly, the worst-case usage of all tasks with priority lower than task T_ECC_2 is determined and space 13 is reserved therefor in the stack 10 on top of space 12.
- stack usage for task T_ECC_2 is determined and space 14 reserved in the stack 10 on top of space 13.
- stack usage for preemptive tasks running above task T_ECC_2 is calculated and space 15 reserved therefor on top of space 14. The calculations may be undertaken by the configuration tool of embodiments of the present invention.
- the stack may go over the bounds of the calculated stack pointer in space 13 to extend the stack to space 14 for another task that may voluntarily yield control of the processor, but only where the running task has higher priority than the task T_ECC_2 that may voluntarily yield control of the processor. In this case the tasks of higher priority than T_ECC_2 will run to completion and so the stack use returns to within space 13 before T_ECC_2 can run.
- the stack pointer is set to the bottom of precalculated stack space 14 and task T_ECC_2 may then run in space 14. Any further preemptive tasks that run over task T_ECC_2 will run in space 15 above space 14.
- Figure 4 shows a stack 20 with space 21 reserved for tasks running under a blocking ECC task, for which space 22 is reserved in the stack 20 above space 21.
- the ECC task When the ECC task is suspended, it is saved in a separate save area 23 so that higher priority preemptive tasks that run when the ECC task yields can extend their stack use from space 21 into space 22 because they will complete and subsequently release this space before the ECC task continues.
- the ECC task When the ECC task is restored, the contents of the save area 23 are replaced in the stack 20 in space 22.
- FIG. 5 illustrates an interesting application of an embodiment of the invention in which two tasks T_ECC_2 and T_ECC_3 that may yield control of the CPU exist in mutual exclusion.
- a stack 30 is shown in which space 31 is reserved at the bottom of the stack for the worst case stack usage of for all tasks running below tasks T_ECC_2 and T_ECC_3.
- a stack pointer for task T_ECC_2 is set at the top of space 31 and a maximum stack usage for task T_ECC_2 is defined as before to give space 32.
- space 33 for the worst case stack usage for all tasks that can preempt task T_ECC_2.
- Task T_ECC_3 is defined to be in mutual exclusion (mutex) with task T_ECC_2.
- tasks T_ECC_2 and T_ECC_3 are in mutual exclusion, they can share the same stack space 32.
- the maximum stack usage for task T_ECC_3 is less than that of task T_ECC_2, but it can be seen that the stack pointers for both of these tasks are the same.
- task T_ECC_2 yields control of the CPU, it must be saved (together with any context) in save area 34, because it may be replaced in the stack 30 in space 32 by task T_ECC_3, as shown in stack configuration 30'.
- task T_ECC_3 When task T_ECC_3 yields control of the CPU, it is saved (together with any context) in a separate save area 35, and task T_ECC_2 and its context can then be restored to the stack from the save area 34 when the task is resumed, as shown in stack configuration 30".
Abstract
Description
Claims
Applications Claiming Priority (5)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US242482 | 1988-09-09 | ||
GB0219936 | 2002-08-28 | ||
GB0219936A GB2392515B (en) | 2002-08-28 | 2002-08-28 | Improvements relating to stack usage in computer-related operating systems |
US10/242,482 US7225443B2 (en) | 2002-08-28 | 2002-09-11 | Stack usage in computer-related operating systems |
PCT/GB2003/003640 WO2004021187A2 (en) | 2002-08-28 | 2003-08-20 | Improvements relating to stack usage in computerrelated operating systems |
Publications (1)
Publication Number | Publication Date |
---|---|
EP1573538A2 true EP1573538A2 (en) | 2005-09-14 |
Family
ID=31979990
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP03791005A Withdrawn EP1573538A2 (en) | 2002-08-28 | 2003-08-20 | IMPROVEMENTS RELATING TO STACK USAGE IN COMPUTER­RELATED OPERATING SYSTEMS |
Country Status (3)
Country | Link |
---|---|
EP (1) | EP1573538A2 (en) |
AU (1) | AU2003255827A1 (en) |
WO (1) | WO2004021187A2 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110231993A (en) * | 2019-06-19 | 2019-09-13 | 爱驰汽车有限公司 | Battery management method, device, electronic equipment, storage medium |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112882804A (en) * | 2016-08-17 | 2021-06-01 | 华为技术有限公司 | Method and device for starting application |
Family Cites Families (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3905023A (en) * | 1973-08-15 | 1975-09-09 | Burroughs Corp | Large scale multi-level information processing system employing improved failsaft techniques |
DE3176724D1 (en) * | 1980-11-20 | 1988-06-01 | Ibm | A process management system for scheduling work requests in a data processing system |
-
2003
- 2003-08-20 AU AU2003255827A patent/AU2003255827A1/en not_active Abandoned
- 2003-08-20 EP EP03791005A patent/EP1573538A2/en not_active Withdrawn
- 2003-08-20 WO PCT/GB2003/003640 patent/WO2004021187A2/en not_active Application Discontinuation
Non-Patent Citations (1)
Title |
---|
See references of WO2004021187A2 * |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110231993A (en) * | 2019-06-19 | 2019-09-13 | 爱驰汽车有限公司 | Battery management method, device, electronic equipment, storage medium |
Also Published As
Publication number | Publication date |
---|---|
AU2003255827A1 (en) | 2004-03-19 |
AU2003255827A8 (en) | 2004-03-19 |
WO2004021187A3 (en) | 2006-02-23 |
WO2004021187A2 (en) | 2004-03-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Anderson et al. | Scheduler activations: Effective kernel support for the user-level management of parallelism | |
US7971205B2 (en) | Handling of user mode thread using no context switch attribute to designate near interrupt disabled priority status | |
EP0945797A2 (en) | Method and apparatus for object-oriented interrupt system | |
CN112416546A (en) | Multitask scheduling method, electronic device and computer storage medium | |
JP2005284749A (en) | Parallel computer | |
US7225443B2 (en) | Stack usage in computer-related operating systems | |
KR20130066900A (en) | Method to guarantee real time for soft real time operating system | |
Kim et al. | A server-based approach for predictable GPU access with improved analysis | |
Jones et al. | {CPU} Reservations and Time Constraints: Implementation Experience on Windows {NT} | |
Bi et al. | Research of key technologies for embedded Linux based on ARM | |
EP1770517A2 (en) | Improvements relating to reduced-overhead context-saving in static priority scheduled operating systems | |
Parks et al. | Non-preemptive real-time scheduling of dataflow systems | |
US8010963B2 (en) | Method, apparatus and program storage device for providing light weight system calls to improve user mode performance | |
US8910181B2 (en) | Divided central data processing | |
EP1573538A2 (en) | IMPROVEMENTS RELATING TO STACK USAGE IN COMPUTER­RELATED OPERATING SYSTEMS | |
Kim et al. | Mixed-criticality on multicore (MC2): A status report | |
Lee et al. | Interrupt handler migration and direct interrupt scheduling for rapid scheduling of interrupt-driven tasks | |
Cherepov et al. | Hard Real-time with {RTX} on Windows {NT} | |
Labrosse | Operating systems | |
Papadimitriou et al. | Mac OS versus FreeBSD: A comparative evaluation | |
Lin et al. | Ada 2012: resource sharing and multiprocessors | |
Elsir et al. | A RTOS for educational purposes | |
Locke et al. | Java technology comes to real-time applications | |
Altmeyer et al. | EMPRESS: an efficient and effective method for PREdictable stack sharing | |
Kwon et al. | A framework accommodating categorized multiprocessor real-time scheduling in the RTSJ |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
17P | Request for examination filed |
Effective date: 20041103 |
|
AK | Designated contracting states |
Kind code of ref document: A2 Designated state(s): AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LI LU MC NL PT RO SE SI SK TR |
|
AX | Request for extension of the european patent |
Extension state: AL LT LV MK |
|
DAX | Request for extension of the european patent (deleted) | ||
PUAK | Availability of information related to the publication of the international search report |
Free format text: ORIGINAL CODE: 0009015 |
|
RIC1 | Information provided on ipc code assigned before grant |
Ipc: G06F 9/50 20060101AFI20060302BHEP Ipc: G06F 9/46 20060101ALI20060302BHEP |
|
17Q | First examination report despatched |
Effective date: 20070215 |
|
GRAP | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOSNIGR1 |
|
INTG | Intention to grant announced |
Effective date: 20161026 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN |
|
18D | Application deemed to be withdrawn |
Effective date: 20170307 |