AGL Realtime Architecture Options Jun-2018 2 1St Technical Contributor

Total Page:16

File Type:pdf, Size:1020Kb

AGL Realtime Architecture Options Jun-2018 2 1St Technical Contributor AGL Real-time Architecture Options for Critical Services Automotive Linux Summit Tokyo June 2018 Fulup Ar Foll Lead Architect [email protected] IoT.bzh Crew AGL Realtime Architecture Options Jun-2018 2 1St Technical Contributor AGL Realtime Architecture Options Jun-2018 3 What is RealTime in an OS? ● Realtime means “on time” and not “faster” – Realtime is about predictability ● Typically Realtime address following concerns – 80% => Could my execution code be disturbed ? ● If then: – For how much time ? – How often ? – By who ? – 20% => How big is my latency ● Time lost between an external event, and the time my code can start to handle it ? ● Maximum latency fluctuation ? AGL Realtime Architecture Options Jun-2018 4 Linux & Soft/Hard Realtime ● Soft realtime ● Periodical tasks/events of several milliseconds ● Some acceptable unpredictable delays (10/100 ms) ● Often implemented by resource controls ● Latency of few ms with exceptional unpredictable fluctuation +-10ms ● Hard realtime ● Total Latency magnitude of 10/100 us ● Predictable and short delays (< 250ms) ● Current vanilla Linux kernel is Soft RealTime ● Harder realtime with: – Preempt-RT – Xenomai AGL Realtime Architecture Options Jun-2018 5 Which Automotive Apps need RT ? ● Soft Realtime ● Data Acquisition ● Audio/Video ● Hard Realtime ● Cluster ● Emergency/Safety signal AGL Realtime Architecture Options Jun-2018 6 Linux RT Application Impact ● Standard Linux a simple “Ping Flood“ will lags applications. ● Linux network IRQs preempt applications too often and for too long, which significantly increase the latency. ● PREEMPT_RT reduces scheduling latency ● Replaces most spinlock by mutexes ● Support threaded IRQs ● Supports high resolution timers AGL Realtime Architecture Options Jun-2018 7 Turn “ON” Linux RealTime. ● Objectives ● Decrease Application Latencies ● Guaranty that high priority tasks will not be bothered by lower priority ones. ● Make sure interrupts cannot lag your critical apps. ● Soft Realtime (Standard Kernel) ● Container, CGroups, ... ● Hard Realtime (Kernel must be patched) ● PREEMPT-RT ● IPIPE+Xenomai AGL Realtime Architecture Options Jun-2018 8 Preempt_RT vs Xenomai ● Xenomai ● Xenomai supports to leagcy RT non-POSIX applications (eg: VxWorks) ● Dual Kernel solution brings more performances when no more than 4 cores run RT threads ● More confidence on the whole RT application (eg: /proc/xenomai statistics) ● Miss some critical Unix development tools (eg: Valgind) ● Preempt_RT ● Almost Vanilla Linux (no API/ABI changes) ● Continuous testing in OSADL QA farm ● No need for extra userspace libraries ● Less confidence in app, harder to debug, needs extra code for RT monitoring AGL Realtime Architecture Options Jun-2018 9 Xenomai Dual Kernel Mode AGL Realtime Architecture Options Jun-2018 10 Preempt-RT Architecture Internal design of the RTLinux system (Image Courtesy - Linux For U) AGL Realtime Architecture Options Jun-2018 11 Preempt_RT Latency IRQs thread improves latency by removing “disabling of interupts” Latency (us) Source: http://www.emlid.com/raspberry-pi-real-time-kernel AGL Realtime Architecture Options Jun-2018 12 Xenomai & Prempt_RT convergence ● The Linux kernel under Xenomai can use Prempt_RT ● Xenomai 3.x offer dual kernel and native option ● Xenomai latency remains significantly better ● Some options (eg: RtNet only run Xenomai) AGL Realtime Architecture Options Jun-2018 13 Playing Darts with Kernel Patches ● Far more matching kernel version with PREEMPT_RT patches (but harder to port) ● IPIPE patch (arm) ~= 700K (25 000 lines). Better documentation. ● PREEMPT_RT patch ~= 2.8Mo (58 000 lines) AGL Realtime Architecture Options Jun-2018 14 RT Kernel is only a start ● Realtime requires more kernel tuning and clean behaviours on the application side. ● Enable CONFIG_PREEMPT_RT_FULL & CONFIG_HIGHRES_TIMERS to get <1ms precision ● Disable CONFIG_CPU_FREQ ! ● Might conflic with power management ● There are strict rules to follow and actions to take in the application ● Stack pre-faulting ● Virtual Memory locking ● Fine tuning of threads priorities ● malloc() and friends chasing, to avoid page faults (can be difficult with some C++ libraries) ● Forbidden usage of system(); popen(); execve() … in runtime. ● Monitoring run-away threads (ie, tight loops in RT contexts) to prevent system hanging (and to allow debugging). ● clock_nanosleep is your friend, for writing periodic tasks ● Carefull initialization parameters of pthread_mutex, default ones do not have PTHREAD_PRIO_INHERIT ! ● Fancy some LTTng sessions ? (does not work with IPIPE) ● Last but not least ● Not everyting can be RT ● Providing high priority to some task means than the other will inherit of low priority ● Base you flow on lock (semaphore) and not on thread priority ● Get rid of any spin lock AGL Realtime Architecture Options Jun-2018 15 C issues ● malloc()/realloc() do not lead to pagefault always, (though sys_brk() or sys_mmap_pgoff() because of internal memory pool of the glibc ● Thus, a RT ‘leak’ may be hard to reproduce ● Using GDB with a breakpoint on malloc() is usually sufficient ● Another technique, less intrusive, is to use Memory Allocation Hooks of the glibc. ● Some companies allow malloc() for initializations, and always forbid the free() ! AGL Realtime Architecture Options Jun-2018 16 C++ specific issues ● In C++, dynamic allocations are not always explicit ● Example: std::vector growing ● In some extra libraries (eg, boost), memory allocations may be completely out of control (in addition of alien-only-friendly backtraces) AGL Realtime Architecture Options Jun-2018 17 RT Options inside AGL Cluster Entertainement Cloud Head Unix Navigation My Car Portal Maintenance Portal Service Paiement Know Bugs Direction Indication Carte handling Subcriptions Maintenances Localistion management Preference Service Packs POI Transport & ACL Transport & ACL Transport & ACL Cluster CAN-BUS Geopositioning Preferences Log Virtual Signal Virtual Signal Virtual & Analytics Signal Custumisation Engine-CAN-BUS CAN-BUS Gyro, Acelerometer MongoDB Engine No-SQL Engine CAN GPS ABS LIN-BUS Paiement Service Statistics & Analytics Hard RealTime Multi ECUSoft & Cloud RealTime Aware Architecture AGL Realtime Architecture Options Jun-2018 18 AGL RT bindings ● The easiest option to enable RT for AGL ● No need to rewrite existing bindings ● Could easily support linux with RT-Prempt ● A subset of AGL AppFW could be ported to lighter OS (eg: Zephyr, VxWorks, …) ● Impose to create ● Portable AppFw RT transport layer ● Add RT definition to application/services ● More statistic & debug mechanism ● A bridge from AGL to Automotive Safety Services AGL Realtime Architecture Options Jun-2018 19 Few References ● IoT.bzh AGL publications ● https://iot.bzh/en/publications ● Practical Linux RT (ELC) ● https://elinux.org/images/d/d7/Practical-Real-Time-Linux -ELCE15.pdf ● Video Intro RT Linux ● https://www.youtube.com/watch?time_continue=1&v=B KkX9WASfpI AGL Realtime Architecture Options Jun-2018 20.
Recommended publications
  • Industrial Control Via Application Containers: Migrating from Bare-Metal to IAAS
    Industrial Control via Application Containers: Migrating from Bare-Metal to IAAS Florian Hofer, Student Member, IEEE Martin A. Sehr Antonio Iannopollo, Member, IEEE Faculty of Computer Science Corporate Technology EECS Department Free University of Bolzano-Bozen Siemens Corporation University of California Bolzano, Italy Berkeley, CA 94704, USA Berkeley, CA 94720, USA fl[email protected] [email protected] [email protected] Ines Ugalde Alberto Sangiovanni-Vincentelli, Fellow, IEEE Barbara Russo Corporate Technology EECS Department Faculty of Computer Science Siemens Corporation University of California Free University of Bolzano-Bozen Berkeley, CA 94704, USA Berkeley, CA 94720, USA Bolzano, Italy [email protected] [email protected] [email protected] Abstract—We explore the challenges and opportunities of control design full authority over the environment in which shifting industrial control software from dedicated hardware to its software will run, it is not straightforward to determine bare-metal servers or cloud computing platforms using off the under what conditions the software can be executed on cloud shelf technologies. In particular, we demonstrate that executing time-critical applications on cloud platforms is viable based on computing platforms due to resource virtualization. Yet, we a series of dedicated latency tests targeting relevant real-time believe that the principles of Industry 4.0 present a unique configurations. opportunity to explore complementing traditional automation Index Terms—Industrial Control Systems, Real-Time, IAAS, components with a novel control architecture [3]. Containers, Determinism We believe that modern virtualization techniques such as application containerization [3]–[5] are essential for adequate I. INTRODUCTION utilization of cloud computing resources in industrial con- Emerging technologies such as the Internet of Things and trol systems.
    [Show full text]
  • The Many Approaches to Real-Time and Safety Critical Linux Systems
    Corporate Technology The Many Approaches to Real-Time and Safety-Critical Linux Open Source Summit Japan 2017 Prof. Dr. Wolfgang Mauerer Siemens AG, Corporate Research and Technologies Smart Embedded Systems Corporate Competence Centre Embedded Linux Copyright c 2017, Siemens AG. All rights reserved. Page 1 31. Mai 2017 W. Mauerer Siemens Corporate Technology Corporate Technology The Many Approaches to Real-Time and Safety-Critical Linux Open Source Summit Japan 2017 Prof. Dr. Wolfgang Mauerer, Ralf Ramsauer, Andreas Kolbl¨ Siemens AG, Corporate Research and Technologies Smart Embedded Systems Corporate Competence Centre Embedded Linux Copyright c 2017, Siemens AG. All rights reserved. Page 1 31. Mai 2017 W. Mauerer Siemens Corporate Technology Overview 1 Real-Time and Safety 2 Approaches to Real-Time Architectural Possibilities Practical Approaches 3 Approaches to Linux-Safety 4 Guidelines and Outlook Page 2 31. Mai 2017 W. Mauerer Siemens Corporate Technology Introduction & Overview About Siemens Corporate Technology: Corporate Competence Centre Embedded Linux Technical University of Applied Science Regensburg Theoretical Computer Science Head of Digitalisation Laboratory Target Audience Assumptions System Builders & Architects, Software Architects Linux Experience available Not necessarily RT-Linux and Safety-Critical Linux experts Page 3 31. Mai 2017 W. Mauerer Siemens Corporate Technology A journey through the worlds of real-time and safety Page 4 31. Mai 2017 W. Mauerer Siemens Corporate Technology Outline 1 Real-Time and Safety 2 Approaches to Real-Time Architectural Possibilities Practical Approaches 3 Approaches to Linux-Safety 4 Guidelines and Outlook Page 5 31. Mai 2017 W. Mauerer Siemens Corporate Technology Real-Time: What and Why? I Real Time Real Fast Deterministic responses to stimuli Caches, TLB, Lookahead Bounded latencies (not too late, not too Pipelines early) Optimise average case Repeatable results Optimise/quantify worst case Page 6 31.
    [Show full text]
  • Enabling Mobile Service Continuity Across Orchestrated Edge Networks
    This is a postprint version of the following published document: Abdullaziz, O. I., Wang, L. C., Chundrigar, S. B. y Huang, K. L. (2019). Enabling Mobile Service Continuity across Orchestrated Edge Networks. IEEE Transactions on Network Science and Engineering, 7(3), pp. 1774-1787. DOI: https://doi.org/10.1109/TNSE.2019.2953129 © 2019 IEEE. Personal use of this material is permitted. Permission from IEEE must be obtained for all other uses, in any current or future media, including reprinting/republishing this material for advertising or promotional purposes, creating new collective works, for resale or redistribution to servers or lists, or reuse of any copyrighted component of this work in other works. Enabling Mobile Service Continuity across Orchestrated Edge Networks Osamah Ibrahiem Abdullaziz, Student Member, IEEE, Li-Chun Wang, Fellow, IEEE, Shahzoob Bilal Chundrigar and Kuei-Li Huang Abstract—Edge networking has become an important technology for providing low-latency services to end users. However, deploying an edge network does not guarantee continuous service for mobile users. Mobility can cause frequent interruptions and network delays as users leave the initial serving edge. In this paper, we propose a solution to provide transparent service continuity for mobile users in large-scale WiFi networks. The contribution of this work has three parts. First, we propose ARNAB architecture to achieve mobile service continuity. The term ARNAB means rabbit in Arabic, which represents an Architecture for Transparent Service Continuity via Double-tier Migration. The first tier migrates user connectivity, while the second tier migrates user containerized applications. ARNAB provides mobile services just like rabbits hop through the WiFi infrastructure.
    [Show full text]
  • Building Embedded Linux Systems ,Roadmap.18084 Page Ii Wednesday, August 6, 2008 9:05 AM
    Building Embedded Linux Systems ,roadmap.18084 Page ii Wednesday, August 6, 2008 9:05 AM Other Linux resources from O’Reilly Related titles Designing Embedded Programming Embedded Hardware Systems Linux Device Drivers Running Linux Linux in a Nutshell Understanding the Linux Linux Network Adminis- Kernel trator’s Guide Linux Books linux.oreilly.com is a complete catalog of O’Reilly’s books on Resource Center Linux and Unix and related technologies, including sample chapters and code examples. ONLamp.com is the premier site for the open source web plat- form: Linux, Apache, MySQL, and either Perl, Python, or PHP. Conferences O’Reilly brings diverse innovators together to nurture the ideas that spark revolutionary industries. We specialize in document- ing the latest tools and systems, translating the innovator’s knowledge into useful skills for those in the trenches. Visit con- ferences.oreilly.com for our upcoming events. Safari Bookshelf (safari.oreilly.com) is the premier online refer- ence library for programmers and IT professionals. Conduct searches across more than 1,000 books. Subscribers can zero in on answers to time-critical questions in a matter of seconds. Read the books on your Bookshelf from cover to cover or sim- ply flip to the page you need. Try it today for free. main.title Page iii Monday, May 19, 2008 11:21 AM SECOND EDITION Building Embedded Linux SystemsTomcat ™ The Definitive Guide Karim Yaghmour, JonJason Masters, Brittain Gilad and Ben-Yossef, Ian F. Darwin and Philippe Gerum Beijing • Cambridge • Farnham • Köln • Sebastopol • Taipei • Tokyo Building Embedded Linux Systems, Second Edition by Karim Yaghmour, Jon Masters, Gilad Ben-Yossef, and Philippe Gerum Copyright © 2008 Karim Yaghmour and Jon Masters.
    [Show full text]
  • Arxiv:2005.01890V1 [Cs.DC] 5 May 2020 Sources Without Compromising Scheduled Execution Within Given Time Con- Straints
    DRAFT Industrial Control VIA Application Containers: Maintaining DETERMINISM IN IAAS Florian Hofer1,3* | Martin Sehr2 | Alberto Sangiovanni-Vincentelli3 | BarbarA Russo1 1Faculty OF Computer Science, FREE Industry 4.0 IS CHANGING FUNDAMENTALLY DATA collection, ITS STORAGE AND UnivERSITY OF Bolzano-Bozen, Bolzano, ANALYSIS IN INDUSTRIAL processes, ENABLING NOVEL APPLICATION SUCH AS flExi- 39100, Italy BLE MANUFACTURING OF HIGHLY CUSTOMIZED products. Real-time CONTROL OF 2CorporATE TECHNOLOGY, Siemens Corporation, BerkELEY, CA, 94704, USA THESE processes, HOWEVER, HAS NOT YET REALIZED ITS FULL POTENTIAL IN USING THE COLLECTED DATA TO DRIVE FURTHER DEVelopment. Indeed, TYPICAL indus- 3EECS, UnivERSITY OF California, BerkELEY, CA, 94720, USA TRIAL CONTROL SYSTEMS ARE TAILORED TO THE PLANT THEY NEED TO control, mak- ING REUSE AND ADAPTATION A challenge. In THE past, THE NEED TO SOLVE PLANT Correspondence SPECIfiC PROBLEMS OVERSHADOWED THE BENEfiTS OF PHYSICALLY ISOLATING A con- Florian Hofer, Faculty OF Computer Science, TROL SYSTEM FROM ITS plant. WE BELIEVE THAT MODERN VIRTUALIZATION tech- FREE UnivERSITY OF Bolzano-Bozen, Bolzano, niques, SPECIfiCALLY , PRESENT A UNIQUE OPPORTUNITY TO 39100, Italy APPLICATION CONTAINERS Email: fl[email protected] DECOUPLE CONTROL FROM plants. This SEPARATION PERMITS US TO FULLY REALIZE THE POTENTIAL FOR HIGHLY distributed, AND TRANSFERABLE INDUSTRIAL PROCESSES FUNDING INFORMATION EVEN WITH real-time CONSTRAINTS ARISING FROM time-critical sub-processes. iCyPhY, THROUGH Siemens Corporation, In THIS PAPER, WE EXPLORE THE CHALLENGES AND OPPORTUNITIES OF SHIFTING in- CorporATE TECHNOLOGY DUSTRIAL CONTROL SOFTWARE FROM DEDICATED HARDWARE TO bare-metal SERVERS OR (EDGE) CLOUD COMPUTING PLATFORMS USING off-the-shelf TECHNOLOGY. WE PRESENT A MIGRATION ARCHITECTURE AND SHOW, USING A SPECIfiCALLY DEVELOPED ORCHESTRATION tool, THAT CONTAINERIZED APPLICATIONS CAN RUN ON SHARED re- arXiv:2005.01890v1 [cs.DC] 5 May 2020 SOURCES WITHOUT COMPROMISING SCHEDULED EXECUTION WITHIN GIVEN TIME con- STRaints.
    [Show full text]
  • Installing Xenomai 3.X I
    Installing Xenomai 3.x i Installing Xenomai 3.x Installing Xenomai 3.x ii REVISION HISTORY NUMBER DATE DESCRIPTION NAME Installing Xenomai 3.x iii Contents 1 Introduction 1 2 Installation steps 1 3 Installing the Cobalt core 1 3.1 Preparing the Cobalt kernel..............................................1 3.2 Configuring and compiling the Cobalt kernel....................................2 3.3 Cobalt kernel parameters...............................................2 3.4 Examples of building the Cobalt kernel.......................................3 3.4.1 Building a Cobalt/x86 kernel (32/64bit)...................................3 3.4.2 Building a Cobalt/powerpc kernel......................................4 3.4.3 Building Cobalt/arm kernel.........................................4 4 Installing the Mercury core 4 5 Installing the Xenomai libraries and tools4 5.1 Prerequisites......................................................4 5.1.1 Generic requirements (both cores)......................................4 5.1.2 Cobalt-specific requirements.........................................5 5.1.3 Mercury-specific requirement........................................5 5.2 Configuring......................................................5 5.2.1 Generic configuration options (both cores)..................................5 5.2.2 Cobalt-specific configuration options....................................8 5.2.3 Mercury-specific configuration options...................................8 5.3 Cross-compilation...................................................8 6 Examples
    [Show full text]
  • How to Install Xenomai?
    How to install Xenomai? This tutorial will detail Xenomai installation on a small Dell Optiplex 990 desktop having 16GB of RAM and an Intel Core i7-2600 CPU @ 3.40GHz × 8 cores. The machine has two 128GB Samsung SSD's. For the Ubuntu installation, 100GB of the first drive was dedicated to the operating system (mount point /) and the rest was left as swap space. On the second drive, 75GB was dedicated to user home directories (mount point /Volumes/<computer_name>) and the rest was left to backup space (mount point /Volumes/backup). 1 Step-by-step guide for Installing Linux 3.8.13 + Xenomai 2.6.3 (Ubuntu 12.04) 1.1 Prerequisites 1.2 Building a Xenomai-patched Linux kernel package 1.2.1 Downloading the sources/configuring xenomai 1.2.2 Kernel configuration and compilation 1.2.3 Testing for latency issues 1.2.4 Graphics drivers and Xenomai 1.2.4.1 NVIDIA GF119 1.2.4.2 Intel Onboard Graphics i915 1.3 Installing RT-NET 1.3.1 Downloading and installation 1.3.2 Network configuration 1.3.3 Running RTNet 1.3.4 Running RTNet at startup (optional) 1.3.5 Testing RTNet (on the SARCOS robot) 1.4 Installing usb4rt 1.4.1 Background 1.4.2 Installation 1.4.3 Configuration 1.4.4 Resolving IRQ sharing 1.4.5 Running usb4rt 1.4.6 Running usbrt at startup (optional) 1.4.7 Using usb4rt with more than one device 1.4.8 Testing usb4rt 1.4.9 Debugging usb4rt 1.5 Issue Log 1.6 Random Notes: 1.6.1 Reinstalling Ubuntu while preserving partitions 1.6.2 Solving the "invalid arch independent ELF magic" GRUB issue 1.6.3 SSH woes Step-by-step guide for Installing Linux 3.8.13
    [Show full text]
  • Paravirtualizing Linux in a Real-Time Hypervisor
    Paravirtualizing Linux in a real-time hypervisor Vincent Legout and Matthieu Lemerre CEA, LIST, Embedded Real Time Systems Laboratory Point courrier 172, F-91191 Gif-sur-Yvette, FRANCE {vincent.legout,matthieu.lemerre}@cea.fr ABSTRACT applications written for a fully-featured operating system This paper describes a new hypervisor built to run Linux in a such as Linux. The Anaxagoros design prevent non real- virtual machine. This hypervisor is built inside Anaxagoros, time tasks to interfere with real-time tasks, thus providing a real-time microkernel designed to execute safely hard real- the security foundation to build a hypervisor to run existing time and non real-time tasks. This allows the execution of non real-time applications. This allows current applications hard real-time tasks in parallel with Linux virtual machines to run on Anaxagoros systems without any porting effort, without interfering with the execution of the real-time tasks. opening the access to a wide range of applications. We implemented this hypervisor and compared perfor- Furthermore, modern computers are powerful enough to mances with other virtualization techniques. Our hypervisor use virtualization, even embedded processors. Virtualiza- does not yet provide high performance but gives correct re- tion has become a trendy topic of computer science, with sults and we believe the design is solid enough to guarantee its advantages like scalability or security. Thus we believe solid performances with its future implementation. that building a real-time system with guaranteed real-time performances and dense non real-time tasks is an important topic for the future of real-time systems.
    [Show full text]
  • Xenomai - Implementing a RTOS Emulation Framework on GNU/Linux Philippe Gerum First Edition Copyright © 2004
    Xenomai - Implementing a RTOS emulation framework on GNU/Linux Philippe Gerum First Edition Copyright © 2004 Copyright © 2002 Philippe Gerum Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later version published by the Free Software Foundation; with no Invariant Sections, no Front- Cover Texts, and no Back-Cover Texts. A copy of the license is published on gnu.org: "GNU Free Documentation License" [http://www.gnu.org/licenses/ fdl.html]. April 2004 Abstract Generally speaking, the Xenomai technology first aims at helping application designers relying on traditional RTOS to move as smoothly as possible to a GNU/ Linux-based execution environment, without having to rewrite their application entirely. This paper discusses the motivations for proposing this framework, the general observations concerning the traditional RTOS directing this technology, and some in-depth details about its implementation. The Xenomai project has been launched in August 2001. It has merged in 2003 with the RTAI project [http://www.gna.org/projects/rtai/] to produce an industrial- grade real-time Free Software platform for GNU/Linux called RTAI/fusion, on top of Xenomai's abstract RTOS core. Eventually, the RTAI/fusion effort became independent from RTAI in 2005 as the xenomai project [http://www.gna.org/ projects/xenomai/]. Linux is a registered trademark of Linus Torvalds. Other trademarks cited in this paper are the property of their respective owner. 1 Xenomai - Implementing a RTOS emulation framework on GNU/Linux Table of Contents 1. White paper ................................................................................................. 2 1.1.
    [Show full text]
  • Xenomai 3 – an Overview of the Real-Time Framework for Linux
    Xenomai 3 – An Overview of the Real-Time Framework for Linux Copyright © Philippe Gerum 2005-2015 Copyright © Gilles Chanteperdrix 2015 Copyright © Free Electrons 2004-2015 Copyright © Siemens AG, 2015 Creative Commons BY-SA 3.0 license Xenomai 3 – An Overview of the Real-Time Framework for Linux Agenda Project introduction Co-Kernel technology, now and then Xenomai 3 for native Linux Improving co-kernel integration Summary Page 2 April 2016 Jan Kiszka, Corporate Technology © Siemens AG 2015, et al. Creative Commons BY-SA 3.0 license. What is Xenomai? • Old-style real-time extension for Linux? • Something like / a fork of RTAI? • Requires real-time applications to be kernel modules? • …? Page 3 April 2016 Jan Kiszka, Corporate Technology © Siemens AG 2015, et al. Creative Commons BY-SA 3.0 license. What is Xenomai really? • Old-style real-time extension for Linux? • Something like RTAI / RTLinux? Xenomai• … is an RTOS-to-Linux Portability Framework • RTOS-to-Linux portability framework • Come in two flavors It now comes in two flavors • • As co-kernelco-kernel extension extension for for (patched) (patched) Linux Linux • As librarieslibraries forfor nativenative Linux Linux (including (including PREEMPT-RT) PREEMPT-RT) Page 4 April 2016 Jan Kiszka, Corporate Technology © Siemens AG 2015, et al. Creative Commons BY-SA 3.0 license. Xenomai History Xenomai 1.0 • Announced in 2001 – as portability framework for RTOS applications • Required a real-time basis • Development of ADEOS layer for Linux and RTAI • Merged with RTAI => RTAI/fusion Xenomai 2.0 • Departed from RTAI in 2005 – incompatible design goals • Evolved ADEOS to I-pipe layer (also used by RTAI) • Ported to 6 architectures Xenomai 3.0 • Released in 2015 after >5 years of development • Rework of in-kernel core (now POSIX-centric) • Support for native Linux Page 5 April 2016 Jan Kiszka, Corporate Technology © Siemens AG 2015, et al.
    [Show full text]
  • Rtmux: a Thin Multiplexer to Provide Hard Realtime Applications for Linux
    RTMux: A Thin Multiplexer To Provide Hard Realtime Applications For Linux Jim Huang ( 黃敬群 ) < serv.t"#gmail.com$ %ct &'( )*14 / Embedded Linux Con0erence -urope Agenda Mission: Build lightweight real-time environments for Linux/ARM Review of existing technologies RTMux: Resource-Multiplexing Real-time Executive Linux-friendly remote communication mechanisms Full source available: https://github.com/rtmux This work is sponsored by ITRI Taiwan and Delta Electronics Mission: Build Lightweight Real-time environments 0or Linux,ARM Applications In short words, it is L%5-R L%5-R = Linux Optimized for Virtualization, Em.edded, and Realtime Use Case for RTMux Quadcopter with Computer Vision Use Case for RTMux Quadcopter with Computer Vision Hard real-time Autonomous Flight Modes (Landing/Take-off) altitude control, feedback-loop control, RC Autopilot, autonomous navigation Soft real-time Stream real-time flight data on-screen over video Parallel Tracking and Mapping (PTAM) , and the detected walls are visualized in 3D with mapped textures. Source: https://github.com/nymanjens/ardrone-exploration External Autonomous Navigation Various Flight Modes-Stabilize, Alt Hold, Loiter, Auto Mode. For the AUTO mode, GPS is necessary. Waypoints are set in advance. Internal Autonomous Navigation GPS fails in a closed-door environment. Detect a door/window and go out where GPS access is present. Design a controller for navigation of quadcopter from indoor to outdoor environsments. SONAR and Computer vision Source: http://wiki.ros.org/tum_ardrone Applications Linux Real-time Executive Device RTOS RTMux1 Drivers Multiplexer 0or Linux-.ased Real3time Applications De-privileged Privileged RTMux Powered b" O#en Sour%e Sta%& POSIX application Linux application Linux application (Real-time) POSIX glibc olibc minilibc Runtime System calls V-Bus VFS Network RTOS Linux Kernel Memory ..
    [Show full text]
  • The DENX U-Boot and Linux Guide (DULG) for Canyonlands
    The DENX U-Boot and Linux Guide (DULG) for canyonlands Table of contents: • 1. Abstract • 2. Introduction ♦ 2.1. Copyright ♦ 2.2. Disclaimer ♦ 2.3. Availability ♦ 2.4. Credits ♦ 2.5. Translations ♦ 2.6. Feedback ♦ 2.7. Conventions • 3. Embedded Linux Development Kit ♦ 3.1. ELDK Availability ♦ 3.2. ELDK Getting Help ♦ 3.3. Supported Host Systems ♦ 3.4. Supported Target Architectures ♦ 3.5. Installation ◊ 3.5.1. Product Packaging ◊ 3.5.2. Downloading the ELDK ◊ 3.5.3. Initial Installation ◊ 3.5.4. Installation and Removal of Individual Packages ◊ 3.5.5. Removal of the Entire Installation ♦ 3.6. Working with ELDK ◊ 3.6.1. Switching Between Multiple Installations ♦ 3.7. Mounting Target Components via NFS ♦ 3.8. Rebuilding ELDK Components ◊ 3.8.1. ELDK Source Distribution ◊ 3.8.2. Rebuilding Target Packages ◊ 3.8.3. Rebuilding ELDT Packages ♦ 3.9. ELDK Packages ◊ 3.9.1. List of ELDT Packages ◊ 3.9.2. List of Target Packages ♦ 3.10. Rebuilding the ELDK from Scratch ◊ 3.10.1. ELDK Build Process Overview ◊ 3.10.2. Setting Up ELDK Build Environment ◊ 3.10.3. build.sh Usage ◊ 3.10.4. Format of the cpkgs.lst and tpkgs.lst Files ♦ 3.11. Notes for Solaris 2.x Host Environment • 4. System Setup ♦ 4.1. Serial Console Access ♦ 4.2. Configuring the "cu" command ♦ 4.3. Configuring the "kermit" command ♦ 4.4. Using the "minicom" program ♦ 4.5. Permission Denied Problems ♦ 4.6. Configuration of a TFTP Server ♦ 4.7. Configuration of a BOOTP / DHCP Server ♦ 4.8. Configuring a NFS Server • 5.
    [Show full text]