Integration of Drivers in the Linux Kernel

Total Page:16

File Type:pdf, Size:1020Kb

Integration of Drivers in the Linux Kernel THCHMUST04 Proceedings of ICALEPCS2011, Grenoble, France FREE AND OPEN SOURCE SOFTWARE AT CERN: INTEGRATION OF DRIVERS IN THE LINUX KERNEL Juan David Gonz´alez Cobas, Samuel Iglesias Gons´alvez, Julian Howard Lewis, Javier Serrano, Manohar Vanga, CERN, Geneva, Switzerland Emilio G. Cota, Columbia University, NY (formerly at CERN), U.S.A. Alessandro Rubini, Federico Vaga, University of Pavia, Italy Abstract Benefits Most device drivers written for accelerator control sys- There are many reasons that make the insertion of code tems suffer from a severe lack of portability due to the in the mainline kernel a desirable target. ad hoc nature of the code, often embodied with intimate knowledge of the particular machine it is deployed in. In • Smoother maintenance in the (frequent) event of ker- this paper we challenge this practice by arguing for the op- nel API changes. [3] posite approach: development in the open, which in our • Very strict process of peer review of the code by case translates into the integration of our code within the knowledgeable and specialised maintainers. Linux kernel. We make our case by describing the up- • Widespread distribution of the code base, which can stream merge effort of the tsi148 driver, a critical (and then be enhanced and get contributions by researchers complex) component of the control system. The encour- working on similar problems. aging results from this effort have then led us to follow • Input from the topmost experts in the field. the same approach with two more ambitious projects, cur- • Best practice and use of bleeding-edge tools selected rently in the works: Linux support for the upcoming FMC by experienced programmers, e.g. git [4], sparse [5] boards [1, 2] and a new I/O subsystem. and Coccinelle [6]. • Avoidance of suboptimal, ad hoc solutions in favour TSI148 DRIVER INTEGRATION IN THE of the best ones from the technical point of view. • KERNEL Contributing back in return to the many benefits the FOSS community gives us. Rationale • Being able to drive a critical hardware component with software in the vanilla kernel, with no local, id- The VME bus is a central component of the Controls iosyncratic modifications. System at CERN. We rely on 1140 FECs (Front End Com- puters), 710 of which are VME crates with SBC (Single It is worth noting that the importance of the last point Board Computers). A process of renovation is in course, only became apparent once the merge effort was well un- involving the migration from derway. In our control system, renovated FECs are diskless • CES RIO2/RIO3 SBCs with PowerPC CPUs runing machines that boot a custom rt kernel [11], carefully con- LynxOS (around 605 crates by August 2011), to figured and patched to match local needs. The upstream • MEN-A20 SBCs with Intel CPUs running real-time merge of the tsi148 driver allows us to deploy off-the-shelf Linux (around 105 by August 2011). kernels packaged by linux distributions, thus largely reduc- ing the kernel maintenance burden. The MEN-A20 SBC incorporates a TSI148 VME-to- PCI-X bridge chip. To support the functionalities re- quired, and for maximum backward compatibility with the Caveats legacy CES API, a device driver was developed by CERN’s Some of the caveats herewith enumerated will be elab- BE/CO group in spring 2009. Clearly, this is a critical com- orated further in the description of the integration process, ponent of the controls system: every VME device relies on but we summarize here the most important ones. the provided programming interface to the VME bus. The CERN-developed driver offers, therefore, a CES compati- • It is hard, frustrating at times. One should be ready for bility API to facilitate the transition during the renovation the peculiar culture of the Linux Kernel Mailing List. process and a new API more in line with what is common • Design, APIs and coding practice that are customary practice in the Linux kernel. or simply acceptable locally must be adapted or re- Work on the inclusion of the driver in the Linux kernel built to comply with the strict standards imposed by 2011 bystarted the respective authors — cc Creative Commons Attribution 3.0 (CC BY 3.0) in late 2010 and is currently nearing completion. the Linux kernel developers. The morale is that the c ○ This effort, along with its motivations and consequences, is end product will most certainly be different to (and documented in the remainder of this Section. better than) the original. Copyright 1248 Embedded + realtime software Proceedings of ICALEPCS2011, Grenoble, France THCHMUST04 • One must be prepared to compromise. The most prac- Wishbone Cores tical, short-lived solution might not be the technically Core Drivers .... perfect one kernel maintainers aim at. • Maintainers are occasionally hard to deal with. Wishbone Bus • The review process may be long; several iterations are usually necessary when merging significant changes. Carrier Firmware • Small, incremental changes are more likely to be ac- Driver cepted than big, hard-to-digest ones. The rule of thumb is to “Separate logical changes into a single MZ FPGA patch file.” [7] ID • Having a good history of prior contributions gives Application Bitstreams more respectability and ease of acceptance: the sys- tem is based on meritocracy. Figure 1: Wishbone bus driver architecture. The Process Submission of source code for acceptance in the kernel the overall quality of the code must improve signifi- is done by means of patches subject to a process of peer re- cantly. [8] • view before acceptance. The reviews are sometimes daunt- There are API incompatibilities with the driver cur- ing, and much editing and re-submissions can result. This rently used at CERN; this implies that a transient ker- process of strict code review is another good practice our nel module must adapt interfaces if driver code has to team adopted for its development process, a practice that remain untouched. has proved very beneficial. Our fist attempt of integration of the tsi148 driver was DRIVERS FOR THE FMC FAMILY initiated in late 2010 by one of the authors (Emilio G. Cota). A family of carrier/mezzanine modules compliant with By that time, a tsi148 driver had recently been admitted the ANSI VITA 57 FMC standard [2] is described in [1]. in the staging [8] area of the kernel, its maintainer being This kit of boards, developed by the BE/CO Hardware and Martyn Welch. This driver brought a tentative support for Timing section at CERN is another case in point for the the VME bus that covered two VME-to-PCI bridges: benefits of a Linux kernel-centric approach. The hardware concept and architecture are described in the aforemen- • The Tundra Universe chips, with work derived from tioned paper [1]; the key point is that the mezzanine pro- VMELinux by John Huggins and Michael Wyrick. vides basic circuitry, and the core of the application logic is • The Tundra TSI148 chip, inspired in the above. implemented in the FPGA of the carrier board. The cores inside this FPGA are interconnected via a Wishbone [9] The set of patches initially submitted provided improve- bus. ments in several areas, esp. in orthodox implementation of From the software point of view, a particular instance the Linux bus/device model concepts. Acceptance by the of this family behaves like a PCI-to-Wishbone or VME-to- maintainer was partial, and modifications related to the de- Wishbone bridge. The Wishbone bus interconnects a set of vice model implementation remained controversial and not cores providing functionalities that are either common to accepted. the whole family of mezzanines, or specific to the applica- In 2011, another of this paper’s authors, Manohar Vanga, tion board actually plugged in the FMC slot. We show in took over the submission effort. Some bugs in the staging figure 2 the block diagram of the FMC 100MS 14 bit ADC, driver were fixed, and the bulk of modifications concern- a typical example of an FPGA application comprising cores ing the device model were partially acknowledged. This for, among others led to several review iterations; at the time of this writ- • 2 ing, the definitive submission and acceptance of the last set Basic I C interfacing to the mezzanine board. • of patches concerning the core device model is in its fi- Wishbone mastering. • nal stage, and will be applied by the corresponding kernel DMA access to DDR3 memory in the carrier board. • maintainer in the next merge window. Mezzanine-specific control logic (e.g. ADC program- Although the whole set of patches concerning bug fixes ming/setup). • and device model of the tsi148 VME bridge driver is fi- Interrupt control. nally accepted, there is still a long way before reaching the final desideratum, i.e., driving our tsi148 devices with The consequence of this modular design of the applica- stock software from the mainline kernel tree. tion FPGA is that the device driver architecture reflects the structure of this set of cores (see figure 1). The driver for 2011 by the respective authors — cc Creative Commons Attribution 3.0 (CC BY 3.0) c • The outstanding goal should be now getting the VME the carrier board performs essentially the following basic ○ driver out of the ./staging/ tree. For this to happen, functions Embedded + realtime software 1249 Copyright THCHMUST04 Proceedings of ICALEPCS2011, Grenoble, France DDR RAM gree of adherence to standard practice among the Linux kernel developers, because of the LynxOS coding practice formerly prevalent. FPGA DDR CONTROLLER Two needs arise here clearly, in the light of our intention of having our whole set of drivers incorporated upstream: AQN AQN ADDR DMA UTC CVRT • Proceed to a more homogeneous, Linux-only code WISHBONE BUS 4cha base.
Recommended publications
  • Interrupt Handling in Linux
    Department Informatik Technical Reports / ISSN 2191-5008 Valentin Rothberg Interrupt Handling in Linux Technical Report CS-2015-07 November 2015 Please cite as: Valentin Rothberg, “Interrupt Handling in Linux,” Friedrich-Alexander-Universitat¨ Erlangen-Nurnberg,¨ Dept. of Computer Science, Technical Reports, CS-2015-07, November 2015. Friedrich-Alexander-Universitat¨ Erlangen-Nurnberg¨ Department Informatik Martensstr. 3 · 91058 Erlangen · Germany www.cs.fau.de Interrupt Handling in Linux Valentin Rothberg Distributed Systems and Operating Systems Dept. of Computer Science, University of Erlangen, Germany [email protected] November 8, 2015 An interrupt is an event that alters the sequence of instructions executed by a processor and requires immediate attention. When the processor receives an interrupt signal, it may temporarily switch control to an inter- rupt service routine (ISR) and the suspended process (i.e., the previously running program) will be resumed as soon as the interrupt is being served. The generic term interrupt is oftentimes used synonymously for two terms, interrupts and exceptions [2]. An exception is a synchronous event that occurs when the processor detects an error condition while executing an instruction. Such an error condition may be a devision by zero, a page fault, a protection violation, etc. An interrupt, on the other hand, is an asynchronous event that occurs at random times during execution of a pro- gram in response to a signal from hardware. A proper and timely handling of interrupts is critical to the performance, but also to the security of a computer system. In general, interrupts can be emitted by hardware as well as by software. Software interrupts (e.g., via the INT n instruction of the x86 instruction set architecture (ISA) [5]) are means to change the execution context of a program to a more privileged interrupt context in order to enter the kernel and, in contrast to hardware interrupts, occur synchronously to the currently running program.
    [Show full text]
  • User Manual Issue 2.0.2 September 2017
    The Embedded I/O Company TDRV015-SW-82 Linux Device Driver Reconfigurable FPGA Version 2.0.x User Manual Issue 2.0.2 September 2017 TEWS TECHNOLOGIES GmbH Am Bahnhof 7 25469 Halstenbek, Germany Phone: +49 (0) 4101 4058 0 Fax: +49 (0) 4101 4058 19 e-mail: [email protected] www.tews.com TDRV015-SW-82 This document contains information, which is Linux Device Driver proprietary to TEWS TECHNOLOGIES GmbH. Any Reconfigurable FPGA reproduction without written permission is forbidden. Supported Modules: TEWS TECHNOLOGIES GmbH has made any TAMC631 (TPLD001) effort to ensure that this manual is accurate and TAMC640 (TPLD002) complete. However TEWS TECHNOLOGIES GmbH TAMC641 (TPLD003) reserves the right to change the product described TAMC651 (TPLD004) in this document at any time without notice. TPMC632 (TPLD005) TEWS TECHNOLOGIES GmbH is not liable for any damage arising out of the application or use of the device described herein. 2011-2017 by TEWS TECHNOLOGIES GmbH Issue Description Date 1.0.0 First Issue March 14, 2011 1.0.1 SupportedModulesadded September30,2011 2.0.0 New API implemented March 7, 2012 2.0.1 IncludestatementinExampleCodescorrected August 18, 2015 Reference to Engineering Documentation removed 2.0.2 Filelistmodified(licenseadded) September28,2017 TDRV015-SW-82 - Linux Device Driver Page 2 of 75 Table of Contents 1 INTRODUCTION......................................................................................................... 4 2 INSTALLATION.........................................................................................................
    [Show full text]
  • Faux Disk Encryption: Realities of Secure Storage on Mobile Devices August 4, 2015 – Version 1.0
    NCC Group Whitepaper Faux Disk Encryption: Realities of Secure Storage On Mobile Devices August 4, 2015 – Version 1.0 Prepared by Daniel A. Mayer — Principal Security Consultant Drew Suarez — Senior Security Consultant Abstract In this paper, we discuss the challenges mobile app developers face in securing data stored on devices including mobility, accessibility, and usability requirements. Given these challenges, we first debunk common misconceptions about full-disk encryption and show why it is not sufficient for many attack scenarios. We then systematically introduce the more sophisticated secure storage techniques that are available for iOS and Android respectively. For each platform, we discuss in-depth which mechanisms are available, how they technically operate, and whether they fulfill the practical security and usability requirements. We conclude the paper with an analysis of what still can go wrong even when current best-practices are followed and what the security and mobile device community can do to address these shortcomings. Table of Contents 1 Introduction ......................................................................... 3 2 Challenges in Secure Mobile Storage .................................................. 4 3 Threat Model Considerations ......................................................... 5 4 Secure Data Storage on iOS .......................................................... 6 4.1 Fundamentals of iOS Data Protection .................................................. 7 4.2 Filesystem Encryption ..............................................................
    [Show full text]
  • Linux Kernel and Driver Development Training Slides
    Linux Kernel and Driver Development Training Linux Kernel and Driver Development Training © Copyright 2004-2021, Bootlin. Creative Commons BY-SA 3.0 license. Latest update: October 9, 2021. Document updates and sources: https://bootlin.com/doc/training/linux-kernel Corrections, suggestions, contributions and translations are welcome! embedded Linux and kernel engineering Send them to [email protected] - Kernel, drivers and embedded Linux - Development, consulting, training and support - https://bootlin.com 1/470 Rights to copy © Copyright 2004-2021, Bootlin License: Creative Commons Attribution - Share Alike 3.0 https://creativecommons.org/licenses/by-sa/3.0/legalcode You are free: I to copy, distribute, display, and perform the work I to make derivative works I to make commercial use of the work Under the following conditions: I Attribution. You must give the original author credit. I Share Alike. If you alter, transform, or build upon this work, you may distribute the resulting work only under a license identical to this one. I For any reuse or distribution, you must make clear to others the license terms of this work. I Any of these conditions can be waived if you get permission from the copyright holder. Your fair use and other rights are in no way affected by the above. Document sources: https://github.com/bootlin/training-materials/ - Kernel, drivers and embedded Linux - Development, consulting, training and support - https://bootlin.com 2/470 Hyperlinks in the document There are many hyperlinks in the document I Regular hyperlinks: https://kernel.org/ I Kernel documentation links: dev-tools/kasan I Links to kernel source files and directories: drivers/input/ include/linux/fb.h I Links to the declarations, definitions and instances of kernel symbols (functions, types, data, structures): platform_get_irq() GFP_KERNEL struct file_operations - Kernel, drivers and embedded Linux - Development, consulting, training and support - https://bootlin.com 3/470 Company at a glance I Engineering company created in 2004, named ”Free Electrons” until Feb.
    [Show full text]
  • Linux Kernal II 9.1 Architecture
    Page 1 of 7 Linux Kernal II 9.1 Architecture: The Linux kernel is a Unix-like operating system kernel used by a variety of operating systems based on it, which are usually in the form of Linux distributions. The Linux kernel is a prominent example of free and open source software. Programming language The Linux kernel is written in the version of the C programming language supported by GCC (which has introduced a number of extensions and changes to standard C), together with a number of short sections of code written in the assembly language (in GCC's "AT&T-style" syntax) of the target architecture. Because of the extensions to C it supports, GCC was for a long time the only compiler capable of correctly building the Linux kernel. Compiler compatibility GCC is the default compiler for the Linux kernel source. In 2004, Intel claimed to have modified the kernel so that its C compiler also was capable of compiling it. There was another such reported success in 2009 with a modified 2.6.22 version of the kernel. Since 2010, effort has been underway to build the Linux kernel with Clang, an alternative compiler for the C language; as of 12 April 2014, the official kernel could almost be compiled by Clang. The project dedicated to this effort is named LLVMLinxu after the LLVM compiler infrastructure upon which Clang is built. LLVMLinux does not aim to fork either the Linux kernel or the LLVM, therefore it is a meta-project composed of patches that are eventually submitted to the upstream projects.
    [Show full text]
  • Singularityce User Guide Release 3.8
    SingularityCE User Guide Release 3.8 SingularityCE Project Contributors Aug 16, 2021 CONTENTS 1 Getting Started & Background Information3 1.1 Introduction to SingularityCE......................................3 1.2 Quick Start................................................5 1.3 Security in SingularityCE........................................ 15 2 Building Containers 19 2.1 Build a Container............................................. 19 2.2 Definition Files.............................................. 24 2.3 Build Environment............................................ 35 2.4 Support for Docker and OCI....................................... 39 2.5 Fakeroot feature............................................. 79 3 Signing & Encryption 83 3.1 Signing and Verifying Containers.................................... 83 3.2 Key commands.............................................. 88 3.3 Encrypted Containers.......................................... 90 4 Sharing & Online Services 95 4.1 Remote Endpoints............................................ 95 4.2 Cloud Library.............................................. 103 5 Advanced Usage 109 5.1 Bind Paths and Mounts.......................................... 109 5.2 Persistent Overlays............................................ 115 5.3 Running Services............................................. 118 5.4 Environment and Metadata........................................ 129 5.5 OCI Runtime Support.......................................... 140 5.6 Plugins.................................................
    [Show full text]
  • Linux GPIO: Evolution and Current State of the User
    Linux GPIO: Evolution and Current State of the User API Embedded Linux Conference 2020 Bartosz Golaszewski About us ● Embedded Linux Engineering Firm ● ~40 senior engineers, coming from the semiconductor world ● HW and SW products: from concept to manufacturing ● Upstream Linux kernel development and maintenance ● Founding developers of kernelCI.org project About me ● 10 years experience ● Kernel and user-space developer ● Maintainer of libgpiod and co-maintainer of the GPIO kernel sub-system 2 A lot can change in a couple months... 3 A lot can change in a couple months... The GPIO character device has been extended with new features in linux v5.5 and final new additions before declaring it feature-complete are planned for v5.6 & v5.7. 4 A lot can change in a couple months... The GPIO character device has been extended with new features in linux v5.5 but due to shortcomings in the first version of the ABI, the existing ioctl() calls are being retired and v2 of the ABI is being introduced aiming at a release as part of linux v5.9. 5 Linux GPIO: A Lesson in user API design Embedded Linux Conference 2020 Bartosz Golaszewski Agenda 1. Current state of user API a. sysfs = bad b. Character device c. Recently added features d. GPIO aggregator 2. Upcoming overhaul a. What’s wrong? b. What’s new? c. Advice on designing good uAPI 3. libgpiod a. what’s new b. Future 7 Current state of GPIO uAPI 8 GPIO in userspace ● Writing drivers for devices using GPIOs is encouraged wherever possible, but..
    [Show full text]
  • Fabric Manager for NVIDIA Nvswitch Systems
    Fabric Manager for NVIDIA NVSwitch Systems User Guide / Virtualization / High Availability Modes DU-09883-001_v0.7 | January 2021 Document History DU-09883-001_v0.7 Version Date Authors Description of Change 0.1 Oct 25, 2019 SB Initial Beta Release 0.2 Mar 23, 2020 SB Updated error handling and bare metal mode 0.3 May 11, 2020 YL Updated Shared NVSwitch APIs section with new API information 0.4 July 7, 2020 SB Updated MIG interoperability and high availability details. 0.5 July 17, 2020 SB Updated running as non-root instructions 0.6 Aug 03, 2020 SB Updated installation instructions based on CUDA repo and updated SXid error details 0.7 Jan 26, 2021 GT, CC Updated with vGPU multitenancy virtualization mode Fabric Ma nager fo r NVI DIA NVSwitch Sy stems DU-09883-001_v0.7 | ii Table of Contents Chapter 1. Overview ...................................................................................................... 1 1.1 Introduction .............................................................................................................1 1.2 Terminology ............................................................................................................1 1.3 NVSwitch Core Software Stack .................................................................................2 1.4 What is Fabric Manager?..........................................................................................3 Chapter 2. Getting Started With Fabric Manager ...................................................... 5 2.1 Basic Components...................................................................................................5
    [Show full text]
  • Documentation and Analysis of the Linux Random Number Generator
    Documentation and Analysis of the Linux Random Number Generator Version: 3.6 Document history Version Date Editor Description 2.0 2018-03-21 Stephan Müller Covering kernel 4.15 Re-running all tests of chapters 6 and following on 4.15 2.1 2018-04-11 Stephan Müller Updating the test results for the reboot tests on bare metal with 50,000 reboot cycles 2.2 2018-04-11 Stephan Müller Covering kernel 4.16 2.3 2018-06-18 Stephan Müller Covering kernel 4.17 2.4 2018-08-24 Stephan Müller Covering kernel 4.18 2.5 2018-11-12 Stephan Müller Covering kernel 4.19 Updated seeding process ChaCha20 DRNG documented 2.6 2019-01-11 Stephan Müller Covering kernel 4.20 3.0 2019-04-05 Stephan Müller Covering kernel 5.0 Re-running all tests of chapters 6 and following on 5.0 3.1 2019-04-12 Stephan Müller Adding results of reboot-tests for 5.0 3.2 2019-05-17 Stephan Müller Addressing comments from BSI Covering kernel 5.1 3.3 2019-08-13 Stephan Müller Covering kernel 5.2 3.4 2019-09-26 Stephan Müller Covering kernel 5.3 3.5 2019-12-13 Stephan Müller Covering kernel 5.4 3.6 2020-04-07 Stephan Müller Covering kernel 5.5 Federal Office for Information Security Post Box 20 03 63 D-53133 Bonn Internet: https://www.bsi.bund.de © Federal Office for Information Security 2020 Document history This analysis was prepared for BSI by atsec information security GmbH.
    [Show full text]
  • (Thingspro Gateway V2.6.0 Installation File for Debian 9) Release Notes
    Software Package for ThingsPro 2 (ThingsPro Gateway v2.6.0 installation file for Debian 9) Release Notes Version: v2.6.0 Build: Build 20200616 Release Date: Jul 31, 2020 Applicable Products MC-1121-E2-T, MC-1121-E4-T, MC-1121-E4-T-US, UC-2100 Series, UC-2100-W Series, UC-3100 Series, UC-5100 Series, UC-8112-LX, UC-8112-ME-T-LX, UC-8112-ME-T-LX1, UC-8100A-ME-T Series, UC-8200 Series Supported Operating Systems Moxa Industrial Linux (Debian 9) New Features • Core: ThingsPro now supports Python 3 (Python 2 is deprecated). • Modbus: Shows Modbus TX/RX packet in debug mode. • AWS IoT Core: Supports 0 and 1 settings in QoS. • Aliyun IoT Platform: Supports 0 and 1 settings in QoS. • Sparkplug: Support user-scheduled periodic group uploading of tags. Enhancements • Modbus: Improved the TCP/RTU reconnect mechanism. • Modbus: Serial port will not be occupied if no RTU device is configured. Bugs Fixed • Cellular: An incorrect tag name. • Cellular: Apply the watchdog to prevent system freeze during the reboot process. • Cellular: Keepalive fails due to arping bind with the MAC address of the host instead of the target. • Route: The routing priority is not working when the cellular interface is not WWAN0. • Route: Changing route priority frequently could lead to a deadlock. • OpenVPN: Missing DNS information when OpenVPN is enabled or disabled. • OpenVPN: DNS info missing in the default route update script. • OpenVPN: Incorrect status for MC1121. • AVEVA Insight: All datatypes are changed to string value type in JSON payload. Keep the original datatype.
    [Show full text]
  • Designing a Fast Index Format for Git
    Free University of Bolzano - Bozen Bachelor Thesis Designing a Fast Index Format for Git Author: Supervisor: Thomas Gummerer Dr. Johann Gamper A thesis submitted in fulfillment of the requirements for the degree of Bachelor in Computer Science in July 2013 Contents List of Figures iv Abstract v 1 Introduction1 1.1 Motivation...................................1 1.2 Problem Description and Objectives.....................2 1.3 Organization of the Thesis...........................2 2 Related Work4 2.1 Version Control Systems............................4 2.2 Types of Version Control Systems.......................4 2.3 Git........................................5 3 A New Index for Git7 3.1 The Git Index File...............................7 3.2 Index v2.....................................8 3.3 The New Index File Format v5........................ 11 4 Implementation 15 4.1 Convert Index.................................. 15 4.2 Read Index................................... 15 4.3 Internal Implementation............................ 16 4.4 New In-memory Format............................ 18 4.5 Index Reading API............................... 19 4.6 Writing the New Index Format........................ 20 5 Discussion 22 5.1 Alternative Solutions.............................. 22 5.1.1 B-tree Format............................. 22 5.1.2 Append-only Data Structure..................... 22 5.1.3 Database Format............................ 23 5.1.4 Padded Structure............................ 23 5.2 Discussion.................................... 24 6
    [Show full text]
  • A Technical Companion to Windows Embedded Automotive 7 Proven Technology Adapted for the Automotive Industry
    A Technical Companion to Windows Embedded Automotive 7 Proven technology adapted for the automotive industry Published: July 2010 For the latest information, please see: www.windowsembedded.com/auto Abstract Windows® Embedded Automotive 7―based on the newest generation of embedded operating systems from Microsoft and combining the award-winning Windows® Automotive and Microsoft® Auto platforms―is designed specifically for developing state-of-the-art, in-vehicle infotainment systems. It offers a standardized, industry-proven platform for building communication, entertainment, and service-enabled location-based solutions. This release of Windows Embedded Automotive includes a large set of integrated, tested, and flexible middleware components and tools, in addition to hundreds of components that are available with Windows® Embedded Compact 7. These components make it possible for Windows Embedded Automotive 7–based systems to scale across a broad range of automotive makes and models. By capitalizing on these tools and on the broad Microsoft partner ecosystem, suppliers can reduce development costs and speed time-to-market while extending customers’ lifestyles into the vehicles that they drive. Table of Contents TABLE OF FIGURES ................................................................................................................................... 4 OVERVIEW ............................................................................................................................................... 5 THE BUSINESS CASE FOR WINDOWS
    [Show full text]