A Real-Time Capable, Open-Source-Based Platform for Off-The-Shelf Embedded Devices

Total Page:16

File Type:pdf, Size:1020Kb

A Real-Time Capable, Open-Source-Based Platform for Off-The-Shelf Embedded Devices A Real-time Capable, Open-Source-based Platform for Off-the-Shelf Embedded Devices Igor Kalkov Department of Computer Science Technical Report Aachener Informatik-Berichte (AIB) ISSN 0935-3232 AIB-2018-03 | | RWTH Aachen University Department of Computer Science March 2018 | | The publications of the Department of Computer Science of RWTH Aachen University are in general accessible through the World Wide Web. http://aib.informatik.rwth-aachen.de/ A Real-time Capable, Open-Source-based Platform for Off-the-Shelf Embedded Devices Von der Fakult¨at fur¨ Mathematik, Informatik und Naturwissenschaften der RWTH Aachen University zur Erlangung des akademischen Grades eines Doktors der Naturwissenschaften genehmigte Dissertation vorgelegt von Igor Kalkov, M.Sc. RWTH aus Bender, Republik Moldau Berichter: Universit¨atsprofessor Dr.-Ing. Stefan Kowalewski Universit¨atsprofessor Dr. Uwe Aßmann Tag der mundlichen¨ Prufung:¨ 10. August 2017 Diese Dissertation ist auf den Internetseiten der Universit¨atsbibliothek online verfugbar.¨ Igor Kalkov Lehrstuhl Informatik 11 [email protected] Aachener Informatik Bericht AIB-2018-03 Herausgeber: Fachgruppe Informatik RWTH Aachen University Ahornstr. 55 52074 Aachen GERMANY ISSN 0935-3232 Abstract Nowadays, software plays a crucial role in the development of embedded products. The product’s design and development process can be significantly simplified by relying on reusable software components and modern general-purpose hardware. However, such off-the-shelf components are typically not able to provide real-time support required in the industry. To address this limitation, different approaches were presented in the past to enable the use of high-level software while retaining precise timings during the inter- action with the physical environment. For example, real-time capable Linux running on general-purpose hardware is widely used in industrial automation today. Furthermore, Linux-based platforms like Android are continuously gaining popularity in all sectors of the market. Due to its intuitive user interface and a wide range of supported hardware, Android is already broadly deployed in different industrial use cases. However, Android devices used in embedded products are still restricted to serving the purpose of pure data visualization and handling of the user input. To extend Android’s field of appli- cation to time-critical domains, this work presents a holistic approach for combining the performance of modern general-purpose off-the-shelf hardware with predictability and determinism of a real-time capable operating system. Instead of adopting common methods for limiting the real-time support to the Linux kernel and native applications, it provides a global perspective on Android’s architecture including the Linux kernel, main high-level components and their interaction in time-critical scenarios. The first part of this dissertation covers enhancements for minimizing the process scheduling latency using the PREEMPT RT patch. Since Android is built upon Linux, in- troducing a fully preemptible kernel and a high-resolution timer enables a more precise process management. This approach allows Android to achieve bounded scheduling deviations in the same order of magnitude as industrial Linux-based systems. In the second part, it is shown that Android’s original memory management may cause unpre- dictable suspensions of running applications or even automatically terminate long-term background processes. To address this issue, the platform is extended with a real-time capable garbage collector based on reference counting. The new collector operates con- currently to real-time threads in a non-blocking incremental manner, avoiding undesired interferences. Furthermore, the proposed modifications provide additional protection for persistent background services. Finally, this thesis implements enhanced methods for data exchange between separate Android applications. Being seamlessly integrated into the platform, new mechanisms allow predictable communication and bounded delays for delivering arbitrary messages across process boundaries. A detailed evaluation of the introduced platform changes highlights the effectiveness and scalability of the presented approach. The resulting system performs better in terms of responsiveness and determinism, while staying fully compatible with standard An- droid components and third-party applications. By combining powerful general-purpose hardware and high-level programming paradigms, Android applications are now able to additionally fulfill strict timing requirements. This allows utilizing the advantages of Android in industrial use cases, which facilitates the development of easily extendable and less complex embedded products with intuitive user interfaces. v Zusammenfassung Heutzutage spielt Software in der Entwicklung eingebetteter Systeme eine besonders wichtige Rolle. Obwohl der Einsatz von Standardhardware und wiederverwendbaren Software-Komponenten die Produktentwicklung bedeutend beschleunigen kann, erfullen¨ diese in der Regel nicht die industriellen Anforderungen an Echtzeitf¨ahigkeit und Ro- bustheit. Aus diesem Grund wurden in der Vergangenheit mehrere Ans¨atze vorgestellt, um auch mit High-Level-Software pr¨azise Timings im Umgang mit der physischen Umge- bung zu erreichen. So sind echtzeitf¨ahige Linux-Systeme auf Basis von Standardhardware in der Industrie bereits weit verbreitet. Auch Linux-basierte Plattformen wie Android ge- winnen kontinuierlich an Popularit¨at in unterschiedlichsten Marktsegmenten. Dank der intuitiven Benutzeroberfl¨ache und der zahlreichen kompatiblen Hardware-Plattformen findet Android heute zunehmend Anwendung in der Industrie. Bisher beschr¨anken sich solche Anwendungen jedoch auf die reine Visualisierung von Programmdaten und Nut- zerinteraktion. Die vorliegende Dissertation pr¨asentiert einen ganzheitlichen Ansatz, um das Einsatzgebiet von Android auf zeitkritische Systeme zu erweitern, indem die Leistungsf¨ahigkeit moderner Standardhardware mit der Vorhersagbarkeit eines echt- zeitf¨ahigen Betriebssystems kombiniert wird. Anstatt die Echtzeitf¨ahigkeit wie ublich¨ auf Linux zu beschr¨anken, wird ein komponentenubergreifendes¨ L¨osungskonzept vorge- stellt. Dieses umfasst sowohl den Linux-Kern als auch die wichtigsten Komponenten von Android und deren Interaktion in zeitkritischen Szenarien. Im ersten Teil der Arbeit wird der PREEMPT RT Patch eingesetzt, um die durch den Prozess-Scheduler verursachte Latenzen zu minimieren. Verbesserte Unterbrechbarkeit des Linux-Kernels sowie ein hochaufl¨osender Timer erm¨oglichen auch unter Android ein pr¨aziseres Prozessmanagement. Damit k¨onnen die maximalen Scheduling-Abweichungen fur¨ Android-Apps auf die Gr¨oßenordnung von industriellen Linux-basierten Systemen beschr¨ankt werden. Im n¨achsten Schritt werden die unvorhersehbaren Unterbrechungen von laufenden Anwendungen durch die automatische Speicherverwaltung untersucht. Dieses Problem wird durch die Einfuhrung¨ eines echtzeitf¨ahigen Garbage Collectors ba- sierend auf Reference Counting gel¨ost. Dieser arbeitet parallel und nicht-blockierend, sodass die Ausfuhrung¨ von Anwendungen mit Echtzeitanforderungen nicht mehr beein- tr¨achtigt wird. Die eingefuhrten¨ Anderungen¨ bieten zus¨atzlichen Schutz fur¨ persistente Hintergrunddienste. Weiterhin pr¨asentiert diese Arbeit erweiterte Methoden fur¨ einen zuverl¨assigen Datenaustausch zwischen laufenden Anwendungen. Diese Erweiterungen werden nahtlos in die Plattform integriert und erm¨oglichen eine vorhersagbare Kommu- nikation zwischen separaten Android-Prozessen mit beschr¨ankten Verz¨ogerungen. Eine detaillierte Auswertung der vorgeschlagenen Modifikationen belegt die Effekti- vit¨at und Skalierbarkeit des gew¨ahlten Ansatzes. Das neue System zeigt eine bessere Re- aktionsf¨ahigkeit und bleibt vollst¨andig kompatibel mit Standard-Android-Komponenten und existierenden Anwendungen. Dadurch k¨onnen Android-Anwendungen strikte zeit- liche Anforderungen erfullen¨ und gleichzeitig von leistungsf¨ahiger Standardhardware und h¨oheren Programmiersprachen profitieren. Der Einsatz einer solchen echtzeitf¨ahigen Android-Plattform erm¨oglicht die Entwicklung von weniger komplexen eingebetteten Produkten in neuen industriellen Szenarien. vii Acknowledgments I hereby express my sincere appreciation to Prof. Dr.-Ing. Stefan Kowalewski for giving me the opportunity to join his group, for supervising my thesis and for providing me the needed freedom to pursue and implement my ideas in research. I also thank Prof. Dr. Uwe Aßmann for serving as the second supervisor and his valuable remarks and suggestions. Furthermore, my thanks go to Prof. Dr. Matthias Muller¨ and Prof. Dr. Jurgen¨ Giesl for taking their time and participating in my examination committee. I have also received help and support from many others during my time as a rese- arch assistant. First of all, I would like to thank my former colleagues at the Chair of Computer Science 11 – Embedded Software for creating a friendly environment and for inspiring discussions. In particular, I thank Thomas Gerlitz, David Th¨onnessen, Mathi- as Obster, Dominik Franke and John F. Schommer for their critical opinions and great collaboration during the development of new concepts in the RTAndroid project. This dissertation owes many of its results to my talented students. A particular men- tion deserve Stefan Schake, Alexandru Gurghian, Stefan Klug, Florian Sehl, Andreas Wustenberg,¨ Stefan Rakel and Johannes Lipp, who wrote excellent
Recommended publications
  • D-Bus, the Message Bus System Training Material
    Maemo Diablo D-Bus, The Message Bus System Training Material February 9, 2009 Contents 1 D-Bus, The Message Bus System 2 1.1 Introduction to D-Bus ......................... 2 1.2 D-Bus architecture and terminology ................ 3 1.3 Addressing and names in D-Bus .................. 4 1.4 Role of D-Bus in maemo ....................... 6 1.5 Programming directly with libdbus ................. 9 1 Chapter 1 D-Bus, The Message Bus System 1.1 Introduction to D-Bus D-Bus (the D originally stood for "Desktop") is a relatively new inter process communication (IPC) mechanism designed to be used as a unified middleware layer in free desktop environments. Some example projects where D-Bus is used are GNOME and Hildon. Compared to other middleware layers for IPC, D-Bus lacks many of the more refined (and complicated) features and for that reason, is faster and simpler. D-Bus does not directly compete with low level IPC mechanisms like sock- ets, shared memory or message queues. Each of these mechanisms have their uses, which normally do not overlap the ones in D-Bus. Instead, D-Bus aims to provide higher level functionality, like: Structured name spaces • Architecture independent data formatting • Support for the most common data elements in messages • A generic remote call interface with support for exceptions (errors) • A generic signalling interface to support "broadcast" type communication • Clear separation of per-user and system-wide scopes, which is important • when dealing with multi-user systems Not bound to any specific programming language (while providing a • design that readily maps to most higher level languages, via language specific bindings) The design of D-Bus benefits from the long experience of using other mid- dleware IPC solutions in the desktop arena and this has allowed the design to be optimised.
    [Show full text]
  • Beej's Guide to Unix IPC
    Beej's Guide to Unix IPC Brian “Beej Jorgensen” Hall [email protected] Version 1.1.3 December 1, 2015 Copyright © 2015 Brian “Beej Jorgensen” Hall This guide is written in XML using the vim editor on a Slackware Linux box loaded with GNU tools. The cover “art” and diagrams are produced with Inkscape. The XML is converted into HTML and XSL-FO by custom Python scripts. The XSL-FO output is then munged by Apache FOP to produce PDF documents, using Liberation fonts. The toolchain is composed of 100% Free and Open Source Software. Unless otherwise mutually agreed by the parties in writing, the author offers the work as-is and makes no representations or warranties of any kind concerning the work, express, implied, statutory or otherwise, including, without limitation, warranties of title, merchantibility, fitness for a particular purpose, noninfringement, or the absence of latent or other defects, accuracy, or the presence of absence of errors, whether or not discoverable. Except to the extent required by applicable law, in no event will the author be liable to you on any legal theory for any special, incidental, consequential, punitive or exemplary damages arising out of the use of the work, even if the author has been advised of the possibility of such damages. This document is freely distributable under the terms of the Creative Commons Attribution-Noncommercial-No Derivative Works 3.0 License. See the Copyright and Distribution section for details. Copyright © 2015 Brian “Beej Jorgensen” Hall Contents 1. Intro................................................................................................................................................................1 1.1. Audience 1 1.2. Platform and Compiler 1 1.3.
    [Show full text]
  • An Introduction to Linux IPC
    An introduction to Linux IPC Michael Kerrisk © 2013 linux.conf.au 2013 http://man7.org/ Canberra, Australia [email protected] 2013-01-30 http://lwn.net/ [email protected] man7 .org 1 Goal ● Limited time! ● Get a flavor of main IPC methods man7 .org 2 Me ● Programming on UNIX & Linux since 1987 ● Linux man-pages maintainer ● http://www.kernel.org/doc/man-pages/ ● Kernel + glibc API ● Author of: Further info: http://man7.org/tlpi/ man7 .org 3 You ● Can read a bit of C ● Have a passing familiarity with common syscalls ● fork(), open(), read(), write() man7 .org 4 There’s a lot of IPC ● Pipes ● Shared memory mappings ● FIFOs ● File vs Anonymous ● Cross-memory attach ● Pseudoterminals ● proc_vm_readv() / proc_vm_writev() ● Sockets ● Signals ● Stream vs Datagram (vs Seq. packet) ● Standard, Realtime ● UNIX vs Internet domain ● Eventfd ● POSIX message queues ● Futexes ● POSIX shared memory ● Record locks ● ● POSIX semaphores File locks ● ● Named, Unnamed Mutexes ● System V message queues ● Condition variables ● System V shared memory ● Barriers ● ● System V semaphores Read-write locks man7 .org 5 It helps to classify ● Pipes ● Shared memory mappings ● FIFOs ● File vs Anonymous ● Cross-memory attach ● Pseudoterminals ● proc_vm_readv() / proc_vm_writev() ● Sockets ● Signals ● Stream vs Datagram (vs Seq. packet) ● Standard, Realtime ● UNIX vs Internet domain ● Eventfd ● POSIX message queues ● Futexes ● POSIX shared memory ● Record locks ● ● POSIX semaphores File locks ● ● Named, Unnamed Mutexes ● System V message queues ● Condition variables ● System V shared memory ● Barriers ● ● System V semaphores Read-write locks man7 .org 6 It helps to classify ● Pipes ● Shared memory mappings ● FIFOs ● File vs Anonymous ● Cross-memoryn attach ● Pseudoterminals tio a ● proc_vm_readv() / proc_vm_writev() ● Sockets ic n ● Signals ● Stream vs Datagram (vs uSeq.
    [Show full text]
  • Open Message Queue Technical Overview Release 5.0
    Open Message Queue Technical Overview Release 5.0 May 2013 This book provides an introduction to the technology, concepts, architecture, capabilities, and features of the Message Queue messaging service. Open Message Queue Technical Overview, Release 5.0 Copyright © 2013, Oracle and/or its affiliates. All rights reserved. This software and related documentation are provided under a license agreement containing restrictions on use and disclosure and are protected by intellectual property laws. Except as expressly permitted in your license agreement or allowed by law, you may not use, copy, reproduce, translate, broadcast, modify, license, transmit, distribute, exhibit, perform, publish, or display any part, in any form, or by any means. Reverse engineering, disassembly, or decompilation of this software, unless required by law for interoperability, is prohibited. The information contained herein is subject to change without notice and is not warranted to be error-free. If you find any errors, please report them to us in writing. If this is software or related documentation that is delivered to the U.S. Government or anyone licensing it on behalf of the U.S. Government, the following notice is applicable: U.S. GOVERNMENT RIGHTS Programs, software, databases, and related documentation and technical data delivered to U.S. Government customers are "commercial computer software" or "commercial technical data" pursuant to the applicable Federal Acquisition Regulation and agency-specific supplemental regulations. As such, the use, duplication, disclosure, modification, and adaptation shall be subject to the restrictions and license terms set forth in the applicable Government contract, and, to the extent applicable by the terms of the Government contract, the additional rights set forth in FAR 52.227-19, Commercial Computer Software License (December 2007).
    [Show full text]
  • Multiprocess Communication and Control Software for Humanoid Robots Neil T
    IEEE Robotics and Automation Magazine Multiprocess Communication and Control Software for Humanoid Robots Neil T. Dantam∗ Daniel M. Lofaroy Ayonga Hereidx Paul Y. Ohz Aaron D. Amesx Mike Stilman∗ I. Introduction orrect real-time software is vital for robots in safety-critical roles such as service and disaster response. These systems depend on software for Clocomotion, navigation, manipulation, and even seemingly innocuous tasks such as safely regulating battery voltage. A multi-process software design increases robustness by isolating errors to a single process, allowing the rest of the system to continue operating. This approach also assists with modularity and concurrency. For real-time tasks such as dynamic balance and force control of manipulators, it is critical to communicate the latest data sample with minimum latency. There are many communication approaches intended for both general purpose and real-time needs [19], [17], [13], [9], [15]. Typical methods focus on reliable communication or network-transparency and accept a trade-off of increased mes- sage latency or the potential to discard newer data. By focusing instead on the specific case of real-time communication on a single host, we reduce communication latency and guarantee access to the latest sample. We present a new Interprocess Communication (IPC) library, Ach,1 which addresses this need, and discuss its application for real-time, multiprocess control on three humanoid robots (Fig. 1). There are several design decisions that influenced this robot software and motivated development of the Ach library. First, to utilize decades of prior development and engineering, we implement our real-time system on top of a POSIX-like Operating System (OS)2.
    [Show full text]
  • Sarath Singapati Inter Process Communication in Android Master of Science Thesis
    SARATH SINGAPATI INTER PROCESS COMMUNICATION IN ANDROID MASTER OF SCIENCE THESIS Examiner: Professor Tommi Mikkonen Examiner and thesis subject approved by The Faculty of Computing and Electrical Engineering on 7th March 2012 II ABSTRACT TAMPERE UNIVERSITY OF TECHNOLOGY Master’s Degree Programme in Information Technology SARATH SINGAPATI INTER PROCESS COMMUNICATION IN ANDROID Master of Science Thesis, 45 pages, 4 Appendix pages June 2012 Major: Software Systems Examiner: Professor Tommi Mikkonen Keywords: Android, Google, mobile applications, Process, IPC Google's Android mobile phone software platform is currently the big opportunity for application software developers. Android has the potential for removing the barriers to success in the development and sale of a new generation of mobile phone application software. Just as the standardized PC and Macintosh platforms created markets for desktop and server software, Android, by providing a standard mobile phone application environment, creates a market for mobile applications and the opportunity for applica- tions developers to profit from those applications. One of the main intentions of Android platform is to eliminate the duplication of functionality in different applications to allow functionality to be discovered and in- voked on the fly, and to let users replace applications with others that offer similar func- tionality. The main problem here is how to develop applications that must have as few dependencies as possible, and must be able to provide services to other applications. This thesis studies the Android mobile operating system, its capabilities in develop- ing applications that communicate with each other and provide services to other applica- tions. As part of the study, a sample application called “Event Planner”, has been devel- oped to experiment how Inter Process Communication works in Android platform, ex- plains how to implement, and use Inter Process Communication (IPC).
    [Show full text]
  • [MS-MQOD]: Message Queuing Protocols Overview
    [MS-MQOD]: Message Queuing Protocols Overview Intellectual Property Rights Notice for Open Specifications Documentation . Technical Documentation. Microsoft publishes Open Specifications documentation (“this documentation”) for protocols, file formats, data portability, computer languages, and standards support. Additionally, overview documents cover inter-protocol relationships and interactions. Copyrights. This documentation is covered by Microsoft copyrights. Regardless of any other terms that are contained in the terms of use for the Microsoft website that hosts this documentation, you can make copies of it in order to develop implementations of the technologies that are described in this documentation and can distribute portions of it in your implementations that use these technologies or in your documentation as necessary to properly document the implementation. You can also distribute in your implementation, with or without modification, any schemas, IDLs, or code samples that are included in the documentation. This permission also applies to any documents that are referenced in the Open Specifications documentation. No Trade Secrets. Microsoft does not claim any trade secret rights in this documentation. Patents. Microsoft has patents that might cover your implementations of the technologies described in the Open Specifications documentation. Neither this notice nor Microsoft's delivery of this documentation grants any licenses under those patents or any other Microsoft patents. However, a given Open Specifications document might be covered by the Microsoft Open Specifications Promise or the Microsoft Community Promise. If you would prefer a written license, or if the technologies described in this documentation are not covered by the Open Specifications Promise or Community Promise, as applicable, patent licenses are available by contacting [email protected].
    [Show full text]
  • On IPC Mechanisms
    More on IPC Mechanisms Karthik Dantu and Steve Ko Administrivia • Project meetings today at 3pm, not Friday. • Assignment 2 due in two days. Today: More on IPC Mechanisms • Why? • Fundamental building blocks of the Android framework • Last time was from the user’s (i.e., programmer’s) perspective to understand other framework components. • Today’s about the internals. • Goal: Understanding the framework structure and IPC mechanisms Today: More on IPC Mechanisms • We will look at two IPC mechanisms. • Looper-handler • Binder • Resources: • AOSP • “Embedded Android” • “Deep Dive into Android IPC/Binder Framework” http://events.linuxfoundation.org/images/ stories/slides/abs2013_gargentas.pdf Looper-Handler • Looper is a per-thread message loop. • Handler processes messages. Looper Architecture Thread Looper Message Queue Message Message Message Handler Handler Handler Looper Protocol: ActivityThread.java Looper • Looper.prepare() Looper • Looper.loop() Handler Handler.sendMessage() Handler.dispatchMessage() Binder • From OpenBinder • Enables two things for IPC • Directory of available IPC calls • Communication mechanism Architecture Context Manager (servicemanager.c) Process A Process B Client IBinder AIDL Binder Proxy AIDL IBinder Stub Binder Token Binder Service Binder Driver (/dev/binder) Context Manager • A special Binder object (handle #0) • The directory of all Binder-ready processes • On Android, ServiceManager becomes this context manager for Binder. • servicemanager.c • binder_become_context_manager(): Registers itself with the kernel Binder module as the context manager. • binder_loop() starts a message loop that listens to the commands from kernel Binder module. ServiceManager Registering with Service Manager System Server Service Manager App • Runs many services, e.g., • Maintains directories for • Can use Context’s Activity Manager, Power registered remote objects getSystemService() or Manager, etc.
    [Show full text]
  • MPI: a Message-Passing Interface Standard
    The MPI Message Queue Dumping Interface Version 1.0 MPI Forum Working Group on Tools Accepted by the Message Passing Interface Forum December 12, 2013 Acknowledgments Author Anh Vo Contributing Authors John DelSignore, Kathryn Mohror, Jeff Squyres Reviewers Dong Ahn, William Gropp, Martin Schulz Contents 1 Background1 2 Overview 2 3 Definitions3 3.1 Shared Library and DLL.............................3 3.1.1 Shared Library..............................3 3.1.2 Shared Object File............................3 3.1.3 Dynamic-link Library..........................3 3.1.4 Dynamically Loaded Library......................3 3.1.5 DLL....................................3 3.2 Process and Image................................3 3.2.1 Image...................................3 3.2.2 MPI Process...............................4 3.2.3 Address Space..............................4 3.2.4 \mqs_image"...............................4 3.3 \Starter" Process.................................4 3.3.1 The MPI Process as the Starter Process................4 3.3.2 A Separate mpiexec as the Starter Process..............4 3.4 MQD Host and Target Node..........................5 4 Debugger/MPI Interaction Model6 4.1 The MQD DLL..................................6 4.2 Debugger/Debug DLL Interaction Use Case..................6 5 Interface Specifications9 5.1 MPIR_dll_name.................................9 5.2 Types for Target Independence.........................9 5.2.1 mqs_tword_t...............................9 5.2.2 mqs_taddr_t............................... 10 5.2.3 mqs_target_type_sizes.........................
    [Show full text]
  • Chapter 14: Interprocess Communication
    Chapter 14: Interprocess Communication CMPS 105: Systems Programming Prof. Scott Brandt T Th 2-3:45 Soc Sci 2, Rm. 167 Plans This week: Chapter 14 Next week: Networked IPC Other? Last week Something Review Introduction Interprocess Communication (IPC) enables processes to communicate with each other to share information Pipes (half duplex) FIFOs (named pipes) Stream pipes (full duplex) Named stream pipes Message queues Semaphores Shared Memory Sockets Streams Pipes Oldest (and perhaps simplest) form of UNIX IPC Half duplex Data flows in only one direction Only usable between processes with a common ancestor Usually parent-child Also child-child Pipes (cont.) #include <unistd.h> int pipe(int fildes[2]); fildes[0] is open for reading and fildes[1] is open for writing The output of fildes[1] is the input for fildes[0] Understanding Pipes Within a process Writes to fildes[1] can be read on fildes[0] Not very useful Between processes After a fork() Writes to fildes[1] by one process can be read on fildes[0] by the other Understanding Pipes (cont.) Even more useful: two pipes, fildes_a and fildes_b After a fork() Writes to fildes_a[1] by one process can be read on fildes_a[0] by the other, and Writes to fildes_b[1] by that process can be read on fildes_b[0] by the first process Using Pipes Usually, the unused end of the pipe is closed by the process If process A is writing and process B is reading, then process A would close fildes[0] and process B would close fildes[1] Reading from a pipe whose write
    [Show full text]
  • Shared Memory Introduction
    12 Shared Memory Introduction 12.1 Introduction Shared memory is the fastest form of IPC available. Once the memory is mapped into the address space of the processes that are sharing the memory region, no kernel involvement occurs in passing data between the processes. What is normally required, however, is some form of synchronization between the processes that are storing and fetching information to and from the shared memory region. In Part 3, we discussed various forms of synchronization: mutexes, condition variables, read–write locks, record locks, and semaphores. What we mean by ‘‘no kernel involvement’’ is that the processes do not execute any sys- tem calls into the kernel to pass the data. Obviously, the kernel must establish the mem- ory mappings that allow the processes to share the memory, and then manage this memory over time (handle page faults, and the like). Consider the normal steps involved in the client–server file copying program that we used as an example for the various types of message passing (Figure 4.1). • The server reads from the input file. The file data is read by the kernel into its memory and then copied from the kernel to the process. • The server writes this data in a message, using a pipe, FIFO, or message queue. These forms of IPC normally require the data to be copied from the process to the kernel. We use the qualifier normally because Posix message queues can be implemented using memory-mapped I/O (the mmap function that we describe in this chapter), as we showed in Section 5.8 and as we show in the solution to Exercise 12.2.
    [Show full text]
  • Interaction Between the User and Kernel Space in Linux
    1 Interaction Between the User and Kernel Space in Linux Kai Lüke, Technische Universität Berlin F Abstract—System calls based on context switches from user to kernel supported in POSIX as well as System V style. A very space are the established concept for interaction in operating systems. common principle for IPC are sockets, and pipes can be seen On top of them the Linux kernel offers various paradigms for commu- as their most simple case. Besides the popular IP family with nication and management of resources and tasks. The principles and TCP/UDP, the local Unix domain sockets play a big role basic workings of system calls, interrupts, virtual system calls, special for many applications, while Netlink sockets are specific purpose virtual filesystems, process signals, shared memory, pipes, Unix or IP sockets and other IPC methods like the POSIX or System V to the Linux kernel and are not often found in user space message queue and Netlink are are explained and related to each other applications due to portability to other operating systems. in their differences. Because Linux is not a puristic project but home for There have been attempts to bring the D-BUS IPC into many different concepts, only a mere overview is presented here with the kernel with a Netlink implementation, kdbus and then focus on system calls. Bus1, but this will not be covered here. Also comparative studies with other operating systems are out of scope. 1 INTRODUCTION 2 KERNEL AND USER SPACE ERNELS in the Unix family are normally not initiating K any actions with outside effects, but rely on requests The processes have virtualized access to the memory as well from user space to perform these actions.
    [Show full text]