

# Inhaltsverzeichnis

|                                                                                         |           |
|-----------------------------------------------------------------------------------------|-----------|
| <b>Abkürzungsverzeichnis</b>                                                            | <b>10</b> |
| <b>Vorwort</b>                                                                          | <b>15</b> |
| <b>1 Einleitung</b>                                                                     | <b>17</b> |
| 1.1 Motivation . . . . .                                                                | 17        |
| 1.2 Ziele der Arbeit . . . . .                                                          | 21        |
| 1.3 Aufbau der Arbeit . . . . .                                                         | 23        |
| <b>2 Grundlagen</b>                                                                     | <b>25</b> |
| 2.1 Parallelle Rechentechnik . . . . .                                                  | 25        |
| 2.1.1 Domänen der Berechnung . . . . .                                                  | 26        |
| 2.1.2 Parallelität der Software-Domäne . . . . .                                        | 28        |
| 2.1.3 Speicherorganisation in parallelen Rechnersystemen . . . . .                      | 32        |
| 2.1.4 Rechentechnik mit rekonfigurierbaren Hardwarestrukturen . . . . .                 | 33        |
| 2.1.5 Ableitung und Modellierung heterogener adaptiver Systemarchitekturen . . . . .    | 38        |
| 2.1.6 Modell eines heterogenen adaptiven Computersystems                                | 41        |
| 2.2 Entwurf von Hardware- und Software-Systemen . . . . .                               | 42        |
| 2.2.1 Entwurfssichten, Abstraktionsebenen und Methodik des Systementwurfs . . . . .     | 43        |
| 2.2.2 Entwurfsprozess anwendungsspezifischer Hardware . . . . .                         | 46        |
| 2.2.3 Dynamisch partiell rekonfigurierbare Schaltungen . . . . .                        | 50        |
| 2.2.4 High-Level-Synthese - Synthese algorithmischer Verhaltensbeschreibungen . . . . . | 51        |
| 2.3 Parallelle Anwendungskonzepte und Programmiermodelle . . . . .                      | 64        |
| 2.4 Scheduling-Strategien . . . . .                                                     | 68        |
| 2.4.1 Shortest Job First (SJF) . . . . .                                                | 69        |
| 2.4.2 Round-Robin . . . . .                                                             | 70        |
| 2.4.3 Prioritätsbasiertes Scheduling . . . . .                                          | 70        |
| 2.4.4 Multilevel-Feedback Scheduling (MLFS) . . . . .                                   | 71        |

|                                                                                   |            |
|-----------------------------------------------------------------------------------|------------|
| <b>3 Stand der Technik</b>                                                        | <b>73</b>  |
| 3.1 Anwendungsentwurf für heterogene Computersysteme . . . . .                    | 73         |
| 3.2 Laufzeitumgebungen und Architekturen . . . . .                                | 77         |
| 3.3 Unterbrechung und Migration . . . . .                                         | 79         |
| <b>4 Entwurf dynamisch verteilter Anwendungen für heterogene Computer</b>         | <b>83</b>  |
| 4.1 Spezifikation . . . . .                                                       | 85         |
| 4.2 Codeumsetzung und Partitionierung in eine parallelisierte Anwendung . . . . . | 85         |
| 4.3 Architektur-Auswahl . . . . .                                                 | 86         |
| 4.4 Management-Code-Injektion . . . . .                                           | 87         |
| 4.5 Kompilierung und Synthese . . . . .                                           | 89         |
| 4.6 HW/SW-Co-Simulation . . . . .                                                 | 90         |
| 4.7 Eigenschafts- und Komplexitätsanalyse . . . . .                               | 92         |
| <b>5 Unterbrechung und Migration</b>                                              | <b>95</b>  |
| 5.1 Modellbildung und Formalisierung . . . . .                                    | 97         |
| 5.2 Kosten für Unterbrechung und Migration . . . . .                              | 101        |
| 5.2.1 Kostenbetrachtungen zusätzlicher Hardwarestrukturen                         | 101        |
| 5.2.2 Zeitliche Aufwände einer Unterbrechung . . . . .                            | 103        |
| 5.3 Verteilung von Unterbrechungspunkten . . . . .                                | 105        |
| 5.3.1 Unterbrechungspunkte auf Hochsprachenebene . . . . .                        | 107        |
| 5.3.2 Unterbrechungspunkte auf RT-Ebene . . . . .                                 | 111        |
| <b>6 Laufzeitumgebung und Systemverwaltung</b>                                    | <b>127</b> |
| 6.1 Ausführungsmodell . . . . .                                                   | 127        |
| 6.2 Anforderungen . . . . .                                                       | 129        |
| 6.3 Konzeption und Aufbau . . . . .                                               | 130        |
| 6.3.1 Programm-Laderoutine, Anwendungsmanager und Speichermanagement . . . . .    | 130        |
| 6.3.2 Kommunikationsschnittstelle . . . . .                                       | 131        |
| 6.3.3 Ressourcenverwaltung und temporale Ablaufplanung der Tasks . . . . .        | 133        |
| 6.3.4 Übersicht des Ausführungsablaufs einer Anwendung .                          | 140        |
| <b>7 Implementierung der Entwurfsmethodik</b>                                     | <b>143</b> |
| 7.1 Zielplattform, Betriebssystem und Laufzeitumgebung . . . . .                  | 143        |
| 7.2 Automatisierung des Entwurfsablaufes . . . . .                                | 145        |
| 7.2.1 Synthesewerkzeuge . . . . .                                                 | 145        |
| 7.2.2 Anwendungsanalyse und Codeinjektion . . . . .                               | 146        |
| 7.3 Hardware-Erweiterungen . . . . .                                              | 148        |

|                                |                                                              |            |
|--------------------------------|--------------------------------------------------------------|------------|
| 7.3.1                          | Unterbrechungslogik und Kontextspeicher . . . . .            | 148        |
| 7.3.2                          | Strombasierte Hardware-Software Schnittstelle . . . . .      | 151        |
| 7.3.3                          | Basisstruktur eines Ausführungskontainers in Hardware        | 152        |
| <b>8</b>                       | <b>Ergebnisse</b>                                            | <b>155</b> |
| 8.1                            | Anwendungsbeispiele . . . . .                                | 155        |
| 8.1.1                          | Auf-/Abwärtszähler . . . . .                                 | 155        |
| 8.1.2                          | MJPEG Kodierung . . . . .                                    | 156        |
| 8.1.3                          | Partikel-Filter . . . . .                                    | 157        |
| 8.2                            | Funktionsnachweis und Schedulinganalyse . . . . .            | 160        |
| 8.3                            | Analyse der Unterbrechungspunktverteilung . . . . .          | 162        |
| 8.4                            | Gewichtsfaktoren zur Unterbrechungspunktverteilung . . . . . | 166        |
| 8.5                            | Fazit . . . . .                                              | 168        |
| <b>9</b>                       | <b>Schluss</b>                                               | <b>169</b> |
| 9.1                            | Zusammenfassung . . . . .                                    | 169        |
| 9.2                            | Ausblick . . . . .                                           | 170        |
| <b>A</b>                       | <b>Werkzeuge zur High-Level-Synthese</b>                     | <b>173</b> |
| A.1                            | Kommerzielle Werkzeuge . . . . .                             | 173        |
| A.2                            | Akademische Ansätze und Werkzeuge . . . . .                  | 174        |
| <b>Literatur</b>               |                                                              | <b>176</b> |
| <b>Abbildungsverzeichnis</b>   |                                                              | <b>201</b> |
| <b>Tabellenverzeichnis</b>     |                                                              | <b>203</b> |
| <b>Algorithmensverzeichnis</b> |                                                              | <b>205</b> |
| <b>Thesen</b>                  |                                                              | <b>207</b> |