Real Time Operating System

Total Page:16

File Type:pdf, Size:1020Kb

Real Time Operating System REAL TIME OPERATING SYSTEM ABSTRACT A real-time operating system (RTOS) is an • Media playback operating system (OS) intended for real-time • Scientific visualization applications . Such operating systems serve • Games application requests nearly real-time. A real- • Interactive applications time operating system offers programmers more Distributed real-time systems are those which have control over process priorities. Real time means multiple resources with non-negligible latency among immediate response from the computer. Thus them. Examples include the multiple processors in a a system in which a transaction that we access car, or media being streamed and update a file quickly enough to affect original decision making is called a real time The term real-time derives from its use in early operating system. A real time operating system simulation. While current usage implies that a has well defined time constraints. computation that is 'fast enough' is real-time, originally it referred to a simulation that proceeded at a rate that matched that of the real process it was INTRODUCTION simulating. Analog computer especially, were often capable of simulating much faster than real-time, a An operating system (OS) is a software , consisting situation that could be just as dangerous as a slow of programs and data that runs on computers and simulation if it were not also recognized and manages the computer hardware and provides accounted for. common services for efficient execution of various application software.A good operating system (OS) Hard and soft real-time systems provides a solid interface to the hardware and allows A system is said to be ''real-time'' if the total the application to be managed in the most efficient correctness of an operation depends not only upon its manner possible. logical correctness, but also upon the time in which it is performed. The classical conception is that in a Real-time operating systems are software/hardware '''hard real-time''' or '''immediate real-time system''', systems in which timing the completion of an operation after its deadline is constraints must be met for correctness. “Real-time” considered useless - ultimately, this may cause a does not mean “really fast”, but rather “get this done critical failure of the complete system. A '''soft real- by the deadline or else you have failed.” Such hard time system''' on the other hand will tolerate such real-time systems are ubquitous and vital in a range lateness, and may respond with decreased service of places from everyday life to quality (e.g., omitting frames while displaying a estoteria: video). • The ignition, fuel injection, and timing of most car engines is handled by a real-time system. Hard real-time systems are used when it is imperative • The antilock brake system in most cars is a real-time that an event is reacted to within a strict deadline. system. Such strong guarantees are required of systems for . which not reacting in a certain interval of time would • The software of the Mars Rovers is architected cause great loss in some manner, especially damaging around VxWorks, a commercial real-time operating the surroundings physically or threatening human system.Most hard real-time systems are embedded lives (although the strict definition is simply that systems, meaning the software is missing the deadline constitutes failure of the system). codesigned with the hardware, under often severe cost For example, a [automobile|car] [engine] control constraints, to accomplish a specific task. The user system is a hard real-time system because a delayed doesn't see the system as a general purpose computer. signal may cause engine failure or damage. Other examples of hard real-time embedded systems include Soft real-time systems are penalized by how much medical systems such as heart[artificial pacemaker| they miss the desired deadlines and by the variance of pacemaker] and industrial process controllers. Hard their latency. Such systems show up in many familiar real-time systems are typically found interacting at a places in general purpose computers, or should: low level with physical hardware, in [[embedded system]]s. Early video game systems such as the Windows operating system. Components installed on [[Atari 2600]] and [[Cinematronics]] vector graphics Windows include a Windows kernel driver and a had hard real-time requirements because of the nature number of Windows services. The driver manages of the graphics and timing hardware. memory for the kernel and real-time applications to run in, and manages the communications Soft real-time systems are typically used where there interface between the two systems. is some issue of concurrent access and the need to keep a number of connected systems up to date with changing situations; for example software that A Windows service loads the real-time kernel into the maintains and updates the flight plans for commercial allocated memory and then causes a context switch [[airline]]rs. The flight plans must be kept reasonably from Windows to the INtime kernel. A low-priority current but can operate to a latency of seconds. thread is created whose function is to switch the machine context back to the Windows system. Because this thread will be preempted by all other real-time threads, as far as the real-time kernel is RECENT WORK IN FIELD concerned, the Windows system is the real-time system's idle task. The 31st IEEE Real-Time Systems Symposium (RTSS) in San Diego, California, will follow the When in the INtime context, any real-time interrupts format of recent RTSSs, with multiple tracks. RTSS is are handled directly, and all other interrupts are the premier conference in the area of real-time masked at the interrupt controller. When the context computing, presenting innovations in the field with returns to Windows, these interrupts are unmasked to respect to theory and practice. allow normal processing by Windows. When a real- time interrupt occurs in the Windows context, the RTSS provides a forum for the presentation of high- Windows IDT is patched so as to cause a context quality, original research covering all aspects of real- switch to the INtime context so the interrupts may be time systems design, analysis, implementation, handled. evaluation, and experiences. RTSS’10 continues the trend of making RTSS an expansive and inclusive The system timer is usually shared between Windows symposium, looking to embrace new and emerging and INtime. The hardware timer is reprogrammed to areas of real-time systems research. interrupt at a higher rate than Windows requires, and the Windows handler is only invoked as required. RTSS’10 welcomes the submission of mature papers Typically, the INtime kernel takes timer interrupts at a in several areas of real-time computing, including but much higher rate (a period as low as 100µs is not limited to scheduling; databases; observability; possible) to allow for finer granularity timing services. composability; security for real-time systems; tools Optimization of the timer handling avoids and reduction to practice; control and adaptive RT unnecessary context switches between Windows and systems theory; testing and debugging; modeling; INtime. formal methods; communications (wireless, wireline, and sensor networks); power, thermal, and energy Certain hardware abstraction layer (HAL) entry points management; embedded systems; sensor and are intercepted and monitored in order to prevent the implantable devices; robustness; fault tolerance and Windows kernel from performing unwanted actions robustness; intelligent behavior; time-sensitive such as masking a real-time interrupt, or changing the robotics; emergency/disaster management; embedded hardware system timer frequency. The HAL file is not real-time systems and infrastructures; QoS support; modified or replaced by the software. real-time systems middleware, and cyber-physical systems. SCOPE FOR THE RESEARCH WORK RELATED DATA INtime is implemented as a real-time operating system which shares the hardware platform with the The INtime kernel provides operating system services links are supported through Serial Line Internet for the real-time virtual machine. It provides the real- Protocol (SLIP). time services expected of such a kernel, consisting of a priority-based preemptive scheduler with priority- USB support is provided as a development kit for based interrupt handling. Thread priorities range from developing USB client software. Standard drivers are 0 (highest priority) to 255 (lowest priority) and provided for Universal Host Controller (UHCI), Open threads below a configurable priority threshold can Host Controller (OHCI), and Enhanced Host time-slice with threads of equal priority. The kernel Controller (EHCI) interfaces. scheduler has been optimized for maximum interrupt performance. Other drivers are provided for a range of standard and industrial interface. The resulting platform exhibits good performance, and above all its behavior is predictable. Win32 API Win32 API lacks some useful features for real-time programming, INtime provides a Win32 API for ease of transporting code from Windows applications. This implementation is a rich subset of the Windows CE Win32 implementation, including a useful subset of Win32 objects, WaitForMultipleObjects, and with extensions to manage interrupts and Peripheral Component Interconnect (PCI) bus configuration Windows APIs PRESENTATION WORK APIs are provided for Windows applications to allow them to share objects created on the real-time kernel. queue
Recommended publications
  • Formal Modelling of Separation Kernels
    The University of York Department of Computer Science Submitted in part fulfilment for the degree of MSc in Software Engineering. Formal Modelling of Separation Kernels Andrius Velykis 18th September 20091 Supervised by Dr Leo Freitas Number of words = 45327, as counted by detex <report.tex> j wc -w. This report consists of 98 pages in total. This includes the body of the report (without blank pages) and Appendix A, but not Appendices B, C, D, E and F. 1Updated transactional operation proofs, 21st September 2009. Abstract A separation kernel is an architecture for secure applications, which benefits from inherent security of distributed systems. Due to its small size and usage in high-integrity environments, it makes a good target for formal modelling and verification. This project presents results from mechanisation and modelling of separation kernel components: a process table, a process queue and a scheduler. The results have been developed as a part of the pilot project within the international Grand Challenge in Verified Software. This thesis covers full development life-cycle from project initiation through design and evaluation to successful completion. Important findings about kernel properties, formal modelling and design decisions are discussed. The developed formal specification is fully verified and contributes to the pilot project aim of creating a formal kernel model and refining it down to implementation code. Other reusable artefacts, such as general lemmas and a new technique of ensuring transactional properties of operations are defined. The results will be curated within the Verified Software Repository. i Robertai. Aˇci¯u. Acknowledgements I would like to thank Dr Leo Freitas for his supervision, encouragement and getting me hooked on formal methods.
    [Show full text]
  • MILS Architectural Approach Supporting Trustworthiness of the Iiot Solutions
    MILS Architectural Approach Supporting Trustworthiness of the IIoT Solutions An Industrial Internet Consortium Whitepaper Rance J. DeLong (The Open Group); Ekaterina Rudina (Kaspersky) MILS Architectural Approach Context and Overview 1 Context and Overview ...................................................................................................... 4 1.1 Need for Trustworthy System Operation ............................................................................. 5 1.2 What is MILS today .............................................................................................................. 6 1.3 How MILS Addresses Safety ................................................................................................. 7 1.4 How MILS Addresses Security .............................................................................................. 8 1.5 How MILS Supports Reliability, Resilience, and Privacy ........................................................ 9 2 MILS Concepts .................................................................................................................. 9 2.1 Centralized vs Distributed Security Architecture .................................................................. 9 2.1.1 Domain Isolation .................................................................................................................................. 10 2.1.2 Isolation and Information Flow Control ............................................................................................... 11 2.1.3 Separation
    [Show full text]
  • National Information Assurance Partnership
    National Information Assurance Partnership ® TM Common Criteria Evaluation and Validation Scheme Validation Report Green Hills Software INTEGRITY-178B Separation Kernel Report Number: CCEVS-VR-10119-2008 Dated: 01 September 2008 Version: 1.0 National Institute of Standards and Technology National Security Agency Information Technology Laboratory Information Assurance Directorate 100 Bureau Drive 9800 Savage Road STE 6757 Gaithersburg, MD 20899 Fort George G. Meade, MD 20755-6757 VALIDATION REPORT Green Hills Software INTEGRITY-178B Separation Kernel ACKNOWLEDGEMENTS Validation Team Shaun Gilmore Santosh Chokhani Ken Elliott Jerry Myers Paul Bicknell Common Criteria Testing Laboratory SAIC, Inc. Columbia, Maryland ii VALIDATION REPORT Green Hills Software INTEGRITY-178B Separation Kernel Table of Contents 1 Executive Summary................................................................1 1.1 Evaluation Details.............................................................2 2 Identification...........................................................................4 3 Threats to Security ..................................................................5 4 Security Policy........................................................................7 5 Assumptions............................................................................8 5.1 Physical Assumptions .......................................................8 5.2 Personnel Assumptions.....................................................8 5.3 Connectivity Assumptions................................................8
    [Show full text]
  • Partitioned System with Xtratum on Powerpc
    Tesina de M´asteren Autom´aticae Inform´aticaIndustrial Partitioned System with XtratuM on PowerPC Author: Rui Zhou Advisor: Prof. Alfons Crespo i Lorente December 2009 Contents 1. Introduction1 1.1. MILS......................................2 1.2. ARINC 653..................................3 1.3. PikeOS.....................................6 1.4. ADEOS....................................7 2. Overview of XtratuM 11 2.1. Virtualization and Hypervisor........................ 11 2.2. XtratuM.................................... 12 3. Overview of PowerPC 16 3.1. POWER.................................... 16 3.2. PowerPC.................................... 17 3.3. PowerPC in Safety-critical.......................... 19 4. Main PowerPC Drivers to Virtualize 20 4.1. Processors................................... 20 4.2. Timer..................................... 21 4.3. Interrupt.................................... 23 4.4. Memory.................................... 24 5. Porting Implementation 25 5.1. Hypercall................................... 26 5.2. Timer..................................... 27 5.3. Interrupt.................................... 28 5.4. Memory.................................... 31 5.5. Partition.................................... 32 6. Benchmark 34 7. Conclusions and Future Work 38 Abstract Nowadays, the diversity of embedded applications has been developed into a new stage with the availability of various new high-performance processors and low cost on-chip memory. As the result of these new advances in hardware, there is a
    [Show full text]
  • Empirical Performance Comparison of Hardware and Software Task Context Switching
    View metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by Calhoun, Institutional Archive of the Naval Postgraduate School Calhoun: The NPS Institutional Archive Theses and Dissertations Thesis Collection 2009-06 Empirical Performance Comparison of Hardware and Software Task Context Switching Schultz, Eric A. Monterey, California. Naval Postgraduate School http://hdl.handle.net/10945/46226 NAVAL POSTGRADUATE SCHOOL MONTEREY, CALIFORNIA THESIS EMPIRICAL PERFORMANCE COMPARISON OF HARDWARE AND SOFTWARE TASK CONTEXT SWITCHING by Eric A. Schultz June 2009 Thesis Advisor: Cynthia E. Irvine Second Reader: David J. Shifflett Approved for public release; distribution is unlimited THIS PAGE INTENTIONALLY LEFT BLANK ii Form Approved REPORT DOCUMENTATION PAGE OMB No. 0704–0188 The public reporting burden for this collection of information is estimated to average 1 hour per response, including the time for reviewing instructions, searching existing data sources, gathering and maintaining the data needed, and completing and reviewing the collection of information. Send comments regarding this burden estimate or any other aspect of this collection of information, including suggestions for reducing this burden to Department of Defense, Washington Headquarters Services, Directorate for Information Operations and Reports (0704–0188), 1215 Jefferson Davis Highway, Suite 1204, Arlington, VA 22202–4302. Respondents should be aware that notwithstanding any other provision of law, no person shall be subject to any penalty for failing to comply with a collection of information if it does not display a currently valid OMB control number. PLEASE DO NOT RETURN YOUR FORM TO THE ABOVE ADDRESS. 1. REPORT DATE (DD–MM–YYYY) 2. REPORT TYPE 3.
    [Show full text]
  • Raytheon Secure Systems and Networks Delivering Mission Assurance in a Hostile Cyberspace Feature the Benefits of Multi-Level Security
    TecHIGhHLIGHTnING RAoYTHEON l’S oTECHNOgLOGY y Tod2a007 Issyue 2 Raytheon Secure Systems and Networks Delivering Mission Assurance in a Hostile Cyberspace Feature The Benefits of Multi-Level Security ulti-level security (MLS) should be accessible to the individ - secret, confidential and unclassified has been a holy grail ever ual. To ameliorate this problem, data all can reside in a single MLS Msince the early days of high-speed guards requiring addi - domain. MLS provides the ability to applying computer systems to meet tional hardware and processing simultaneously receive, process, Col. Roger Shell was the automation needs of military overhead, or labor intensive proce - store and disseminate data of mul - the deputy director of and intelligence systems. In the dures such as manually reviewing tiple classifications within a domain the National Security 1970s, MITRE published a series of data, are commonly used when where not all users have the securi - Agency’s (NSA) papers (by Bell and LaPadua) that moving data between domains. ty clearance to access all the data National Computer describe the issues and rules of within the domain. MLS needs to Security Center (NCSC) determining access rights of individ - The single-level security domain permeate into the computing envi - as it was formed in the ual users to information, based on paradigm is not compatible with ronment (workstations, servers and early 1980s. Dr. Kenneth their credentials. In fact, in 1971, this time-sensitive collaborative pro - operating systems), the network, Kung joined NCSC in Dr. Roger Schell (then a U.S. Air cessing environment needed to the database and the mission appli - 1984 as one of the Force major) conducted his Ph.D.
    [Show full text]
  • Separation Kernels on Commodity Workstations
    Systems and Network Analysis Center Information Assurance Directorate Separation Kernels on Commodity Workstations 11 March 2010 SNAC DoD, 9800 Savage Rd. Ft. Meade, MD 20755-6704 410-854-6632 DSN: 244-6632 FAX: 410-854-6604 www.nsa.gov/snac [email protected] 1 Separation Kernels on Commodity Workstations 1 Executive Summary ................................................................................................. 3 2 Introduction .............................................................................................................. 4 2.1 SKPP Evaluation ................................................................................................ 4 2.2 Assurance Maintenance ..................................................................................... 5 3 Commodity Workstation Security ............................................................................. 7 3.1 Workstation Security Argument .......................................................................... 7 3.1.1 The Applications .......................................................................................... 7 3.1.2 The Operating System ................................................................................. 7 3.1.3 The Hardware Platform ................................................................................ 8 3.2 Evaluating the Workstation Security Argument .................................................. 8 3.3 Too Many Cooks in the Kitchen ........................................................................
    [Show full text]
  • Say Goodbye to Virtualization for a Safer Cloud
    Say Goodbye to Virtualization for a Safer Cloud Dan Williams Ricardo Koller Brandon Lum IBM T.J. Watson Research Center, Yorktown Heights, NY When it comes to isolation on the cloud, conven- The main culprit is the hugely powerful kernel tional wisdom holds that virtual machines (VMs) pro- syscall API that containers use to interact with vide greater isolation than containers because of their the host OS. [23] low-level interface to the host. A lower-level interface reduces the amount of code and complexityneeded in the Yet LightVM then goes on to try to introduce container- kernel that must be relied upon for isolation. However, like properties to VMs, without giving up the complex it is incorrectly assumed that virtualization mechanisms hardware-based virtualization mechanism implementing are required to achieve a low-level interface suitable for the low-level interface to guests. isolation. In this paper, we argue that the interface to In this paper, we make the observation that the level the host can be lowered for any application by moving of the interface between the guest and the host is not kernel components to userspace. We show that using a fundamentally tied to the actual mechanism used to sep- userspace network stack results in a 33% reduction in arate the guest from the host (like the virtualization or kernel code usage, which is 20% better than when re- process mechanism). In Section 3, we describe how the sorting to virtualization mechanisms and using a VM. high-level container interface can be arbitrarily lowered by introducing library OS (libOS) components to appli- cations or using userspace services in a manner we dub 1 Introduction microkernelification.
    [Show full text]
  • Leaving Legacy Behind Reducing Carbon Footprint of Network Services with Mirageos Unikernels
    Leaving legacy behind Reducing carbon footprint of network services with MirageOS unikernels Hannes Mehnert, https://hannes.nqsb.io 36c3, 27th December 2019, Leipzig 1 / 37 Stack Application Binary Configuration Files Programming language runtime • Unix applications depend on System libraries (libc) Crypto (libssl) libraries and configuration files. System calls, Sockets API • Kernel isolates processes from each other using virtual memory. File system Scheduler Network • Compromise is contained to a User Process Hardware Management Management Drivers single process. Hardware (CPU, disk, NIC, memory) • Privilege escalation by flaws in the system call API (568 in sys/syscall.h). 2 / 37 Hypervisor stack Application Binary Configuration Files Programming language runtime • The hypervisor manages the System libraries (libc) Crypto (libssl) resources, and splits them across System calls, Sockets API virtual machines. Hardware is emulated. File system Scheduler Network • Scheduling is done by the User Process Hardware Management Management Drivers hypervisor (VMs) and by each Emulated Hardware and assigned resources virtual machines (processes). • The hypervisor isolates virtual Hypervisor vmm.ko - Resource management - Scheduling of VMs machines from each other. Kernel Hardware (CPU, disk, NIC, memory) 3 / 37 . 4 / 37 . Memory corruption issues are the root-cause of 68% of listed CVEs. Ben Hawkes analysed 108 CVE since start of Google’s Project Zero in 2014, 0day "In the Wild" https://googleprojectzero.blogspot.com/p/0day.html (published 2019-05-15)
    [Show full text]
  • Real-Time Operating System Security T
    Real-Time Operating System Security Weider D. Yu (Dipti Baheti, Jeremy Wai) Computer Engineering Department, San Jose State University, San Jose, CA 95192-0180 6.0 COMMERCIAL SYSTEM DESIGN .......................... 11 Abstract — Real Time Operating Systems 6.1 GREEN HILLS SOFTWARE , INC . .................................. 11 lie at the heart of most embedded systems. 6.2 LYNUX WORKS , INC . ................................................ 12 Connectivity of these systems enable user to 6.3 WIND RIVER , INC . .................................................. 12 monitor and control these systems remotely. 6.4 MICROSOFT , INC . ................................................... 13 This report show current systems have 7.0 SOME KNOWN CASES OF SECURITY LAPSE ......... 13 many faults in which the system is connected to each other, and to the world. 7.1 SECURITY IN VEHICLE NETWORKS .............................. 13 An analysis shows these systems could be 7.2 RISKS IN SCADA SYSTEMS ....................................... 14 significantly more secure if security policies 7.3 ATTACKS ON MOBILE PHONES .................................. 14 were followed and if current computer 8.0 LESSONS LEARNED ............................................. 15 networking security techniques are applied. 9.0 CONCLUSION ..................................................... 15 10.0 REFERENCES ..................................................... 16 Index 0.0 OUR CONTRIBUTIONS .......................................... 1 0.0 OUR CONTRIBUTIONS 1.0 INTRODUCTION ...................................................
    [Show full text]
  • An X86/64 Separation Kernel for High Assurance
    Muen - An x86/64 Separation Kernel for High Assurance Reto Buerki Adrian-Ken Rueegsegger August 29, 2013 University of Applied Sciences Rapperswil (HSR), Switzerland ii Abstract Computer systems are used to store and protect highly sensitive data. At the same time the resources and determination of attackers have increased significantly. Therefore, systems capable of safeguarding critical information must conform to rigorous quality standards to establish trust in the correct functioning. Attaining high assurance for today's monolithic operating systems is exceptionally hard since they tend to be large and include complex functionality. This fact is highlighted by regular security updates provided by operating system vendors. Thus, they are a weak foundation for building secure systems. In contrast, microkernels can be well suited as a basis for systems with strict demands on robustness. They are by definition small, which is a precondition for rigorous verification of correctness. Additionally, they lend themselves to the construction of component-based systems where the incorrect behavior of one partition does not impact the whole system. A separation kernel (SK) is a specialized microkernel that provides an execution environment for multiple components that can only communicate according to a given policy and are otherwise isolated from each other. Hence, the isolation also includes the limitation of potential side- and covert channels. SKs are generally more static and smaller than dynamic microkernels, which minimizes the possibility of kernel failure and should ease the application of formal verification techniques. Recent addition of advanced hardware virtualization support for the Intel x86 architecture has the potential of greatly simplifying the implementation of a separation kernel which can support complex systems.
    [Show full text]
  • Trusted Display on Untrusted Commodity Platforms
    Trusted Display on Untrusted Commodity Platforms ∗ Miao Yu Virgil D. Gligor Zongwei Zhou ECE Department and CyLab ECE Department and CyLab ECE Department and CyLab Carnegie Mellon University Carnegie Mellon University Carnegie Mellon University [email protected] [email protected] [email protected] ABSTRACT Keywords A trusted display service assures the confidentiality and au- GPU separation kernel; Trusted display thenticity of content output by a security-sensitive applica- tion and thus prevents a compromised commodity operating 1. INTRODUCTION system or application from surreptitiously reading or mod- A trusted display service provides a protected channel ifying the displayed output. Past approaches have failed that assures the confidentiality and authenticity of content to provide trusted display on commodity platforms that use output on selected screen areas. With it users can rely modern graphics processing units (GPUs). For example, full on the information output by a security-sensitive applica- GPU virtualization encourages the sharing of GPU address tion (SecApp) without worrying about undetectable screen space with multiple virtual machines without providing ade- \scrapping" or \painting" by malicious software on commod- quate hardware protection mechanisms; e.g., address-space ity systems; i.e., the display output is surreptitiously read separation and instruction execution control. This paper or modified by a compromised commodity operating systems proposes a new trusted display service that has a minimal (OSes) or applications (Apps). trusted code base and maintains full compatibility with com- Security architectures that isolate entire SecApps from un- modity computing platforms. The service relies on a GPU trusted commodity OSes and Applications (Apps) [35] im- separation kernel that (1) defines different types of GPU plement trusted display functions via trusted path [55, 56].
    [Show full text]