



**Hochschule**  
**Augsburg** University of  
Applied Sciences

## Bachelorarbeit

Fakultät für  
Informatik

Studienrichtung  
Technische Informatik

### Konfiguration und Optimierung des Embedded-Linux-Betriebssystem für Automotive Image Processing Unit

Betreuer: Mladen Kovacev

in Kooperation mit der Firma: EDAG Engineering GmbH

Prüfer: Prof.Dr.-Ing Hubert Högl

Verfasser:  
Hugues landry Nseupi Nono  
Salomon-Idler-Str 25  
86159 Augsburg  
+49 157 79552970  
landrynono60@yahoo.de  
Matrikelnr.: 2022666

Hochschule für angewandte  
Wissenschaften Augsburg  
An der Hochschule 1  
86161 Augsburg  
Telefon: +49 (0)821-5586-0  
Fax: +49 (0)821-5586-3222  
info@hs-augsburg.de

---

© 2022 Hugues landry Nseupi Nono

Diese Arbeit mit dem Titel

»Konfiguration und Optimierung des Embedded-Linux-Betriebssystem für  
Automotive Image Processing Unit - Betreuer: Mladen Kovacev«

von Hugues landry Nseupi Nono steht unter einer

*Creative Commons Namensnennung-Nicht-kommerziell-Weitergabe unter gleichen  
Bedingungen 3.0 Deutschland Lizenz (CC BY-NC-SA).*  
<http://creativecommons.org/licenses/by-nc-sa/3.0/de/>



Sämtliche, in der Arbeit beschriebene und auf dem beigelegten Datenträger vorhandene, Ergebnisse dieser Arbeit in Form von Quelltexten, Software und Konzeptentwürfen stehen unter einer GNU General Public License Version 3.

<http://www.gnu.de/documents/gpl.de.html>

Die nachfolgende Arbeit enthält vertrauliche Informationen und Daten der Firma EDAG Engineering GmbH. Veröffentlichungen oder Vervielfältigungen - auch nur auszugsweise oder in elektronischer Form sind ohne ausdrückliche schriftliche Genehmigung der Firma EDAG Engineering GmbH nicht gestattet.

---

## **Zusammenfassung**

Abstract auf Deutsch. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.

## **Abstract**

Abstract in English. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. At vero eos et accusam et justo duo dolores et ea rebum. Stet clita kasd gubergren, no sea takimata sanctus est Lorem ipsum dolor sit amet.

# **Inhaltsverzeichnis**

|                                                             |             |
|-------------------------------------------------------------|-------------|
| <b>Inhaltsverzeichnis</b>                                   | <b>IV</b>   |
| <b>Abkürzungsverzeichnis</b>                                | <b>VI</b>   |
| <b>Abbildungsverzeichnis</b>                                | <b>VII</b>  |
| <b>Verzeichnis der Listings</b>                             | <b>VIII</b> |
| <b>1 Einleitung</b>                                         | <b>1</b>    |
| 1.1 Motivation . . . . .                                    | 1           |
| 1.2 Ziel der Arbeit . . . . .                               | 1           |
| 1.3 Überblick über den Aufbau der Arbeit . . . . .          | 2           |
| <b>2 Technische Grundlagen</b>                              | <b>3</b>    |
| 2.1 Technische Ausgangssituation . . . . .                  | 3           |
| 2.2 Can Bus Systeme . . . . .                               | 4           |
| 2.2.1 Can Message Frame . . . . .                           | 4           |
| 2.2.1.1 Data Frame . . . . .                                | 5           |
| 2.2.1.2 Remote Frame . . . . .                              | 6           |
| 2.2.1.3 Error Frame . . . . .                               | 7           |
| 2.2.1.4 Overload Frame . . . . .                            | 8           |
| 2.2.2 Can Physical Layer . . . . .                          | 8           |
| 2.3 SPI Interface . . . . .                                 | 9           |
| 2.4 Embedded Linux . . . . .                                | 11          |
| 2.5 Komponente eines Embedded Linux Systems . . . . .       | 12          |
| 2.6 Petalinux Tool Flow . . . . .                           | 14          |
| 2.6.1 Petalinux Installation . . . . .                      | 15          |
| 2.6.2 Wichtige Petalinux Kommando . . . . .                 | 15          |
| 2.6.3 Petalinux Projekt Strukture . . . . .                 | 17          |
| <b>3 Umsetzung</b>                                          | <b>19</b>   |
| 3.1 Allgemein über das Projekt . . . . .                    | 19          |
| 3.2 Hardware Platform . . . . .                             | 21          |
| 3.2.1 ZynqMP UltraScale + MPSoC ZCU106 Evaluation Board . . | 21          |
| 3.2.1.1 Ultrasale + MPSoC Architektur . . . . .             | 21          |

*Inhaltsverzeichnis*

---

|          |                                                        |           |
|----------|--------------------------------------------------------|-----------|
| 3.2.1.2  | Allgemeine Ansicht des Zynq Ultrasale+ MPSoC . . . . . | 23        |
| 3.2.1.3  | Processing System (PS) . . . . .                       | 25        |
| 3.2.1.4  | Programmable Logik (PL) . . . . .                      | 26        |
| 3.2.2    | MCP251XFD CAN Controller . . . . .                     | 27        |
| 3.3      | Konfiguration und Bauen des Systems . . . . .          | 27        |
| <b>4</b> | <b>Fazit und Ausblick</b>                              | <b>28</b> |
| 4.1      | Fazit . . . . .                                        | 28        |
| 4.2      | Ausblick . . . . .                                     | 28        |
|          | <b>Literaturverzeichnis</b>                            | <b>29</b> |
| <b>A</b> | <b>Anhang</b>                                          | <b>a</b>  |
| A.1      | Inhalt des Datenträgers . . . . .                      | a         |

## **Abkürzungsverzeichnis**

|            |                               |
|------------|-------------------------------|
| APU .....  | Application processing units  |
| CAN .....  | Control Area Network          |
| CRC .....  | Cyclic Redundancy Check       |
| CSU .....  | Configuration Security Unit   |
| DLC .....  | Data Length Code              |
| FPGA ..... | Field Programmable Gate Array |
| FSBL ..... | First Stage Bootloader Codes  |
| IPU .....  | Image Processing Unit         |
| OCM .....  | On-Chip RAM                   |
| PMU .....  | Platform Management Unit      |
| RPU .....  | Real-time processing units    |
| RTR .....  | Remote Transmission Request   |
| SOF .....  | Start of Frame                |

## **Abbildungsverzeichnis**

|      |                                                                              |    |
|------|------------------------------------------------------------------------------|----|
| 2.1  | CAN System Diagram . . . . .                                                 | 3  |
| 2.2  | CAN-Data Frame Architektur . . . . .                                         | 5  |
| 2.3  | CAN-Remote Frame Architektur . . . . .                                       | 7  |
| 2.4  | Can-Error-Frame . . . . .                                                    | 7  |
| 2.5  | Can-Overload-Frame . . . . .                                                 | 8  |
| 2.6  | Can-Bus Connexion . . . . .                                                  | 8  |
| 2.7  | CAN_H and CAN_L . . . . .                                                    | 9  |
| 2.8  | SPI Bus . . . . .                                                            | 10 |
| 2.9  | der Bootvorgang bei zynq+MPSoCs . . . . .                                    | 13 |
| 2.10 | PetaLinux-Werkzeugfluss . . . . .                                            | 14 |
| 2.11 | petalinux Projektstruktur . . . . .                                          | 17 |
| 3.1  | Versuchsaufbau ZynqMP Ultralcale + mcp251xfd . . . . .                       | 20 |
| 3.2  | Hard-(ARM Cortex-A9/Cortex-A53) und Soft-Prozessoren (Micro-Blaze) . . . . . | 22 |
| 3.3  | Zynq UltraScale+ MPSoC EV Block Diagram . . . . .                            | 23 |
| 3.4  | Zynq UltraScale+ MPSoC Top-Level Blockdiagramm . . . . .                     | 24 |
| 3.5  | Detailliertes APU-Blockdiagramm . . . . .                                    | 26 |

## **Verzeichnis der Listings**

# 1 Einleitung

## 1.1 Motivation

Aufgrund der Einsätze von immer mehr Geräten, deren Funktionen uns das Leben erreichten. Egal, ob die Waschmaschine zu Hause, der Drucker in unseren Büros, oder die Kaffeemaschine in der Kantine, werden in alle diese Geräte kleine Computer gebaut, damit sie ihre Aufgabe bequem erledigen. Aber durch die gestiegene Rechenleistung und die erweiterten Kapazitäten von Mikroprozessoren werden die Aufgaben von solche kleine Computer immer komplexer. Es besteht dann die Möglichkeit, ein vollwertiges Betriebssystem im diesen einzusetzen. Hier hat sich Linux durch die vielseitige Anwendbarkeit und das offene Ökosystem für Embedded Devices besonders bewährt. Am EDAG Engineering GmbH, wurde im Rahme des internen Projekts, ein Image Processing Unit (IPU) Hardware Plattform auf Basis des Kria KV260 FPGA(Field Programmable Gate Array) entwickelt. Auf dieser Plattform wird dann aufgrund der Komplexität des Projekts ein Linux Betriebssystem eingesetzt, mit dem die 8 wesentlichen Anwendungen des Projekts konfiguriert, kompiliert, und zum User zur Verfügung gestellt wird.

## 1.2 Ziel der Arbeit

Angesichts der weltweiten Krise auf dem Halbleitermarkt in den letzten Monaten, wurde es immer schwieriger, hochwertige Komponenten, wie die für das Projekt verwendeten Kria KV260 Board zu finden. Statt auf der einzigen Platine des Unternehmens, musste ich meine Arbeit auf einer alternativen Platine durchführen. Also meine Arbeit in den letzten Monaten bei EDAG Engineering GmbH wurde in zwei Aufgaben aufgeteilt. Das erste Ziel dieser Arbeit war es, ein in der Firma entwickelte CAN FD Controller (mcp251xfd), der über SPI mit einem Zynq UltraScale + MP-SoC ZCU106 Board verbunden ist, in Betrieb zu nehmen, damit verschiedenen Can Node vom Linux angesprochen wird.

Im Anschluss musste ich 3 von den in der Firma entwickelte Applikationen, im Linux bauen, damit das System automatisch mit den Anwendungen bootet. Dafür

müsste ich Rezepte schreiben, die sich darum kümmern werden, die Applikationen zu konfigurieren, zu kompilieren und zu installieren.

### 1.3 Überblick über den Aufbau der Arbeit

Diese Arbeit lässt sich in 4 Hauptkapitel aufteilen:

- **Die Einleitung:** In der Einleitung werden, die Motivation, das Ziel der Arbeit und ein gesamter Überblick auf dem Ablauf der Arbeit behandeln.
- **In den technischen Grundlagen** wird zuerst erklärt, wie das System (CAN Controller und die Zynq Mp Plattform) gebaut und funktionieren soll. Des Weiteren werden, der CAN Bus System und die SPI Interface erklärt. Dann wird dem Grundprinzip von Embedded Linux Systemen und deren Komponenten erläutert. Zum Schluss erfolgt, die Beschreibung der Petalinux Tools Flow, welches der Build System, der verwendet wird, um Linux Distribution für Xilinx Bausteinen zu kompilieren.
- **Im Versuch Aufbau** wird das Projekt, in dem ich gearbeitet habe dargestellt, dann folgt eine tiefe beschreibung der Hardware. Anschließen wird detailliert auf verschiedenen Schritte für das Bauen des System eingegangen.
- **Im Kapitel Fazit und Ausblick** werden aufgetretene Probleme und Herausforderungen erläutert, es wird analysiert, wie weit das Ergebnis von dem Ziel entfernt ist. Und anschließend wird ein Ausblick auf die möglichen Verbesserungen gegeben.

## 2 Technische Grundlagen

In einem ersten Schritt wird es darum gehen, die Eigenschaften eines solchen Systems zu beschreiben, das aus einem MCP251XFD CAN Controller und einem ZynqMP besteht. Das dient dazu, die Anforderungen an die Hardware und die Konfiguration des Systems verständlicher zu machen. Und dann werden die CAN Bus Systeme und die SPI Schnittstelle tiefer vorgestellt. Danach folgt eine Beschreibung von allgemeine Embedded Linux System. Im letzten Abschnitt wird das verwendete Build System präsentiert.

### 2.1 Technische Ausgangssituation



**Abbildung 2.1:** CAN System Diagram

Das Bild auf der Abbildung 2.1 stellt die Verschaltung zwischen der MCP251xFD CAN Controller und der ZynqMP Plattform dar. Aufgrund der hohen Lizenzgebühren für den internen Ultrascale CAN-Bus-Controller wird ein externer CAN-Controller mit Serial Peripheral Interface (SPI) als Ersatz verwendet, um die Gesamtkosten des Systems zu reduzieren. Das SPI Interface wird also verwendet, um

sowohl der CAN-Controller zu konfigurieren, als auch die CAN-Bus-Daten bis zum FPGA zu übertragen. Auf dem Xilinx FPGA Board werden außer viele andere Peripheriegeräte auch ein SPI-Controller implementiert, mit dem Zweck, die Daten, die vom externen Peripheriegeräte kommen, zu kontrollieren. Zwischen dem MCP251XFD und dem physikalischen Zweidraht-CAN-Bus ist ein CAN-FD Transceiver (ATA6563 von Microchip) zu sehen, der als Schnittstelle zwischen beiden dient. Der bietet unterschiedlicher Empfangs- und Sendefähigkeiten mit einer Hochgeschwindigkeiten von bis 5Mbit/s. In den folgenden Abschnitt gebe ich die Vorteile, ein CAN-Bus zu verwenden.

## 2.2 Can Bus Systeme

Ein typischer Bereich, in dem die Nutzung von CAN-Bussen unumgänglich ist, wäre die Automobilindustrie. Moderne Auto verfügen Heutzutage über eine Vielzahl an elektronischen Systemen, die miteinander kommunizieren müssen. Und die übliche Verkabelungen wäre mit dem Vielzahl an Steuergeräten kaum mehr möglich. Der CAN-Bus ist in der CAN-Spezifikation von [Bosch \(1991\)](#) als ein Multicast-Kommunikationsprotokoll definiert, das folgende Vorteile aufweist

- CAN ist ein Multi-Master-Broadcast-System. Das heißtt, dass jeder Knoten auf dem Bus mit jedem anderen Knoten kommunizieren kann.
- Der CAN-Bus hat eine Datenübertragungsgeschwindigkeit von bis zu 1 Mbit/s.
- Jeder neue Knoten kann in den Bus eingefügt werden, ohne die ursprüngliche Hardware zu verändern.
- Es bietet eine Fehlerprüfung zur Vermeidung von Busfehlern.
- Das differentielle CAN-Signal bietet eine hohe Rauschunterdrückung.

Da dieses Protokoll sehr viele Vorteile mitbringt, wurde es in den letzten Jahren in der Industrie sehr viel verbreitet. In viele Mikrocontroller werde auf diesem Grund bei der Herstellung ein CAN-Bus eingebaut.

### 2.2.1 Can Message Frame

In der Sprache des CAN-Standards werden alle Nachrichten als Frames bezeichnet; es gibt Daten-Frames, Remote-Frames, Error-Frames und Overload-Frames. Die an den CAN-Bus gesendeten Informationen müssen definierten Frame-Formaten von

unterschiedlicher, aber begrenzter Länge entsprechen. CAN verfügt über vier verschiedene Arten von Message Frames:

- **Data Frame (Sendet Daten):** Die Daten werden von einem Sendeknoten zu einem oder mehreren Empfangsknoten übertragen.
- **Remote Frame (Fordert Daten an):** Jeder Knoten kann Daten von einem Quellknoten anfordern. Auf einen Remote-Frame folgt somit ein Daten-Frame, der die angeforderten Daten enthält
- **Error Frame (Meldet einen Fehlerzustand):** Jeder Busteilnehmer, egal ob Sender oder Empfänger, kann zu jeder Zeit während einer Daten- oder Remote-Frame-Übertragung einen Fehlerzustand melden.
- **Overload-Frame (Meldet Knotenüberlastung):** Ein Knoten kann zwischen zwei Daten- oder Remote-Frames eine Verzögerung anfordern, das heißt, dass der Overload-Frame nur zwischen Daten- oder Remote-Frame-Übertragungen auftreten kann.

Im Nachfolgenden gehen wir auf der Architektur von den jeweiligen CAN Frame Typen ein.

### 2.2.1.1 Data Frame



Abbildung 2.2: CAN-Data Frame Architektur Bosch (1991)[p. 12]

Die Abbildung 2.2 beschreibt die 7 Bestandteile, aus denen ein Data Frame besteht, nämlich:

- **SOF(Start of Frame):** Zeigt den Beginn von Daten und Remote Frames an.
- **Arbitration Field:** der besteht auf
  - Identifikator: Die Basis-ID besteht aus 11 Bits und die erweiterte ID aus 29 Bits.
  - RTR(Remote Transmission Request)-Bit: Im Data Frame ist das RTR-Bit "0". Im RTR-Frame hingegen ist es "1".
- **Control Field:** Dient zur Bestimmung der Datengröße und der Länge der Nachrichten-ID. der besteht auf 6 Bits.
  - IDE ( Identifikator-Erweiterung): Dieses Bit bestimmt den Identifikator als Basis-ID oder Erweiterte ID.
  - R0,R1: reservierte Bits.
  - DLD (Data Length Code): Er wird zur Bestimmung der Datenlänge verwendet.
- **Data Field:** bis zu 8 Byte Datenfeld.
- **CRC-Field (Cyclic Redundancy Check):** zur Überprüfung der Datenkorrektur.
- **ACK Field (Acknowledgement Field):** um zu bestimmen, ob die Nachricht empfangen wurde oder nicht. Bei Empfang von Daten wird dieses Bit auf High gezogen.
- **EOF (End of Frame):** Zeigt das Ende von Daten- und Remote-Frames an.

### 2.2.1.2 Remote Frame

Die Abbildung 2.3 beschreibt die Bestandteile eines Remote-Frame. Data-Frame und Remote-Frame sind sich sehr ähnlich. Im Prinzip ist der Remote Frame ein Data Frame ohne das Datenfeld. Dieser besteht in der Regel aus den gleichen Bestandteilen wie der Data Frame.



Abbildung 2.3: CAN-Remote Frame Architektur Bosch (1991)[p. 17]

#### 2.2.1.3 Error Frame

Abbildung 2.4 zeigt die Struktur der Error Frame an. Der Error Frame besteht aus zwei Teilen:

- Error Flag: stellt einen Fehlerzustand fest, erzeugt er bis zu 12 Bits "0" für das Fehlerflag.
- Error Delimiter: 8 Bits "1" beenden den Error Frame.



Abbildung 2.4: Can-Error-Frame Bosch (1991)[p. 18]

### 2.2.1.4 Overload Frame

Abbildung 2.5 ist der Überlastrahmen. Er wird von dem Empfängerknoten erzeugt, um mehr Verzögerung zwischen den Datenrahmen zu erzwingen.



Abbildung 2.5: Can-Overload-Frame Bosch (1991)[p. 19]

### 2.2.2 Can Physical Layer

Der CAN FD Protokoll, der während dieser Arbeit verwendet wird, ist in ISO 1189-1:2015 definiert. Dieses Protokoll beschreibt nicht die mechanischen, Drähte, und Anschlüsse, aber fordert allerdings, dass die Drähte und Anschlüsse den elektrischen Spezifikationen entsprechen müssen. Abbildung 2.6 zeigt eine CAN-Verbindung mit



Abbildung 2.6: Can-Bus Connexion Richards (2002)[p. 2]

zwei CAN-Node gemäß der ISO-11898-1 CAN-Spezifikation. CAN High(CAN\_H) und CAN Low(CAN\_L) verlangen zwei  $120\Omega$ -Abschlusswiderstände. Der Transceiver wandelt die von CAN-Knoten kommenden CAN-Signale in ein digitales Rx- und Tx-Signal für den Node Controller um. Des Weiteren handelt es sich bei CAN\_H und CAN\_L um Differenzsignale. wie auf der Abbildung 2.7 zu sehen ist, wenn die zwei Signale bei 2,5 V liegen, ist dies ein rezessives Signal, also eine logische 0. Wenn CAN\_H auf 3,5 V und CAN\_L auf 1,5 V, dann handelt es sich um ein dominantes Signal, also eine logische 1.



Abbildung 2.7: CAN\_H und CAN\_L Richards (2002)[p. 3]

## 2.3 SPI Interface

Die *Serial Peripheral Interface* (SPI) ist eine der am häufigsten verwendeten Schnittstellen zwischen Mikrocontrollern und Peripherie-ICs wie Sensoren, ADCs, DACs, Schieberegistern, SRAM und anderen. Die Schnittstelle SPI ist eine synchrone, auf Voll-Duplex basierte Master-Slave-Schnittstelle. Die Daten vom Master oder Slave werden mit der aufsteigenden oder abfallenden Taktflanke synchronisiert. Dabei können sowohl Master als auch Slave gleichzeitig Daten übertragen.

Das SPI arbeitet aber nach dem Single-Master-Prinzip. Das bedeutet, dass ein zentrales Gerät die gesamte Kommunikation mit den Slaves initiiert. Der Master sendet Daten auf der MOSI-Signalleitung und empfängt Daten auf der MISO-Signalleitung,

so dass der Busmaster gleichzeitig Daten senden und empfangen kann. wie auf dem Bild A der Abbildung 2.8 zu sehen ist. Alle Datenübertragungen müssen zwischen dem Bus-Master und den Slaves stattfinden. Datenübertragungen die direkt zwischen zwei Slave-Geräten stattfinden sind nicht erlaubt.



Abbildung 2.8: SPI Bus [Leens \(2009\)](#)[p. 9]

Möchte der SPI-Master Daten an einen Slave senden und/oder von ihm Informationen anfordern, dann wählt er einen Slave aus, und zwar durch Ziehen der entsprechenden SS-Leitung nach unten, während er das Taktsignal mit einer für den Master und den Slave nutzbaren Taktfrequenz aktiviert. SPI ist eine Protokoll mit vier Signalleitungen, wie auf [Leens \(2009\)](#)[p. 9] zu lesen ist.

- **Ein Clock-Signal (SCLK)**, welches vom Bus-Master an alle Slaves gesendet wird; alle SPI-Signale sind mit diesem Clock-Signal synchronisiert.
- **Der Slave Select Signal**: der zur Auswahl des Slaves dient, mit dem der Master kommuniziert.

- **Eine Datenleitung vom Master zu den Slaves**, bezeichnet als Master Out-Slave In (MOSI).
- **Eine Datenleitung von den Slaves zum Master**, bezeichnet als Master In-Slave Out (MISO).

Im kommenden Abschnitt möchte ich das Thema Embedded Systems ansprechen und die Vorteile solcher Systeme erläutern.

## 2.4 Embedded Linux

Bevor ich auf *Embedded Linux* eingehe, was eigentlich der englische Begriff von *eingebettetes System* ist, möchte ich zunächst klarstellen, dass es keine spezielle Version des Linux-Kernels für Embedded-Systeme gibt. Das Wort *Linux* in embedded Linux bezeichnet hier den Mainline-Linux-Kernel, der auf einem embedded System läuft. Aus Sprachmissbrauchsgründen wird es anstelle von "Linux auf einem eingebetteten System" verwendet.

Im Bereich der eingebetteten Softwareentwicklung wird entschieden, ob man auf Basis von Baremetal oder auf Basis eines Betriebssystems programmiert. Ein Betriebssystem bringt gegenüber der direkten Systemprogrammierung Vorteile mit sich, die es zu berücksichtigen gilt. Bare Metal heißt, dass ein Programm oder eine Software ohne Unterstützung eines Betriebssystems direkt auf der Hardwareebene ausgeführt wird. Anders ausgedrückt, programmiert man einen Mikrocontroller direkt mit ein paar Zeilen C- oder Assembler-Code. Bei embedded Linux im Gegenteil werden Anwendungen über dem Kernel ausgeführt oder von diesem unterstützt und arbeiten so als Betriebssystem (OS). Jede Kommunikation zwischen Hardware und Software läuft also über den Kernel, was tatsächlich viele Vorteile mit sich bringt.

- Treiber-Unterstützung für viele Geräte
- Prozess- und Speicherverwaltung
- Bestehende Anwendungen und Netzwerkprotokolle
- Skalierbarkeit und Echtzeitfähigkeit
- Große Entwickler-Community

Man spart nicht nur Zeit, sondern trägt auch zur Wartbarkeit der Software bei, wenn man vorhandene Software verwendet. Wenn man solche Komponenten von Null an entwickelt, dann hat man eine Quelle für eventuelle Fehler, die bei betriebssystembasierter Software wegen der hohen Verbreitung und Unterstützung durch die

Gemeinschaft und die Entwickler in der Regel minimiert werden. Außerdem haben Betriebssysteme den Vorteil, dass die Software leichter auf Nachfolgeplattformen und mithilfe von Standards wie POSIX auf andere Betriebssysteme übertragen werden kann.

Im Rahmen dieser Arbeit wird ein Linux-Kernel auf Basis der Kernel Version 5.10 verwendet [[Linux-kernel](#)], der um einige Zynq-spezifische Features in Form von Treibern erweitert wurde. Eine Liste der von Xilinx zur Verfügung gestellten Treiber ist im Official Xilinx Wiki zu finden. Eine Liste der von Xilinx bereitgestellten Treiber kann man

## 2.5 Komponente eines Embedded Linux Systems

In diesem Abschnitt möchte ich auf die wesentlichen Komponenten von eingebetteten Linux-Systemen im Detail eingehen. Im Anschluss daran wird der typische Boot-Prozess solcher Systeme beschrieben. Fast Jedes embedded Linux Projekt beginnt mit der Erstellung, Konfiguration und Kompilierung der folgenden vier Komponenten [Derviš \(2013\)](#):

- **Toolchain:** Die Toolchain enthält den Compiler und andere zur Erstellung von Code für Ihr Endgerät notwendige Werkzeuge
- **der Bootloader:** Beim Einschalten des Rechners, auf denen Linux als Betriebssystem installiert ist, wird nach der ersten Einrichtung ein Bootloader in den Speicher geladen und der Code ausgeführt. Die Hauptaufgabe des Bootloaders ist es, der Linux Kernel in den Speicher zu laden und dann es auszuführen.
- **Der Kernel:** ist das Herzstück des Systems, das die Systemressourcen und Schnittstelle zur Hardware verwaltet.
- **Root filesystem:** beinhaltet die Bibliotheken und Programme, die ausgeführt werden, sobald der Kernel seine Initialisierung abgeschlossen hat.

Als Nächstes möchte ich den Boot-Prozess bei Systemen, die auf Zynq UltraScale+ MPSoCs basieren, erläutern, da dies genau die Plattform ist, die wir für unsere Arbeit verwenden werden. Die Abbildung [2.9](#) zeigt ein Beispiel für den Bootablauf an.

Der Bootvorgang bei Xilinx Bausteine besteht, ebenso wie bei allen Linux-Systemen, aus drei Phasen [UG1137 \(2017\)](#)[p. 57], die von der Platform Management Unit (PMU) und die Configuration Security Unit (CSU) gesteuert und geführt wird. Das Booten des Geräts kann entweder im sicheren (*secure boot*) oder im nicht sicheren (*non-secure boot*) Modus durchgeführt werden



Abbildung 2.9: Überblick über den Bootvorgang UG1137 (2017)[p. 58]

- **Pre-configuration stage (Oder Vor-Konfigurationsphase):** Dieser Phase wird von der PMU angesteuert, die den PMU-ROM-Code zur Einrichtung des Systems ausführt. Die PMU wickelt alle Prozesse im Verbindung mit dem Zurücksetzen und Aufwachen ab.
- **Configuration stage oder (Konfiguration der Phase):** Diese Phase übernimmt das Laden des First-Stage-Bootloader-Codes (FSBL) für den PS in das On-Chip-RAM (OCM), und zwar sowohl im sicheren als auch im unsicheren Boot-Modus. Während des Bootvorgangs lädt die CSU auch die PMU-Benutzerfirmware (PMU FW) in das PMU-RAM, um in Verbindung mit dem PMU-ROM Plattform-Management-Dienste bereitzustellen.
- **Post-configuration stage oder (Post-Konfigurationsphase):** Nach dem Start der FSBL-Ausführung geht der CSU-ROM-Code in die Nachkonfigurationsphase über, die für die Reaktion auf Systemmanipulationen verantwortlich ist

auf dieser Ebene ist das Betriebssystem noch nicht vollständig betriebsbereit. sobald der FSBL an den TF-Agent übergeben wird, dann wird er Auf der Application processing units(APU) ausgeführt. TF-Agent wird an einen Second Stage Boot Loader wie U-Boot übergeben, der ein Betriebssystem wie Linux ausführt und lädt, und Linux lädt seinerseits die ausführbare Software.

Alle bisher genannten Linux-Komponenten, ob die Toolchains, der Bootloader, der Kernel oder das Root-Dateisystem können mit einem Build-System wie dem Yocto-Projekt erstellt werden. Da unser FPGA aber einen MPsoc enthält, der einen Bootloader, ATF-Firmware, pmufw, den Bitstream und u-boot benötigt, ist ein Build System zu verwenden, das automatisch alle diese Komponenten erzeugen kann..

Hierfür ist Petalinux am besten geeignet. Im nächsten Abschnitt werde ich das Petalinux Build System vorstellen.

## 2.6 Petalinux Tool Flow

PetaLinux ist ein Embedded Linux Software Development Kit (SDK), das auf FPGA-basierte System-on-a-Chip (SoC)-Designs abzielt. Petalinux (2020). Es erstellt das Root-Dateisystem unter Verwendung von Yocto, es setzt praktisch auf Yocto auf. Unter PetaLinux versteht man eine Reihe von High-Level-Befehlen, die auf der Yocto-Linux-Distribution aufbauen. Die PetaLinux-Werkzeuge können zur Anpassung, Erstellung und Bereitstellung von Embedded Linux-Lösungen/Linux-Images für Xilinx-Prozessorsysteme verwendet werden. So arbeitet PetaLinux mit den Hardware-Design-Tools von Xilinx (z.B. Vivado) zusammen, um die Entwicklung von Linux-Systemen für unseren Zynq UltraScale+MPSoC zu erleichtern.

Ein wesentlicher Vorteil von petalinux ist, dass es eine Reihe von vereinfachten Befehlen enthält, die für das Booten und die Integration von HW- und SW-Projekten sehr nützlich sind. In Abbildung 2.10 sehen Sie einen Überblick über den PetaLinux-Werkzeugfluss auf oberster Ebene.



**Abbildung 2.10:** Überblick über den PetaLinux-Werkzeugfluss [Support (2022)]

Wie man in der Abbildung 2.10 sehen kann, ist es möglich, mit Vivado erstellte Hardware-Designs in petalinux zu importieren, einige Anwendungen in petalinux einzubinden und ein Linux-Image zu erstellen.

### 2.6.1 Petalinux Installation

Wie jedes Build-System benötigt petalinux viele Ressourcen auf Ihrem PC. Um die Kompilierzeit deutlich zu reduzieren, ist es daher sinnvoll, einen Computer mit folgenden Eigenschaften zu verwenden.[Petalinux \(2020\)](#)

- 8 GB RAM
- 2 GHz CPU-Takt oder gleichwertig
- 100 GB freier HDD-Platz
- Petalinux unterstützt nur auf Linux Kernel basierte Betriebssysteme.
- PetaLinux-Tools erfordern, dass Ihr Host-System /bin/sh **bash** ist. Der folgende Befehl kann verwendet werden, um die Bash als Terminal einzurichten, wobei der Befehl als root ausgeführt werden muss.

---

```
1 $ sudo dpkg-reconfigure dash
```

---

Einmal die vorherigen Voraussetzungen erfüllt, kann man also die Installationsdatei von Petalinux unter diesem Link [Petalinux Installer Download](#) herunterladen. mit dem **mkdir** Kommando in Linux kann man ein Petalinux Installation Ornder erstellen, in dem die Installationsdatei dann kopiert wird. mit dem -p Schalter kann den Ordner in einem spezifischen Ordner erstellen.

---

```
1 $ mkdir -p /home/<user>/petalinux/<petalinux-version>
```

---

Mit den folgenden Befehlen kann man die Datei ausführbar machen und der Installationsprozess starten.

---

```
1 $ chmod 755 ./petalinux-v<petalinux-version>-final-installer.run
2 $ ./petalinux-v<petalinux-version>-final-installer.run
```

---

### 2.6.2 Wichtige Petalinux Kommando

- **petalinux-create**: Erstellt ein neue Petalinux Projekt. man kann dem Befehl verschiedenen Optionen zuweisen,
  - **type**: definiert den Projekt Type
  - **template**: Bei der Erstellung des Projekts kann man eine Vorlage definieren. Für das Projekt wurde zynqMP verwendet.

- ***srcuri***: Hier wird der Pfad zu einem Board Support Package (BSP) angegeben, das zur Erstellung des Projekts verwendet wird.
- ***name***: definiert den Name des Projekts.
- **petalinux-config**: dieser Befehl wird verwendet zur Initialisierung oder Aktualisierung der Hardwarekonfiguration des Projekts oder Konfiguration der Kernel- und/oder Dateisystemeinstellungen. Je nach Anwendung stehen hier auch uns eine Reihe von Konfiguration-Optionen zur Verfügung. Einige davon sind:
  - ***get-hw-description***: Initialisiert den Petalinux-Projekt mit einem vom Vivado Hardware-description-file(HDF). PetaLinux verwendet HSI-Dienstprogramme, um Informationen über die Hardware aus dieser Datei zu extrahieren, sowie Informationen wie Intellectual property Cores (IP-Cores), Netze, Ports und Schnittstellen, die in anderen Tools wie dem Devicetree-Generator verwendet werden .
  - ***-c rootfs***: Startet das Konfigurations-Menü des Root-Dateisystems.
  - ***-c kernel***: Startet das Konfigurations-Menü des Kernel.
- **petalinux-build**: Das Tool Erstellt bestimmter Komponenten oder eines ganzen Linux-Systems für das PetaLinux-Projekt (einschließlich FSBL, uboot, Gerätebaum usw.). Genau so wie mit ***petalinux-config*** Befehl, können auch Besonderheiten mit den Zeichen ***-c*** und ***-x*** festgelegt werden.
  - ***-c oder -component***: Baut die angegebene Komponente(kernel, u-boot, rootfs, device-tree ...). Es handelt sich hierbei um die Standard Komponente, die unterstützt werden. Es können aber auch eigenes Objekt erstellen werden (z. B. eigene Anwendung oder Modul).
  - ***-x oder execute*** : Führt den angegebenen Build-Schritt aus. Es können alle Yocto-Tasks über diese Option übergeben werden(build, clean, cleansstate, distclean ...).
- **petalinux-boot**: Das Werkzeug Bootet ein angegebenes Linux-Image entweder über JTAG auf die Hardware oder den QEMU-Softwareemulator.
  - ***-jtag***: Die jtag-Tools sind sehr hilfreich, wenn man genau sehen möchte, wie der Boot-Vorgang im Einzelnen abläuft.

- **petalinux-package:** Das Werkzeug packt ein gebauter PetaLinux-Projekt in einem für die Bereitstellung geeigneten Format. je nach Zielpaketformat bietet es mehrere Arbeitsabläufe, deren Operationen abweichen. Für das Projekt verwenden wir ***petalinux-package -boot***, der hat die folgenden Optionen:
  - **-format:** Das zu erzeugendes Bilddateiformat(BIN, MCS, DOWNLOAD.BIT)
  - **-fsbl:** Damit definiert man den Pfad zum First Stage Bootloader(FSBL) .elf-Binäre Datei.
  - **-fpga BITSTREAM:** Den Pfad zur Bitstream-Datei.
  - **-force:** Existierende Dateien auf der Festplatte überschreiben.
- **petalinux-devtool:** Das petalinux-devtool ist das letzte auf der Liste der petalinux-Tools, die ich beschreiben wollte und die ich für meine Arbeit benötigen werde. Das ist ein Dienstprogramm, das mit Hilfe des Yocto-Devtools Software erstellt, getestet und verpackt werden können. In den kommenden Abschnitten werde ich auf jeweilige Optionen, die ich verwendet habe eingehen.

### 2.6.3 Petalinux Projekt Strukture

In diesem Abschnitt möchte ich über die Petalinux-Projektstruktur sprechen. Es ist wichtig, dies zu erwähnen, damit klar ist, wie und wo Komponenten, Module oder Software geändert werden können.

```
project-spec
    hw-description
    configs
    meta-user
pre-built
    linux
        implementation
        images
        xen
hardware
    <project-name>
components
    plnx_workspace
    device-tree
config.project
README
```

Abbildung 2.11: typische petalinux projektstruktur [Support (2022)]

In Abbildung 2.11 ist eine typische Petalinux Projektstruktur dargestellt.

- **project-spec:** In diesem Verzeichnis werden alle Änderungen an dem Projekt durchgeführt. Hier können z. B. neue Projekt Layers erstellen, den Gerätebaum(Device-tree) geändert oder sogar Rezepte für Software, die vom Kernel kompiliert werden soll, erstellt werden.
- **pre-built:** Dieses Verzeichnis beinhaltet alle Board-spezifischen Design- und Konfigurationsdateien, vorgefertigte und getestete Hardware und Software-Images, die Sie auf dem Board direkt heruntergeladen werden können. Der Ordner ist jedoch nur sichtbar, wenn man das Projekt auf der Basis des für das Board spezifischen Board Support Package (BSP) erstellt hat.
- **hardware:**

## 3 Umsetzung

In diesem Kapitel möchte ich mich am allerersten noch mal über das Ziel dieser Arbeit äußern, dabei geben ich eine tiefe Eindruck auf meine tatsächliche Arbeit. Dann möchte ich die verwendete Hardware, folgen mit einer grobe Beschreibung, wie sie Verschalten sind, beschreiben. Anschließend möchte ich auf die Schritte zum Bauen und Konfigurieren des Gesamt Betriebssystem eingehen.

### 3.1 Allgemein über das Projekt

Ähnlich wie ein Desktop-PC, der ein Betriebssystem wie Windows oder Linux benötigt, um seine gesamte Software auszuführen oder die angeschlossene Hardware zu steuern, benötigt embedded Geräte auch ein Betriebssystem, um ihre Anwendungen einfacher zu verwalten. Das Betriebssystem, das auf unserem Gerät laufen wird, soll also die folgenden 8 Softwaremodule im Hintergrund ausführen, die dann sämtliche Funktionen der IPU-NG Projekt beschreiben. Wie im Kapitel 1.2 beschrieben, sollen im Rahmen dieser Arbeit 3 der 8 unten beschriebenen Softwaremodule in das Betriebssystem eingebaut werden.

- **System Watchdog:** der zuständig ist das System zu überwachen.
- **Power Manager:** der bedient die Stromversorgung der einzelnen Teile des Systems.
- **System Updater:** der aktualisiert das gesamte System, in falls, dass es Neuerung gibt.
- **License Manager:**
- **Web Backend:** der dient als Brücke zwischen der Web Anwendung und dem Rest des Systems
- **Web Anwendung / WEB Frontend:** Die Webanwendung ermöglicht es dem Benutzer, den Status des Geräts abzurufen, es zu aktualisieren, die Debug-Protokolldateien herunterzuladen

- **System Logger:** die von Linux erzeugten Log Files verfolgen, parsen und entsprechend der Liste von oben die notwendigen Informationen von den entsprechenden Log Files extrahieren und in den von der System Logger Anwendung verwalteten zirkularen Buffer schreiben.
- **Hauptanwendung:** die stellt die Kern-Funktionalität des IPU NG Gerätes zur Verfügung

Weiterhin sollte im Rahmen dieser Arbeit das Betriebssystem so konfiguriert werden, dass der MCP251xFD CAN-Controller über SPI sowohl konfiguriert werden als auch Daten an den Mainline-Linux-Kernel senden kann.



**Abbildung 3.1:** Versuchsaufbau ZynqMP Ultralcale + mcp251xfd

Die Abbildung 3.1 zeigt die Verschaltung zwischen der Ersatz Board und der MCP251xfd CAN Controller und der Ersatzt Board Zynq Ultrascale. Im folgenden Abschnitt würde ich eine ausführliche Beschreibung der verwendeten Hardware vorstellen.

## 3.2 Hardware Platform

Aus Kostengründen wurde anstelle des FPGA-internen CAN-Controllers ein externer CAN-Controller verwendet. Und viel besser: Dieser CAN-Controller wurde im Unternehmen entwickelt. Außerdem wurde das von Xilinx entwickelte Board ZCU106 verwendet, das auf dem Zynq UltraScale + MPSoC basiert. Das enthaltene ZU7EV-Gerät(Zynq UltraScale + MPSoC) integriert ein Quad-Core Arm Cortex-A53 Processing System (PS) und einen Dual-Core Arm Cortex-R5F Echtzeit-Prozessor. Das board verfügt auch über viele programmierbare digitale Komponenten, mit denen wiederum eine Vielzahl von Schaltungen realisiert werden können. Wie bereits erwähnt, ist das FPGA Bestandteil des ZCU106 Boards, das im nächsten Kapitel besprochen wird.

### 3.2.1 ZynqMP UltraScale + MPSoC ZCU106 Evaluation Board

Dieses Kapitel beschreibt die ZynqMP + MPSoC-Plattform, insbesondere die Bereiche, die diese Plattform einzigartig machen. Dazu gehören die Zynq UltraScale + MPSoC Architektur, das Processing System (PS) und die Programmable Logik (PL). Die Peripheriegeräte, die für die Interaktion mit dem CAN-Controller erforderlich sind, werden dabei erwähnt. Genauere Informationen dazu findet man im technischen Referenzhandbuch [Xilinx Inc. (2019)] des Zynq-Platforms.

#### 3.2.1.1 Ultrasale + MPSoC Architektur

Lassen wir uns, bevor wir uns mit der Zynq UltraScale+ MPSoC-Architektur beschäftigen, ein wenig über die Zynq-Architektur im Allgemeinen sprechen. Es handelt sich bei Zynq um eine neue Generation von System-on-Chip (SoC), die eine CPU mit einem programmierbaren Logik-FPGA auf demselben Chip kombiniert. FPGAs sind für ihre besondere Flexibilität beim Entwurf digitaler Schaltungen bekannt. Dennoch ist für viele Anwendungen der Entwurf einer riesigen Zustandsmaschine in Very High Speed Hardware Description Language (VHDL) oder Verilog nicht ausreichend. Stattdessen ziehen wir eine softwareprogrammierbare CPU-Architektur vor, die mit einfacheren FPGA-Blöcken zusammenarbeitet. Im Grunde genommen kann eine CPU jeden Algorithmus ausführen, so lange genug Speicher für ihre Bedürfnisse vorhanden ist. Softwarecode kann schnell geändert, neu kompiliert, gepatcht und debuggt werden. Die Rechenkapazität eines CPU-Kerns allein reicht jedoch oft nicht aus, um eine große Datenmenge zu verarbeiten. weshalb tendieren wir zu parallelen Architekturen, wie Multicore-CPUs, FPGAs und GPUs, um den Rechendurchsatz

zu erhöhen.

Bislang gab es für jemanden, der eine CPU in Kombination mit einem FPGA benötigte, zwei Möglichkeiten: eine diskrete CPU und ein diskretes FPGA, die über einen Bus miteinander kommunizieren (was zu Bandbreitenbeschränkungen führte), oder eine Soft-Core-CPU. Diese wird direkt in den FPGA programmiert (z.B. 32-Bit Microblaze, 64-Bit Ultrascale, usw.). Die Entscheidung hängt von den Einschränkungen und Anforderungen der Anwendung ab, wie z. B. dem Systempreis, dem Stromverbrauch, der Komplexität und selbstverständlich der Leistung. Xilinx bietet mit der Zynq-Serie ein höheres Maß an Integration mit einer System-on-Chip-Hardcore-ARM-CPU, einem Xilinx-FPGA und Bussen für den effizienten Datentransfer zwischen beiden. Darüber hinaus umfassen die Zynq-Bausteine verschiedene Arten von Input/Output (I/O)-Controllern, Speicherschnittstellen und Hochgeschwindigkeits-Transceivern



**Abbildung 3.2:** Die Anordnung von Hard- (ARM Cortex-A9/Cortex-A53) und Soft-Prozessoren (MicroBlaze) auf einem Zynq/ZynqMP-Baustein [Crockett, Louise H and Elliot, Ross A and Enderwitz, Martin A and Stewart (2014)]

Die Abbildung 3.2 zeigt die Trennung zwischen dem festen Logik-Hardware-Prozessor und der programmierbaren Logik, die einen oder mehrere Soft-Prozessoren enthalten kann.

### 3.2.1.2 Allgemeine Ansicht des Zynq Ultrascale+ MPSoC

Die Zynq Ultrascale+ MPSoC-Serie ist eine im Jahr 2015 von Xilinx eingeführte moderne SoC-Architektur [CNX Software]. Abbildung 3.3 zeigt das Blockdiagramm des Zynq Ultrascale+ EG.



Abbildung 3.3: Zynq UltraScale+ MPSoC EV Block Diagram [Xilinx Inc.]

Im Folgenden findet sich eine Liste der besonderen Komponenten dieser Familie:

- **APU**
  - 64-bit Quad-core ARM Cortex-A53 1.5 GHz
  - NEON Media Processing Engine + Floating Point Unit (FPU)
- **RPU**
  - 32-bit Dual-core ARM Cortex-R5 600 MHz
- **graphics processing uni(GPU)**
  - ARM Mali-400 MP2
- **On-Chip Memory (OCM):** 256KB
- **Zwei 8-Channel Direct Memory Access (DMA) controllers**
- **System Memory Management Unit (SMMU)**

- Platform Management Unit (PMU)

Der PS unterstützt auch viele Eingangs-/Ausgangsschnittstellen wie SRAM-Schnittstellen (SD, QSPI, NAND), GPIOs, UART usw.



Abbildung 3.4: Zynq UltraScale+ MPSoC Top-Level Blockdiagramm [Xilinx Inc. (2019)]

Im Top-Level-Blockdiagramm der Zynq MPSoC-Architektur 3.4 ist die Verbindung zwischen den verschiedenen Blöcken markiert. Da kann die verschiedenen Verarbeitungseinheiten (APU, RPU, GPU) sowie viele Verbindungen zwischen den Blöcken finden. Zu beachten ist, dass die Richtung der Pfeile die Prioritätsreihenfolge zwi-

schen Master und Slave festlegt. Sie haben vielleicht bemerkt, dass in Abbildung 3.3 erwähnt wird, dass es sich um das Blockdiagramm für die EV-Variante handelt. Tatsächlich gibt es drei Varianten des Zynq MPSoC, die wie folgt gekennzeichnet sind:

- **CG:** Mittelklasse-Gerät, mit Dual Cortex-A53 und Dual Cortex-R5.
- **EG:** High-End-Gerät, mit Quad-Cortex-A53, Dual-Core-Cortex-R5 und Mali GPU
- **EV:** High-End-Gerät, mit Quad Cortex-A53, Dual-Core Cortex-R5, Mali GPU und Video-Codec (H.264, H.265).

Die beiden Hauptkomponenten des ZynqMP, das Verarbeitungssystem und die programmierbare Logik, werden im Folgenden ausführlicher beschrieben.

### 3.2.1.3 Processing System (PS)

Das ZynqMP-Verarbeitungssystem umfasst einerseits den ARM-Prozessor, anderseits aber auch mehrere zugehörige Verarbeitungsmodule, die eine Application Processing Unit (APU) bilden, sowie weitere Schnittstellen für Peripheriegeräte, Cache-Speicher, Speicherschnittstellen, Verbindungs- und Takterzeugungsschaltungen. Die APU besteht aus einem speziellen ARM Cortex-A53 MPCore (Quad oder Dual). In der ARM-Gerätefamilie gelten diese als relativ stromsparend, sind aber in der Lage, ein vollwertiges Betriebssystem wie Linux, Android oder ähnliches auszuführen

Abbildung 3.5 fasst einige wichtige Merkmale der APU zusammen. So verfügt sie beispielsweise über einen separaten 32-KB-Cache der Ebene 1 für Befehle und Daten und einen gemeinsamen 1-MB-Cache der Ebene 2. Eine Snoop Control Unit (SCU) sorgt für Cache-Kohärenz zwischen den Kernen und zeigt an, wenn die Daten ungültig sind.

Der L2-Cache-Controller APU kommuniziert mit dem Rest des SoC über eine 128-Bit AXI Coherency Extension (ACE) Master-Schnittstelle zur Cache Coherent Interconnect

Andererseits kann ein 128-Bit-Accelerator Coherency Port (ACP) Slave-Controller verwendet werden, wenn ein anderer Block mit Master-Zugriff auf Daten im L2-Cache zugreifen möchte. In der Praxis bedeutet dies, dass der PL auf den L2-Cache über den Port S\_AXI\_ACP\_FPD ZUGREIFEN KANN.



Abbildung 3.5: Detailliertes APU-Blockdiagramm [UG1137 (2017)[p. 57]]

### 3.2.1.4 Programmable Logik (PL)

Dieser Abschnitt bietet einen Überblick über die verfügbaren Funktionen der Zynq Ultrascale+ MPSoC Programmable Logic (PL). Tabelle 3.1 ist ein Vergleich einiger EG-Bausteine. Es gibt tatsächlich mehr Varianten als die dort aufgeführten. Die FPGA-Fabric besteht hauptsächlich aus Logikzellen und konfigurierbaren Logikblöcken (CLB). Ein CLB kann Flipflops und eine Look-up-Table (LUT) enthalten, muss es aber nicht.

| Gerät Name                      | ZU4EV | ZU5EV | ZU7EV |
|---------------------------------|-------|-------|-------|
| <b>System Logic Cells (K)</b>   | 192   | 256   | 504   |
| <b>Speicher (Mb)</b>            | 18.5  | 23.1  | 38.0  |
| <b>DSP-Schnitte</b>             | 728   | 1,248 | 1,728 |
| <b>Video-Code-Einheit (VCU)</b> | 1     | 1     | 1     |
| <b>Maximale E/A-Pins</b>        | 252   | 252   | 464   |

Tabelle 3.1: Vergleich einiger Zynq Ultrascale+ MPSoC EG [Xilinx Inc.]

Der Speicher eines FPGAs besteht entweder aus dedizierten Speicherblöcken wie BlockRAM und UltraRAM oder aus CLB, die als RAM-Zellen verwendet werden (Distributed RAM). Schließlich enthält das FPGA eine Reihe von DSP48E2 IP-Blöcken, die Multiplikationen und andere arithmetische/logische Aufgaben effizient durchführen können

### **3.2.2 MCP251XFD CAN Controller**

## **3.3 Konfiguration und Bauen des Systems**

## **4 Fazit und Ausblick**

### **4.1 Fazit**

### **4.2 Ausblick**

## **Literaturverzeichnis**

### **[Bosch 1991]**

BOSCH, Robert: CAN Specification Version 2.0. In: *Rober Bousch GmbH, Postfach 300240* (1991), 72. <http://esd.cs.ucr.edu/webres/can20.pdf> 2.2, 2.2, 2.3, 2.4, 2.5

### **[CNX Software ]**

CNX SOFTWARE: CNXSoft. Xilinx Introduces Zynq Ultrascale+ MPSoC with Cortex A53 and R5 Cores, Ultrascale FPGA. <https://www.cnx-software.com/2015/03/05/xilinx-introduces-zynq-ultrascale-mpsoc-with-cortex-a53-r5-cores-ultrascale-fpga/> 3.2.1.2

### **[Crockett, Louise H and Elliot, Ross A and Enderwitz, Martin A and Stewart 2014]**

CROCKETT, LOUISE H AND ELLIOT, ROSS A AND ENDERWITZ, MARTIN A AND STEWART, Robert W.: *The ZYNQ book: embedded processing with the ARM Cortex-A9 on the Xilinx Zynq-7000 all programmable SoC*. Strathclyde Academic Media, 2014 <https://cds.cern.ch/record/2001018> 3.2

### **[Derviş 2013]**

DERVIŞ, Barış: *Mastering Embedded Linux Programming*. 2013. – 1689–1699 S. – ISBN 9788578110796 2.5

### **[Leens 2009]**

LEENS, Frédéric: An introduction to I2C and SPI protocols. In: *IEEE Instrumentation and Measurement Magazine* 12 (2009), Nr. 1, S. 8–13. <http://dx.doi.org/10.1109/MIM.2009.4762946>. – DOI 10.1109/MIM.2009.4762946. – ISSN 10946969 2.8, 2.3

### **[Linux-kernel ]**

LINUX-KERNEL: *ChangeLog-5 @ mirrors.edge.kernel.org*. <https://mirrors.edge.kernel.org/pub/linux/kernel/v5.x/ChangeLog-5.10> 2.4

### **[Petalinux 2020]**

PETALINUX: PetaLinux Tools Documentation Reference Guide. In: *Ug1144* 1144 (2020), 1–144. [https://www.xilinx.com/support/documentation/sw\\_ug1144](https://www.xilinx.com/support/documentation/sw_ug1144)

[manuals/xilinx2019\\_1/ug1144-petalinux-tools-reference-guide.pdf](#)

2.6.1

**[Richards 2002]**

RICHARDS, Pat: A CAN Physical Layer Discussion. In: *Technology* (2002), S. 1–12 [2.6](#), [2.7](#)

**[Support 2022]**

SUPPORT, Xilinx: *Xilinx Support*. [https://support.xilinx.com/s/article/1066813?language=en\\_US](https://support.xilinx.com/s/article/1066813?language=en_US). Version: 2022 [2.10](#), [2.11](#)

**[UG1137 2017]**

UG1137: Zynq UltraScale. In: *User guide 1137* (2017), 1–268. [https://www.xilinx.com/support/documentation/user\\_guides/ug1137-zynq-ultrascale-mpsoc-swdev.pdf](https://www.xilinx.com/support/documentation/user_guides/ug1137-zynq-ultrascale-mpsoc-swdev.pdf) [2.5](#), [2.9](#), [3.5](#)

**[Xilinx Inc. ]**

XILINX INC.: *zynq-ultrascale-mpsoc*. <https://www.xilinx.com/products/silicon-devices/soc/zynq-ultrascale-mpsoc.html> [3.3](#), [3.1](#)

**[Xilinx Inc. 2019]**

XILINX INC.: ZCU106 Evaluation Board. In: *Xilinx Technical Documentation 1244* (2019), Nr. v1.4, S. 1–134 [3.2.1](#), [3.4](#)

## Literaturverzeichnis

---

Ich, Hugues landry Nseupi Nono, Matrikel-Nr. 2022666, versichere hiermit, dass ich die vorliegende Arbeit mit dem Thema

*Konfiguration und Optimierung des Embedded-Linux-Betriebssystem für  
Automotive Image Processing Unit - Betreuer: Mladen Kovacev*

selbstständig verfasst und keine anderen als die angegebenen Quellen und Hilfsmittel benutzt habe, wobei ich alle wörtlichen und sinngemäßen Zitate als solche gekennzeichnet habe. Die Arbeit wurde bisher keiner anderen Prüfungsbehörde vorgelegt und auch nicht veröffentlicht.

Augsburg, den 22. März 2022

---

HUGUES LANDRY NSEUPI NONO

## **A Anhang**

### **A.1 Inhalt des Datenträgers**

Der dieser Arbeit beigelegte Datenträger beinhaltet zusätzliche Materialen. Neben der Arbeit selbst im Portable Document Format (PDF) befinden sich sowohl die Sources der Implementierungen als auch die lauffähigen Pakete.

**./all-my-packages/**

Sources der Packages

**./Architektur/**

UML-Diagramme der Architektur

**./Thesis\_Vorname\_Nachname\_123456.pdf**

PDF Version dieser Arbeit

**./ThesisVM.ova**

Virtual Box Image mit lauffähiger Demoumgebung