Anpassung Eines Netzwerkprozessor-Referenzsystems Im Rahmen Des MAMS-Forschungsprojektes

Total Page:16

File Type:pdf, Size:1020Kb

Anpassung Eines Netzwerkprozessor-Referenzsystems Im Rahmen Des MAMS-Forschungsprojektes Anpassung eines Netzwerkprozessor-Referenzsystems im Rahmen des MAMS-Forschungsprojektes Diplomarbeit an der Fachhochschule Hof Fachbereich Informatik / Technik Studiengang: Angewandte Informatik Vorgelegt bei von Prof. Dr. Dieter Bauer Stefan Weber Fachhochschule Hof Pacellistr. 23 Alfons-Goppel-Platz 1 95119 Naila 95028 Hof Matrikelnr. 00041503 Abgabgetermin: Freitag, den 28. September 2007 Hof, den 27. September 2007 Diplomarbeit - ii - Inhaltsverzeichnis Titelseite i Inhaltsverzeichnis ii Abbildungsverzeichnis v Tabellenverzeichnis vii Quellcodeverzeichnis viii Funktionsverzeichnis x Abkurzungen¨ xi Definitionen / Worterkl¨arungen xiii 1 Vorwort 1 2 Einleitung 3 2.1 Abstract ......................................... 3 2.2 Zielsetzung der Arbeit ................................. 3 2.3 Aufbau der Arbeit .................................... 4 2.4 MAMS .......................................... 4 2.4.1 Anwendungsszenario .............................. 4 2.4.2 Einführung ................................... 5 2.4.3 NGN - Next Generation Networks ....................... 5 2.4.4 Abstrakte Darstellung und Begriffe ...................... 7 3 Hauptteil 8 3.1 BorderGateway Hardware ............................... 8 3.1.1 Control-Blade - Control-PC .......................... 9 3.1.2 ConverGate-D Evaluation Board: Modell easy4271 ............. 10 3.1.3 ConverGate-D Netzwerkprozessor ....................... 12 3.1.4 Motorola POWER Chip (MPC) Modul ..................... 12 3.1.5 Test- und Arbeitsumgebung .......................... 13 3.2 Vorhandene Software / Werkzeuge .......................... 15 3.2.1 ConverGate-D Konfiguration .......................... 15 3.2.2 Das U-Boot (Universal Boot) .......................... 22 3.2.3 Buildroot: Cross-Compile-Umgebung ..................... 24 3.2.4 Embedded Linux ................................ 27 3.3 BorderGateway Software: Struktur .......................... 32 Inhaltsverzeichnis - iii - Fachhochschule Hof 3.4 BorderGateway Software: Spezifikation ........................ 34 3.4.1 Allgemeines ................................... 34 3.4.2 Fehlerbehandlung ............................... 35 3.4.3 Control-PC Schnittstelle ............................ 36 3.4.4 ConverGate-D Schnittstelle .......................... 54 3.4.5 Binärer Dateizugriff (BCFA) .......................... 62 3.4.6 Netzwerkpakete ................................ 65 3.5 BorderGateway Software: Implementierung ..................... 80 3.5.1 Allgemeines ................................... 80 3.5.2 Fehlerbehandlung ............................... 81 3.5.3 Control-PC Schnittstelle ............................ 82 3.5.4 ConverGate-D Schnittstelle .......................... 91 3.5.5 Binärer Dateizugriff (BCFA) .......................... 99 3.5.6 Netzwerkpakete ................................ 100 3.6 Modul- / System- / Integrationstests ......................... 108 3.6.1 Modul- und Funktionstests ........................... 108 3.6.2 Systemtests ................................... 109 3.6.3 Integrationstests ................................ 123 4 Schlussbetrachtung 125 4.1 Zusammenfassung ................................... 125 4.2 Ausblick ......................................... 126 A Pr¨aambel: Anh¨ange 128 B Meilensteine / Zeitplan 129 C Errata 131 C.1 Sourceball buildroot_easy4271.sh ........................... 131 C.2 ConverGate-D Linux Kernel Treiber: drv_cg, v3.2.5 ................. 132 C.3 ConverGate-D Linux Kernel Treiber Erweiterungen ................. 133 C.4 ConverGate-D Treiber: cg_connectix ......................... 133 D Offene Themen 134 E Benutzte Software 136 E.1 Betriebssysteme ..................................... 136 E.2 ARP / ICMP Generierung ................................ 136 E.2.1 Linux: arping, ping ............................... 136 E.2.2 Windows: arp.exe, ping.exe .......................... 137 E.3 Serielle Verbindungen ................................. 137 E.4 Ethernet Paketüberwachung .............................. 138 E.5 Testpaketgenerierung .................................. 138 E.6 TFTP ........................................... 138 E.7 NFS ........................................... 139 E.8 Erstellung der Diplomarbeit .............................. 139 E.9 Bilder, Diagramme ................................... 139 E.10 Quellcodedokumentation ............................... 140 Inhaltsverzeichnis Diplomarbeit - iv - E.10.1 Doxygen ..................................... 140 E.10.2 Quellcodestatistik: cncc ............................ 140 E.11 Dateimanager / Editor ................................. 140 F Technische Informationen 141 F.1 Quellcode ........................................ 141 F.2 Bytereihenfolge (byte order) .............................. 141 F.3 ConverGate-D Daten .................................. 142 F.4 MPC-Modul Daten ................................... 142 F.5 Buildroot Daten ..................................... 143 F.6 uClibc: semtimedop Patch ............................... 143 F.7 Installation des gesamten Quellcode ......................... 143 F.8 Erstellen eines Sourceballs ............................... 143 F.9 BorderGateway Software: Kommandozeilenparameter ............... 144 F.10 BorderGateway: Makefile.am ............................. 145 Literaturverzeichnis 146 Internetverzeichnis 147 Index 158 Eidesstattliche Erkl¨arung 161 Inhaltsverzeichnis - v - Fachhochschule Hof Abbildungsverzeichnis Mit Ausnahme der Bilder 1.1 bis 2.2, 3.3 bis 3.5 und F.2 bis F.4, wurden alle Bilder in diesem Dokument vom Autor erstellt. Die Beschriftung in Bildern und Diagrammen ist durchweg in Englisch, da dieses Dokument und Bilder daraus in firmeninternen Projekten verwendet werden werden, bei denen die Sprache für technische Dokumente immer Englisch ist. Zudem ist Englisch die Sprache der IT-Industrie und lässt sich meistens nicht verständlich und knapp übersetzen. Ausgenommen hiervon sind z.B. die Internetseiten im Anhang. 1.1 Fachhochschule Hof (Logo) .............................. 1 1.2 Infineon Technologies AG (Logo) ........................... 1 1.3 Alcatel-Lucent (Logo) ................................. 2 2.1 Multi Access, Modular Services (Logo) ........................ 4 2.2 Bundesministerium für Bildung und Forschung (Logo) ............... 5 2.3 Next Generation Network (abstrakt) ......................... 6 2.4 Multi Access, Modular Services (abstrakt) ...................... 7 3.1 BorderGateway Hardware - prototypische Darstellung ............... 8 3.2 BorderGateway Hardware - Control-Blade (rechts) ................. 9 3.3 ConverGate-D Evaluation Board ............................ 11 3.4 ConverGate-D Netzwerkprozessor ........................... 12 3.5 MPC-Modul ....................................... 12 3.6 Testumgebung ..................................... 13 3.7 WinEASY - Programmfenster ............................. 17 3.8 WinEASY - Neue Nachrichten ............................. 18 3.9 WinEASY - LIB_WE_CGD_OpenFile .......................... 19 3.10 WinEASY - LIB_WE_CGD_CloseFile .......................... 19 3.11 WinEASY - CG_UC_FWD_FIB_VALUE_Assign ..................... 20 3.12 WinEASY - CG_UC_FWD_FIB_VALUE_Query ..................... 20 3.13 WinEASY - Nachrichtenübertragung ......................... 21 3.14 BorderGateway Software - Struktur .......................... 33 3.15 Befehl an MPC-Modul ................................. 41 3.16 Befehl - ADD_REQ ................................... 42 3.17 Befehl - SUBTRACT_REQ ............................... 44 3.18 Befehl - MODIFY_REQ ................................. 46 3.19 Befehl - READ_STATUS_REQ ............................. 48 3.20 Befehl - CONFIG_REQ ................................. 49 3.21 Befehl - WAKE_UP ................................... 50 3.22 Befehl - FAULT ..................................... 51 Abbildungsverzeichnis Diplomarbeit - vi - 3.23 BorderGateway - Media Stream Switching (downstream) .............. 60 3.24 ARP-Request Prozess .................................. 69 3.25 SIP Paketbehandlung .................................. 76 3.26 Debug-Thread - Hilfe [hH?] .............................. 110 3.27 Control-PC - CONFIG_REQ senden [ENTER] ..................... 111 3.28 MPC-Modul - CONFIG_REQ empfangen ....................... 112 3.29 MPC-Modul - FAULT senden [f] & [F] ......................... 112 3.30 Control-PC - FAULT empfangen ............................ 113 3.31 MPC-Modul - BorderGateway Information [1] .................... 114 3.32 MPC-Modul - BCAM und FIB Lese-/Schreibzugriffe [vV] .............. 115 3.33 Linux - ARP-Anfragen senden (arping) ........................ 116 3.34 MPC-Modul - ARP-Anfragen beantworten ....................... 116 3.35 Control-PC - IP- und MAC-Adresse .......................... 116 3.36 MPC-Modul - ARP-Anfrage an Control-PC (Test #1) ................. 116 3.37 MPC-Modul - ARP-Anfrage an Control-PC (Test #2) ................. 117 3.38 Linux - ICMP-Anfragen senden (ping) ......................... 117 3.39 MPC-Modul - ICMP-Anfragen beantworten ...................... 117 3.40 MPC-Modul - SIP-Pakete senden [s] & [S] ...................... 118 3.41 PC #1 - SIP-Pakete empfangen ............................. 119 3.42 MPC-Modul - BorderGateway Information nach SIP-Test [1] ............ 119 3.43 PC #1 - Paket an BorderGateway senden ....................... 122 3.44 PC #1 - Pakete an den BorderGateway ........................ 122 3.45 PC #2 - Pakete vom BorderGateway ......................... 123 3.46 T-Systems Berlin - Testaufbau ............................. 124 3.47 T-Systems Berlin
Recommended publications
  • Embedded Java with GCJ
    Embedded Java with GCJ http://0-delivery.acm.org.innopac.lib.ryerson.ca/10.1145/1140000/11341... Embedded Java with GCJ Gene Sally Abstract You don't always need a Java Virtual Machine to run Java in an embedded system. This article discusses how to use GCJ, part of the GCC compiler suite, in an embedded Linux project. Like all tools, GCJ has benefits, namely the ability to code in a high-level language like Java, and its share of drawbacks as well. The notion of getting GCJ running on an embedded target may be daunting at first, but you'll see that doing so requires less effort than you may think. After reading the article, you should be inspired to try this out on a target to see whether GCJ can fit into your next project. The Java language has all sorts of nifty features, like automatic garbage collection, an extensive, robust run-time library and expressive object-oriented constructs that help you quickly develop reliable code. Why Use GCJ in the First Place? The native code compiler for Java does what is says: compiles your Java source down to the machine code for the target. This means you won't have to get a JVM (Java Virtual Machine) on your target. When you run the program's code, it won't start a VM, it will simply load and run like any other program. This doesn't necessarily mean your code will run faster. Sometimes you get better performance numbers for byte code running on a hot-spot VM versus GCJ-compiled code.
    [Show full text]
  • Java in Embedded Linux Systems
    Java in Embedded Linux Systems Java in Embedded Linux Systems Thomas Petazzoni / Michael Opdenacker Free Electrons http://free-electrons.com/ Created with OpenOffice.org 2.x Java in Embedded Linux Systems © Copyright 2004-2007, Free Electrons, Creative Commons Attribution-ShareAlike 2.5 license http://free-electrons.com Sep 15, 2009 1 Rights to copy Attribution ± ShareAlike 2.5 © Copyright 2004-2008 You are free Free Electrons to copy, distribute, display, and perform the work [email protected] to make derivative works to make commercial use of the work Document sources, updates and translations: Under the following conditions http://free-electrons.com/articles/java Attribution. You must give the original author credit. Corrections, suggestions, contributions and Share Alike. If you alter, transform, or build upon this work, you may distribute the resulting work only under a license translations are welcome! identical to this one. For any reuse or distribution, you must make clear to others the license terms of this work. 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. License text: http://creativecommons.org/licenses/by-sa/2.5/legalcode Java in Embedded Linux Systems © Copyright 2004-2007, Free Electrons, Creative Commons Attribution-ShareAlike 2.5 license http://free-electrons.com Sep 15, 2009 2 Best viewed with... This document is best viewed with a recent PDF reader or with OpenOffice.org itself! Take advantage of internal
    [Show full text]
  • Industrial Iot: from Embedded to the Cloud Using Java from Beginning to End
    Industrial IoT: from Embedded to the Cloud using Java from Beginning to End © Copyright Azul Systems 2015 Simon Ritter Deputy CTO, Azul Systems @speakjava © Copyright Azul Systems 2019 1 Industrial IoT © Copyright Azul Systems 2019 Industrial Revolutions Industry 1.0 Industry 2.0 Industry 3.0 Industry 4.0 st 1st mechanical loom 1st assembly line 1 programmable Industrial (1784) (1913) logic controller Internet (1969) End of Start of Start of Start of 18th Century 20th Century 1970s 21st Century © Copyright Azul Systems 2019 3 Industrial Automation The traditional segment drivers haven’t changed... Competitive edge Production throughput Enhanced quality Manufacturing visibility and control Energy and Government & Safety Business resource management standards compliance and security integration © Copyright Azul Systems 2019 5 Industrial Automation Smart devices are key Local intelligence and Flexible networking Performance and scalability decision-making Security Remote management Functions become services © Copyright Azul Systems 2019 6 Industrial IoT: Edge to Cloud Intelligent Gateways Cloud Edge Devices • Minimal compute power • Complex event filtering • Data collection • Raw event filtering • Basic analytics • Analytics • Programmable control • Offline/online control • Machine Learning • Mesh networking • Command & control © Copyright Azul Systems 2019 Why Java For Industrial IoT? © Copyright Azul Systems 2019 Java Embedded Platform ▪ Hardware and Operating System independence ▪ Local database, web-enabled, event aware ▪ Optimised for
    [Show full text]
  • JOP: a Java Optimized Processor for Embedded Real-Time Systems
    Downloaded from orbit.dtu.dk on: Oct 04, 2021 JOP: A Java Optimized Processor for Embedded Real-Time Systems Schoeberl, Martin Publication date: 2005 Document Version Publisher's PDF, also known as Version of record Link back to DTU Orbit Citation (APA): Schoeberl, M. (2005). JOP: A Java Optimized Processor for Embedded Real-Time Systems. Vienna University of Technology. http://www.jopdesign.com/ General rights Copyright and moral rights for the publications made accessible in the public portal are retained by the authors and/or other copyright owners and it is a condition of accessing publications that users recognise and abide by the legal requirements associated with these rights. Users may download and print one copy of any publication from the public portal for the purpose of private study or research. You may not further distribute the material or use it for any profit-making activity or commercial gain You may freely distribute the URL identifying the publication in the public portal If you believe that this document breaches copyright please contact us providing details, and we will remove access to the work immediately and investigate your claim. DISSERTATION JOP: A Java Optimized Processor for Embedded Real-Time Systems ausgef¨uhrt zum Zwecke der Erlangung des akademischen Grades eines Doktors der technischen Wissenschaften unter der Leitung von AO.UNIV.PROF. DIPL.-ING. DR.TECHN. ANDREAS STEININGER und AO.UNIV.PROF. DIPL.-ING. DR.TECHN. PETER PUSCHNER Inst.-Nr. E182 Institut f¨ur Technische Informatik eingereicht an der Technischen Universit¨at Wien Fakult¨at f¨ur Informatik von DIPL.-ING. MARTIN SCHOBERL¨ Matr.-Nr.
    [Show full text]
  • Ein FPGA-Basierter Java Just-In-Time Compiler Für Eingebettete Anwendungen
    JIFFY - Ein FPGA-basierter Java Just-in-Time Compiler für eingebettete Anwendungen Georg Acher Lehrstuhl für Rechnertechnik und Rechnerorganisation JIFFY - Ein FPGA-basierter Java Just-in-Time Compiler für eingebettete Anwendungen Georg Acher Vollständiger Abdruck der von der Fakultät für Informatik der Technischen Universität München zur Erlangung des akademischen Grades eines Doktors der Naturwissenschaften (Dr. rer. nat.) genehmigten Dissertation. Vorsitzender: Univ.-Prof. Dr. Hans Michael Gerndt Prüfer der Dissertation: 1. Univ.-Prof. Dr. Arndt Bode 2. Univ.-Prof. Dr. Eike Jessen, em. Die Dissertation wurde am 18.6.2003 bei der Technischen Universität München eingereicht und durch die Fakultät für Informatik am 6.10.2003 ange- nommen. JIFFY - Ein FPGA-basierter Java Just-in-Time Compiler für eingebettete Anwendungen Georg Acher Kurzfassung Durch die wachsende Leistungsfähigkeit von Prozessoren für eingebettete Sys- teme wird der Einsatz von Java für diesen Bereich immer vielversprechender. Al- lerdings sind die von normalen Desktop- oder Serversystemen bekannten Tech- niken zur Beschleunigung der Java Virtual Machine (JVM), wie z.B. die Just- in-Time-Compilation (JIT), bei den sehr begrenzten Ressourcen in dieser Gerä- teklasse nur schwer einsetzbar oder erfordern eine Bindung auf eine bestimmte CPU-Architektur. Diese Arbeit stellt das JIFFY-Konzept vor, das den Ablauf und die Integration eines vollständigen JIT-Compilers für die JVM in einem frei programmierbaren Logikbaustein (FPGA, Field Programmable Gate Array) beschreibt. Durch den Einsatz des FPGAs wird eine sehr hohe Übersetzungsgeschwindigkeit erreicht, wobei die Qualität des erzeugten Compilats die von einfachen, softwarebasierten JIT-Compilern mindestens erreicht und oft übersteigt. Durch ein spezielles Kon- zept ist der gesamte Übersetzungsvorgang im FPGA und damit die synthetisierte Gatterlogik unabhängig von der Zielarchitektur und erlaubt eine flexible Nutzung auch für typische heterogene Mehrprozessorsysteme in Kommunikationsanwen- dungen.
    [Show full text]
  • JOP Reference Handbook: Building Embedded Systems with a Java Processor
    Downloaded from orbit.dtu.dk on: Sep 30, 2021 JOP Reference Handbook: Building Embedded Systems with a Java Processor Schoeberl, Martin Publication date: 2009 Document Version Publisher's PDF, also known as Version of record Link back to DTU Orbit Citation (APA): Schoeberl, M. (2009). JOP Reference Handbook: Building Embedded Systems with a Java Processor. http://www.jopdesign.com/ General rights Copyright and moral rights for the publications made accessible in the public portal are retained by the authors and/or other copyright owners and it is a condition of accessing publications that users recognise and abide by the legal requirements associated with these rights. Users may download and print one copy of any publication from the public portal for the purpose of private study or research. You may not further distribute the material or use it for any profit-making activity or commercial gain You may freely distribute the URL identifying the publication in the public portal If you believe that this document breaches copyright please contact us providing details, and we will remove access to the work immediately and investigate your claim. JOP Reference Handbook JOP Reference Handbook Building Embedded Systems with a Java Processor Martin Schoeberl Copyright c 2009 Martin Schoeberl Martin Schoeberl Strausseng. 2-10/2/55 A-1050 Vienna, Austria Email: [email protected] Visit the accompanying web site on http://www.jopdesign.com/ and the JOP Wiki at http://www.jopwiki.com/ Published 2009 by CreateSpace, http://www.createspace.com/ All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, electronic, mechanical, recording or otherwise, without the prior written permission of Martin Schoeberl.
    [Show full text]
  • A Dynamic Binary Instrumentation Engine for the ARM Architecture
    A Dynamic Binary Instrumentation Engine for the ARM Architecture Kim Hazelwood Artur Klauser University of Virginia Intel Corporation ABSTRACT behavior. The same frameworks have been used to implement run- Dynamic binary instrumentation (DBI) is a powerful technique for time optimizations, run-time enforcement of security policies, and analyzing the runtime behavior of software. While numerous DBI run-time adaptation to environmental factors, such as power and frameworks have been developed for general-purpose architectures, temperature. Yet, almost all of this research has targeted the high- work on DBI frameworks for embedded architectures has been fairly performance computing domain. limited. In this paper, we describe the design, implementation, and The embedded computing market is a great target for dynamic applications of the ARM version of Pin, a dynamic instrumentation binary instrumentation. On these systems it is critical for perfor- system from Intel. In particular, we highlight the design decisions mance bottlenecks, memory leaks, and other software inefficiencies that are geared toward the space and processing limitations of em- to be located and resolved. Furthermore, considerations such as bedded systems. Pin for ARM is publicly available and is shipped power and environmental adaptation are arguably more important with dozens of sample plug-in instrumentation tools. It has been than in other computing domains. Unfortunately, robust, general- downloaded over 500 times since its release. purpose instrumentation tools aren’t nearly as common in the em- bedded arena (compared to IA32, for example). The Pin dynamic instrumentation system fills this void, allowing novice users to eas- Categories and Subject Descriptors ily, efficiently, and transparently instrument their embedded appli- D.3.4 [Programming Languages]: Code generation, Optimiza- cations, without the need for application source code.
    [Show full text]
  • Embedding Linux
    L1nux Alex Lentnon explains the whys and hows of fitting a software quart into a pint pot-with room to spare t's hard to escape hearing about Liiiux these for networking. This includes a large nurnber of days, while sightiiigs of the. Linux mascot, drivers for network interface adaptors, and a a slightly overweight penguin, are complete implementation ofTCP/IP networking. Ibecoming commonplace. If you're a There are also drivers available for USB devices, systems softw-are buff tlie excitement can seem PCMClA cards, multimedia devices and many natural enough, but for everyone else, curious other types of hardware. bewilderment is the more likely sentiment. So The typical Liiiux distribution comprises a what exactly is Linux, and why is it so wealth of software resources. In addition to the important? kernel, it will include a basic Linux file system, Linux is an open-source Unix-like kernel, that a desktop GUI, development and debugging can be freely distributed under the ternis of the tools and a myriad of other open-source GNU General Public Liccnse. (See the Links (distributed under the GPL) amlications and section for details of the GNU project and the utilities Such is the enthusiasm of the Linux Open Source Initiative). It was developed initially fraternity that, whatever your requirements, by the Finnish student LinusTorvalds, and had its there 15 likely to he a group working on a first official release a surprisingly long time ago project which will be useful to you-XM in October 199 1.Right from the beginning, as is Java, wireless networking, Bluetooth, netwo tlie case today, distributions of the Linux kernel protocols, IPv6, home automatLon, remote have been accompanied by GNU-developed data acquisition and many iiiore utility prograins to form a complete operating system.
    [Show full text]
  • Oracle Java ME Embedded 8 and 8.1
    ORACLE FAQ Frequently Asked Questions Oracle Java ME Embedded 8 and 8.1 Introduction Customer Benefits Oracle Java ME Embedded 8 enables device software Oracle Java ME Embedded 8 is designed to meet the needs of intelligence that can be delivered via modules and in- intelligent and connected services on resource constrained market upgrades, allowing device manufacturers to devices in the Internet of Things (IoT), such as those found in Wireless Modules, Building and Industrial Controllers, Smart extend the lifetime, flexibility, and value of embedded Meters, Tracking Systems, Environmental Monitors, solutions. Heathcare, Home Automation devices, Vending Machines, and more. Oracle Java ME Embedded 8 Enables IoT Technology in Small Embedded Devices Oracle Java ME Embedded 8 is a complete Java runtime Oracle Java ME Embedded 8 is designed and optimized to client, optimized for ARM architecture connected meet the unique requirements of small embedded, low power microcontrollers and other resource-constrained systems. The devices such as micro-controllers and other resource- product provides dedicated embedded functionality and is constrained hardware without screens or user interfaces. targeted for low-power, limited memory devices requiring • Ready-to-run client Java runtime stack optimized for support for a range of network services and I/O interfaces. embedded systems Built on an optimized implementation of Java Platform, Micro • Scalable from resource-constrained microcontroller devices to more powerful embedded systems Edition (Java ME)
    [Show full text]
  • Real-Time Code Generation in Virtualizing Runtime Environments
    Department of Computer Science Real-time Code Generation in Virtualizing Runtime Environments Dissertation submitted in fulfillment of the requirements for the academic degree doctor of engineering (Dr.-Ing.) to the Department of Computer Science of the Chemnitz University of Technology from: Dipl.-Inf. (Univ.) Martin Däumler born on: 03.01.1985 born in: Plauen Assessors: Prof. Dr.-Ing. habil. Matthias Werner Prof. Dr. rer. nat. habil. Wolfram Hardt Chemnitz, March 3, 2015 Acknowledgements The work on this research topic was a professional and personal development, rather than just writing this thesis. I would like to thank my doctoral adviser Prof. Dr. Matthias Werner for the excellent supervision and the time spent on numerous professional discus- sions. He taught me the art of academia and research. I would like to thank Alexej Schepeljanski for the time spent on discussions, his advices on technical problems and the very good working climate. I also thank Prof. Dr. Wolfram Hardt for the feedback and the cooperation. I am deeply grateful to my family and my girlfriend for the trust, patience and support they gave to me. Abstract Modern general purpose programming languages like Java or C# provide a rich feature set and a higher degree of abstraction than conventional real-time programming languages like C/C++ or Ada. Applications developed with these modern languages are typically deployed via platform independent intermediate code. The intermediate code is typi- cally executed by a virtualizing runtime environment. This allows for a high portability. Prominent examples are the Dalvik Virtual Machine of the Android operating system, the Java Virtual Machine as well as Microsoft .NET’s Common Language Runtime.
    [Show full text]
  • Oracle Optimized Java SE for Embedded Platforms
    <Insert Picture Here> DOAG 2010, Nürnberg Oracle Optimized Java SE for Embedded Platforms Dr. Rainer Eschrich Principal Sales Consultant Java Embedded Business Unit The preceding is intended to outline our general product direction. It is intended for information purposes only, and may not be incorporated into any contract. It is not a commitment to deliver any material, code, or functionality, and should not be relied upon in making purchasing decisions. The development, release, and timing of any features or functionality described for Oracle’s products remains at the sole discretion of Oracle. © Oracle 2010 2 Topics Why Java Java SE Embedded Technical Details Use Cases Conclusions © Oracle 2010 3 ©2010 Oracle Corporation Java in Embedded – An Introduction Embedded Microprocessor Trends • Cortex A5 Dual Core • Atom Dual Core Processors • PowerPC QorIQ Family • Cortex A9 Dual/Quad Core • N550 1.5ghz 8.5w • P2020 Dual Core 1.2ghz • 250mw power 1ghz today • D525 1.8ghz 13w • P4080 Quad Core 1.5ghz •ARM Eagle Cortex A15 Coming • D510 1.66ghz 13w Embedded Communication • Quad 2.5 ghz! • Nvidia Tegra 2 – 1ghz Dual A9 • 330 1.6ghz 8w Processors • Marvell Quad-Core •TI OMAP4 Dual core Cortex-A9 Common Themes • Embedded Multi-Core is everywhere • ARM continuing low power legacy, Intel moving into that space with Atom • ARM setting sights on server market © Oracle 2010 5 Java Features • Proven & Stable • Huge Developer Base • Rapid Application Development • Fully Object Oriented • Run on a Virtual Machine – Memory Management, Portability, Cross
    [Show full text]
  • Supporting Precise Garbage Collection in Java Bytecode-To-C
    Supporting Precise Garbage Collection in Java Bytecode- to-C Ahead-of-Time Compiler for Embedded Systems Dong-Heon Jung Sung-Hwan Jaemok Lee Soo-Mook JongKuk Park Bae Moon School of Electrical Engineering and Computer Science Seoul National University, Seoul 151-742, Korea {clamp,uhehe99,seasoul,jaemok,smoon}@altair.snu.ac.kr Abstract digital TVs, and telematics [19]. The advantage of Java as an A Java bytecode-to-C ahead-of-time compiler (AOTC) can embedded platform is three folds. First, the use of a virtual improve the performance of a Java virtual machine (JVM) by machine allows a consistent runtime environment for a wide translating bytecode into C code, which is then compiled into range of devices that have different CPUs, OS, and hardware machine code via an existing C compiler. Although AOTC is (e.g., displays). Secondly, Java has an advantage in security such effective in embedded Java systems, a bytecode-to-C AOTC that it is extremely difficult for a malicious Java code to break could not easily employ precise garbage collection (GC) due to a down a whole system. Finally, it is much easier to develop difficulty in making a GC map, which keeps information on software contents with Java due to its sufficient, mature APIs where each root live object is located when GC occurs. This is and its language features that increase software stability such as one of the reasons why all previous JVMs using a bytecode-to-C garbage collection and exception handling. AOTC employed conservative GC, which can lead to poorer GC The advantage of platform independence is achieved by using performance with more frequent memory shortage, especially in the Java virtual machine (JVM), a program that executes Java’s embedded systems where memory is tight.
    [Show full text]