1. Field of the Invention
The present invention relates to a task management method and, in particular, to a task management method for efficiently managing task in resource constrained embedded systems where a Memory Management Unit does not exist.
2. Description of the Related Art
In these days, rapid advancement of computer technologies has enabled us to use embedded systems on our real lives. The embedded systems are very small and dedicated purpose computing systems, so that they can pervade into lots of things such as buildings, forest, handheld devices, jewels, and even very thin papers. This feature makes the embedded systems to be resource-constrained, and thus, operating systems running on them should be aware of constraints including limited energy, computing power, and very small memory space. Recently, both event-driven and multithreaded task management schemes and some variations have been made to provide better resource utilization on such embedded systems. However, both events and threads have some disadvantages, and their variations can be used in very specific conditions.
The present invention has been made in an effort to solve the above problems and it is an object of the present invention to provide a method and apparatus for controlling the data update periods of the applications running on the terminal effectively.
Aspects of the present invention are to provide a task management method for efficiently managing task in resource constrained embedded systems where a Memory Management Unit does not exist.
Another aspect of the present invention is to provide a new task management method for combined mechanisms managing multi-threads and event driven tasks.
Still another aspect of the present invention is to provide a task management able to enhance efficiency and performance in resource utility, and remove stack overflow problems in resource constrained embedded systems where a Memory Management Unit does not exist.
In accordance with an aspect of the present invention, a task management method for an embedded system, comprising designing a task management according to a short term task and a long term task; managing stack spaces for the short term task and the long term task; scheduling a time and a space for the short term task and the long term task; performing an adaptive stack management based on stack profiling; providing a uniform programming model for the short term task and the long term task; and implementing the short term task and the long term task.
Preferably, the character input method may be implemented with programs that can be executed by a processor, which are stored in a computer-readable recording media.
The operation principle of the present invention is described hereinafter with reference to accompanying drawings. Detailed description of well-known functions and structures incorporated herein may be omitted to avoid obscuring the subject matter of the present invention. Further, the following terms are defined in consideration of the functionality in the present invention, and may vary according to the intention of a user or an operator, usage, etc. Therefore, the definition should be made on the basis of the overall content of the present specification.
In the present invention, we compare the event-driven and the multi-threaded task management schemes in many aspects. Then, we present the design of yet-another task management for the resource-constrained embedded systems, which is neither event-driven nor multi-threaded. Our experimental results show that the proposed task management scheme provides better performance compared with the existing task management schemes.
In the most recent years, computer technologies have significantly changed people's real lives. They enabled us to use small embedded devices such as mobile handheld devices, wearable computers, and even wireless sensor networks which monitor huge environments. For example, wireless sensor nodes are used in the forest and mountains to detect fire [15], and MP3 players are embedded in several sports wears such as sunglasses, jackets, and running shoes [2]. In addition, a typical top-of-the-range automobile has more than 100 micro sensors to monitor the entire vehicle components [18].
Generally, the embedded devices have a few dedicated purposes, and they consist of very limited hardware components to minimize their production cost. In case of wireless sensor nodes, Berkeley's MicaZ has one 8 bit microprocessor, 4 KB SRAM, low-power R/F module, and 2 alkaline batteries. Such resource constraints are much more severe than general purpose computing systems. For example, a personal computer typically has 1˜4 GB space as the main memory, and there are about 1 million imes gap between them. This made the system software and operating systems running on the embedded devices to be more aware of the severe resource constraints. In the history of computer science, many operating systems have been developed for both the general-purpose and the special-purpose computer systems such as embedded computing devices. They can be categorized into two classes according to how the internal kernel structures were designed, and how they manage resources in the computer systems. Historically, the names of the two classes were defined as follows: message oriented (event-driven), and procedure-oriented (multi-threaded)[23]. For the past several decades, many discussions have been made on the two canonical models of the operating systems[10,12,17,1,21,8]. In 1978, Lauer and Needham presented the duality between the event-driven and the multi-threaded operating systems [12]. In their work, they concluded that the two classes are duals in terms of characteristics, operation, and the system's performance.
In theoretical point of view, above conclusion is correct. However, in the real implementations, the two classes show significant difference on performance and efficiency of the systems and their applications. The following are the pros and cons of the event-driven and the multi-threaded systems when implementing embedded operating systems. The design of the event-driven system provides small context switching overhead, much less memory space usage based on single stack sharing mechanism. However, average response time, scheduling latency, and preemptivity are much poorer than that of the multithreaded system [17]. The design of the multi-threaded provides fully-preemptible task management. But necessary memory space is much larger than the event-driven system because each thread requires its own stack space [21].
Considerable efforts have been made to design networked embedded operating systems under severe resource constraints of the embedded devices. They also can be categorized into the two aforementioned classes. TinyOS [13], SOS [9], PEEROS [16], CORMOS [22], and Contiki [5,4] are event-driven operating systems, while MANTIS OS [3], Nano-Qplus [13], and RETOS [11] are multi-threaded operating systems. The pros and cons on the event-driven and the multithreaded still exist in their works. When using the event-driven operating systems, software developers should be careful not to write locking operations on event handlers. In case of using the multi-threaded operating systems, the developers must understand how much memory space is required for allocating threads' stacks, and how much space is available in the system.
As depicted in
The eThread is a portmanteau of the Thread and Event, and is a combination of the event-driven and the multithreaded task management structures. The present invention implements the prototype version of eThread on actual embedded sensor platform. The experimental results show that eThread provides better efficiency, performance, and programmability compared with the existing task management schemes.
Next, some related works on networked embedded operating systems and their variations are presented, and comparison of the event-driven and multi-threaded operating system structures is described in terms of both performance and characteristics. Then, the design and implementation of eThread is presented in detail. Also, performance of the eThread and the existing event-driven and multi-threaded task management schemes is evaluated and, finally, according to the embodiments of the present invention, some conclusions and future work are presented.
1. Previous Work
In this section, existing works related to the networked embedded operating systems and mechanism proposed by the present invention, are briefly presented as follows. That is, lots of researches have been made on developing embedded operating systems and resource management schemes under severe resource constraints. The following subsections describe the existing works in detail.
1.1 Event-Driven vs. Multi-Threaded
In the recent several decades, many researchers had argued performance and efficiency of the event-driven and the multithreaded task management schemes. In H. C. Lauer and R. M. Needham, On the duality of operating system structures, In Second International Symposium on Operating Systems, IRIA, (1978), Lauer and Needham concluded that the two schemes are duals, and both have equivalent features and functionalities theoretically. After several years, however, some other researchers found that the real implementations of the event-driven and the multi-threaded task management show significantly different performance in terms of throughput, task scheduling, and concurrency.
In J. K. Ousterhout, Why threads are a bad idea (for most purposes), Presentation given at the 1996 Usenix Annual Technical Conference, (1996), Ousterhout argued several disadvantages of the multi-threaded task management by showing results of actual examples of the event-driven and multi-threaded systems. He also presented that the multi-threaded task management is better than the event-driven when a target system is susceptible to the response time, concurrency, and/or preemptivity of running tasks.
In A. Adya, J. Howell, M. Thiemer, W. J. Bolosky, and J. R. Douceur, Cooperative task management without manual stack management, In Proceedings of the 2002 USENIX Annual Technical Conference, (2002), Adya et al. suggested a sweet spot hybrid task management model of the two existing schemes (event-driven and multi-threaded). The authors insisted that the sweet spot, which provides cooperative task processing without manual stack management, can be implemented based on continuation and stack ripping mechanisms. However, they failed to present how to implement it, and the expected overhead of the continuation and the stack ripping mechanisms.
In R. Von Behren, J. Condit, and E. Brewer, Why events are a bad idea (for high-concurrency servers). In HotOS IX: The 9th Workshop on Hot Topic in Operating Systems, pp. 19-24, (2003)) evaluated performance of the real implementations of the event-driven and the multi-threaded task management. Based on the results, they insisted that the efficiency of the multi-threaded operating systems can be improved by several compiler-assisted techniques.
In A. Gustafsson, Threads without the pain, ACM Queue 3, pp. 34-41, (2005), Gustafsson describes the concept of the stackless multi-threading implementation in C/C++ programs to reduce memory space requirement. In the stackless implementation, all running functions have their own stack frame space allocated from the heap memory space, and they are managed as linked lists data structure.
1.2 Existing Operating Systems for Resource-Constrained Embedded Systems
Recently, several embedded operating systems were developed for severely resource constrained embedded systems. Also, their variations were made to improve them in terms of memory space-efficiency, preemptivity, energy-efficiency, and etc. These examples are shown in
In P. Levis, S. Madden, D. Gay, J. Polastre, R. Szewczyk, A. Woo, E. Brewer, and D. Culler, The emergence of networking abstractions and techniques in TinyOS, In First USENIX/ACM Symposium on Networked Systems Design and Implementation (NSDI)(2004)), Levis et al. proposed a TinyOS, which is an embedded operating system for wireless sensor networks. TinyOS was developed by UC Berkeley's research team, and is the most well-known operating system for tiny sensor nodes. It adopts the event-driven task management, and thus, event tasks are scheduled by First In First Out (FIFO) manner, and tasks share one stack space.
In C.-C. Han, R. Kumar, R. Shea, E. Kohler, and M. B. Srivastava, A dynamic operating system for sensor nodes, In The 3rd International Conference on Mobile Systems, Applications, and Services (MobiSys), pp. 163-176, (2005)), Han et al. proposed a SOS operating system for sensor embedded systems. Similar to the TinyOS, it uses event-driven task management, and tasks are scheduled by FIFO with priority. Due to the FIFO scheduling mechanism, TinyOS and SOS have very fixed preemption points. If a running task requires relatively much longer execution time, then the other tasks should be waiting for finishing execution of the running task.
In A. Dunkels, B. Gronvall, T. Voigt, Contiki—a lightweight and flexible operating system for tiny networked sensors, In The 1st IEEE Workshop on Embedded Networked Sensors (EWSN), (2004).) and A. Dunkels, N. Finne, J. Eriksson, and T. Voigt, Runtime dynamic linking for reprogramming wireless sensor networks, In The 4th ACM Conference on Embedded Networked Sensor Systems (SENSYS), (2006)), Dunkels et al. proposed a Contiki operating system for networked embedded and sensor systems. Contiki provides a Protothreads mechanism [6] which enables a user-level thread programming method. But, the Protothreads is not the solution to provide multi-threading on sensor nodes, but a programming sugar of event-driven programming. It does not allow preemption and automatic state management between threaded tasks.
To avoid the disadvantages on the event-driven, several researchers developed multi-threaded embedded operating systems including MANTIS OS, Nano-Qplus, and RETOS. MANTIS OS supports preemptive multi-threading, so it can handle various tasks and events from sensors concurrently.
In addition, it can process time-sensitive tasks by Round-Robin scheduling mechanism. Similar to MANTIS OS], Nano-Qplus and RETOS adopted the multi-threaded task management as shown in
Several mechanisms were proposed to alleviate such problems on both the event-driven and the multi-threaded embedded operating systems. The mechanisms will be described referring to
In Torgerson (R. Von Behren, J. Condit, and E. Brewer, Why events are a bad idea (for high-concurrency servers). In HotOS IX: The 9th Workshop on Hot Topic in Operating Systems, pp. 19-24, (2003)), Torgerson proposed a fixed stack management for MANTIS OS based on the compile-time calculation of the upper-bound of the thread's stack requirement. Then, the scheme statically allocates a stack space with fixed-size. In this way, it can reduce the unnecessarily allocated stack space. However, the scheme cannot be used when recursion or pointer functions are called on the source codes. In addition, as the result of
In S. Yi, H. Min, S. Lee, Y. Kim, I. Jeong, and S. Y. Shin, SESAME: Space-efficient stack allocation mechanism for multi-threaded sensor operating systems, In ACM Symposium on Applied Computing (SAC), pp. 1201-1202, (2007), and S. Yi, S. Lee, Y. Cho, and J. Hong, OTL: On-demand thread stack allocation scheme for real-time sensor operating systems, Lecture Notes in Computer Science 4490, pp. 905-912, (2006), Yi et al. proposed a SESAME, which is a space efficient stack allocation mechanism for multi-threaded sensor operating systems. SESAME enables to adaptively adjust stack size by allocating or releasing additional stack frame based on the amount of each function's stack usage information. The information is calculated at compile-time, and the adaptive stack space adjustment occurs at run-time. In this way, the space-efficiency is significantly improved compared with the fixed stack management. However, SESAME may degrade overall performance of the target systems because it performs stack allocation and releasing operations at every call and ret instructions. To reduce such overhead, the authors proposed a SESAME-P, which is a memory Pool-based SESAME.
By using predetermined memory pool structures, SESAME-P reduced execution time consumed on memory allocation and releasing operations.
In S. Yi, H. Min, Y. Cho, I. Jeong, Y. Kim, B. Lee, and J. Choi, PreeMe: Preemptive real-time task management for event-driven sensor operating systems, In 2008 ACM Symposium on Applied Computing (SAC), pp. 1726-1727, (2008), Yi et al. proposed a preemptive task management for event-driven sensor operating systems, called PreeMe. It dynamically manages stack space for each event handling task on demand to provide preemptiveness on the event-driven systems.
However, PreeMe does not consider efficiency of the task preemption, and thus, time overhead incurred by run-time context switching may degrade systems' performance. The authors also proposed a PreeMe-X, which provides both energy and space-efficient preemptive task managements for the event driven sensor operating systems. It determines the space efficient context switching points based on the stack usage profile. If a task needs to preempt the running task, PreeMe-X takes a context switching when the size of the running task's stack is relatively small.
The above schemes showed good performance and efficiency on the resource-constrained embedded systems. However, as the authors mentioned in their papers, the previous schemes can be adopted in very limited systems and applications which meets specific conditions.
2. Design of Yet-Another Task Management Structure for Resource-Constrained Embedded Systems
Hereinafter, detailed comparison of the event driven and the multi-threaded task management are presented in many aspects. Then, requirements, and design principles of the new task management structure for resource-constrained embedded systems are presented. According to the embodiment of the present invention, design and prototype implementation of the new task management, eThread, are presented in detail.
2.1 Comparison of Events and Threads in More Detail
2.1.1 Memory Space Usage
Table 1 presents characteristics of the event-driven and the multi-threaded task management. The event-driven task management requires just one stack space because there is only one execution flow. On the other hand, the multi-threaded management requires multiple stacks to provide multiple threads of execution. On resource-constrained embedded systems, such as wireless sensor nodes, they have a few KB space as the main memory, and they do not have memory management or protection unit. Therefore, when using the multi-threaded task management, how much memory space is required for each thread stack to remove stack overflow problem, should be considered.
2.1.2 Time Overhead
To compare the two task management schemes in terms of the execution time overhead is also needed. Generally, the multithreaded management has more time overhead than the event driven.
For example, each thread requires saving and restoring its TCB (thread control block) on context switching point because they did not finish their execution. However, in case of event handlers, context switching occurs only when the running task finishes its execution. For this reason, the event-driven task management has smaller overhead than the multi-threaded.
2.1.3 Preemptivity
Preemptivity is the most important criteria when evaluating design of the operating system structures. The multi-threaded system typically provides fully-preemptive task scheduling except some critical sections. On the other hand, the event driven system has the limited points to preempt the running task. The preemption on the event-driven is available only when the running task's priority is smaller than that of the next waiting task, and the reverse directional preemption is impossible. That's because all event tasks share one stack, and such structure cannot provide fully preemptive task management.
2.2 Requirements
Resource-constrained embedded systems typically consist of very limited hardware components. Table 2 shows some examples of the networked embedded sensor platform used in wireless sensor networks.
In Table 2, sensor platforms show that the main memory space is extremely smaller than that of the general-purpose computing systems. It's about 1,000,000 times gap between the sensor platforms and current desktop computer systems. Moreover, many other kinds of resource-constrained embedded systems exist in the real-world applications (e.g. mobile handheld devices, wearable medical caring devices, and many other wireless communication devices). In those systems, memory space, computing power, and the power sources are very limited, and thus, the new task management for those systems should meet the following requirements.
There are three important requirements; space-efficient stack management, execution time minimization, and preemptive task management support. Especially, execution time is closely related to the energy-efficiency of the embedded systems. If time overhead by half is reduced, it may reduce the energy consumption on microprocessor significantly.
2.3 eThread: Yet-Another Task Management Structure—Neither Event-Driven Nor Multi-Threaded
Hereinafter, we propose a yet-another task management structure for resource-constrained embedded systems. eThread is a portmanteau of the two words, Thread and Event, which is neither event-driven nor multi-threaded task management. It provides both space and time-efficient and preemptive task management for both short-term tasks (event handlers) and long-term tasks (threads). Also, it supports a unified programming model on both the short-term and the long-term tasks for easier understanding and development.
2.3.1 Design Principles
In the present invention, we attempted to provide a unified view for two different tasks, events and threads. The event is a unit of tasks in the event-driven, and event handlers are the main task processing routines on the event-driven system. The thread is a task in the multi-threaded system, and each thread can perform unbounded loops because they can be preempted by other threads at anytime. Typically, events require very short time to handle events, and threads require much longer execution time. In other words, the events can finish their work in just few time slices, while the threads should have interleaved execution by some Round-Robin-like scheduling algorithms. In eThread task management, we virtually divided the events and the threads as follows.
Based on the virtual division, we defined several principles on designing eThread task management for the following items.
2.3.2 Stack Space Management
In the present invention, a SSMT (shared stack-based multithreading) as the main stack management to follow above design principles can be used.
In
2.3.3 Task Scheduling
a Lazy-RR1 scheduling mechanism which provides both time and space-efficient task management for the short and long-term tasks are proposed. Lazy-RR is different from the legacy round-robin on managing context switching points and time slices of each running task.
In the present invention, the major difference between the normal and Lazy-RR comes from context switching points between runnable tasks. In the example of
On the other hand, in
2.3.4 Adaptive Stack Management Based on Stack Profiling
Stack space-efficiency by exploiting stack usage information of each task can be also increased. In our previous work, PreeMe-X provides efficient context switching points based on stack profiling mechanism. In the present invention, we used the same stack mechanism to minimize the amount of stack space.
2.3.5 Programming Model
Programming models for the event-driven and the multi-threaded task management schemes are firstly compared.
In
In above comparison results, the events and the threads have relatively different programming interfaces, and each of them has its own characteristics. This makes the system development to be hard work, because the system engineers should aware of the characteristics of both event-driven and multi-threaded, different programming interfaces, and how to select an appropriate one for programming. To remove such problems, in the present invention, we provide the uniform programming model for both the short (event) and long-term (thread) tasks.
When using eThread, we do not need to consider how long execution time is required for each task. In
2.4 Implementation of eThread
In this section, we present how to implement eThread task management for resource-constrained embedded systems. The prototype version of eThread and its several varieties on Nano-Qplus operating system for wireless networked embedded systems is implemented. The full source codes used in the present invention are available on the website.
2.4.1 Prototype Implementation
Nano-Qplus is a kind of multi-threaded operating systems. It has the normal round-robin scheduling mechanism with fixed stack management scheme. To provide eThread task management on top of the Nano-Qplus sensor operating system, new schemes and modified several existing components are implemented as follows.
To do the above, source codes of the latest version of Nano-Qplus (ver. 2.3.0), are modified and each newly added component can be easily configured by dynamic kernel configuration (dynamic prototyping) utility. We added two variables (nExec, nThres) for each task structure to implement Lazy-RR and adaptive context switching based on stack usage information.
The nExec denotes how many times a task has been scheduled by a processor. If the value is smaller than 2, the task will have extra time slice, and it continues its execution. By doing so, Lazy-RR performs delayed context switching. Then, some short-term tasks may finish their work in just one time slice without allocating and saving their own stack space on the heap memory. The nThres is used for denoting threshold value of each task's stack usage. If the stack usage of the running task is larger than nThres, the context switching will be skipped and retried at the next context switching point. If the context switching has been skipped for an reasonable duration, the scheduler performs context switching between tasks. In our implementation, we set the reasonable duration as the amount of the default (one) time slice.
In addition, we have been made several stack usage profilers for our previous works. However, in this work, such profiled results should be inserted into nThres by human programmers. We are now implementing automatic stack usage profiling and adapting toolkits, and it will be added in our future work of the present invention.
2.4.2 Building Process
This section presents a building process of the implemented eThread task management for actual wireless networked embedded sensor platforms.
scheme. In this process, compile-time stack profiler calculates stack usage by analyzing assembly-level stack increment and decrement codes such as push and pop. Then, the stack usage report is used to add a C source code which initializes the nThres of each created task structures. Finally, the building process is ended by compiling the modified C source codes.
3. Performance Evaluation
In this section, we evaluate performance of eThread with various kinds of task management schemes in terms of the execution time, the amount of allocated stack space, and the spacetime product. We made several experiments based on Tmote Sky sensor platforms and existing applications of Nano-Qplus.
3.1 Experimental Setup
To evaluate various features of eThread task management scheme, we measured every combination of sub-components on eThread such as normal vs. lazy round-robin, fixed vs. shared stack management, and whether using stack profiling or not. The following are the combinations used in the present invention.
In our performance evaluation, we used three kinds of nodes and one monitor (base station). Each sensor node performs sensing, and transmitting the sensed data to the sink node. Then the sink transmits the sensed data to the base station node via wired serial line, and it sends some commands to actuators. To do these works, each sensor node has 3 non-returning tasks, and creates 1 extra task when transmitting data to the sink node.
The sink node has 2 non-returning tasks and it creates a task when receiving data from a sensor node. In this application scenario, sensor and sink nodes has both long-term (non-returning) tasks and a short-term (packet transmitting/receiving) task. By using above applications, we made experiments and compared several schemes in terms of both the time and space efficiency.
3.2 Experimental Results and Evaluation
First of all, we measured the amount of allocated stack space and the changes for 8 kinds of task management combinations.
In
The total execution time and the number of task context switching when using each task management scheme for a sensor node are also compared. From
The present invention also focuses on the worst-case and the average stack usage of the task management schemes.
In the present invention, we presented why both the event-driven and the multi-threaded are not enough to implement efficient embedded operating systems. Based on the reasons why they are inefficient, a new task management, eThread, which is designed for the resource-constrained embedded systems, is proposed. the prototype version of eThread on Nano-Qplus sensor operating system is implemented, and experiments on the well-known Tmote Sky sensor platforms are made. Our experimental results showed that eThread provides much better efficiency and performance compared with the existing task management schemes.
Automatic stack space profiling and source codes modification toolkits for the eThread is implemented. We are currently extending our work to analyze the impact of the Lazy round-robin scheduler and Profiling-based context switching scheme on schedulability of real-time embedded systems. We are also interested in selecting better policies and parameters for above scheduling and context switching schemes.
As described above, the system and method for inputting characters in a touch-based electronic device according to the present invention can be implemented with program commands that can be conducted via various types of computers and recorded in computer-readable recording media. The computer-readable recording media contain program commands, data files, data structures, or a combination thereof. The program commands recorded in the recording media may be designed or configured to comply with the present invention or may be software well-known to the ordinary person skilled in the art.
The computer-readable recoding media includes hardware systems for storing and conducting program commands. Examples of the hardware systems are magnetic media such as a hard disk, floppy disk, a magnetic tape, optical media such as CD-ROM and DVD, Magneto-Optical Media, such as floptical disk, ROM, RAM, and flash memory. The program commands include assembly language or machine code complied by a complier and a higher level language interpreted by an interpreter. The hardware systems may be implemented with at least one software module to comply with the present invention.
Although exemplary embodiments of the present invention have been described in detail hereinabove, it should be clearly understood that many variations and/or modifications of the basic inventive concepts herein taught which may appear to those skilled in the present art will still fall within the spirit and scope of the present invention, as defined in the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2012-0092007 | Aug 2012 | KR | national |
This application claims priority under 35 U.S.C. §119 to U.S. Provisional Application No. 61/526,068, which was filed in the U.S. Patent and Trademark Office on Aug. 22, 2011, and to Korean Application Serial No. 10-2012-0092007, which was filed in the Korean Industrial Property Office on Aug. 22, 2012, the content of each of which is hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
61526068 | Aug 2011 | US |