

## Rechneraufbau und Rechnerarchitektur

Bearbeitet von  
Axel Böttcher

1. Auflage 2006. Taschenbuch. xi, 210 S. Paperback  
ISBN 978 3 540 20979 9  
Format (B x L): 15,5 x 23,5 cm  
Gewicht: 346 g

[Weitere Fachgebiete > EDV, Informatik > EDV, Informatik: Allgemeines, Moderne Kommunikation > EDV & Informatik Allgemein](#)

Zu [Leseprobe](#)

schnell und portofrei erhältlich bei

**beck-shop.de**  
DIE FACHBUCHHANDLUNG

Die Online-Fachbuchhandlung beck-shop.de ist spezialisiert auf Fachbücher, insbesondere Recht, Steuern und Wirtschaft. Im Sortiment finden Sie alle Medien (Bücher, Zeitschriften, CDs, eBooks, etc.) aller Verlage. Ergänzt wird das Programm durch Services wie Neuerscheinungsdienst oder Zusammenstellungen von Büchern zu Sonderpreisen. Der Shop führt mehr als 8 Millionen Produkte.

# Inhaltsverzeichnis

|          |                                                          |    |
|----------|----------------------------------------------------------|----|
| <b>1</b> | <b>Landschaft der Prozessoren</b>                        |    |
| 1.1      | Prozessortypen .....                                     | 3  |
| 1.1.1    | Personal Computer und ihre Prozessoren .....             | 3  |
| 1.1.2    | Embedded Prozessoren .....                               | 5  |
| 1.1.3    | Signalprozessoren .....                                  | 5  |
| 1.1.4    | Mehrprozessorsysteme und Supercomputer .....             | 6  |
| 1.1.5    | Einsatzgebiete für Prozessoren .....                     | 6  |
| 1.2      | Technologische Randbedingungen .....                     | 8  |
| 1.3      | Befehlssätze .....                                       | 11 |
| 1.3.1    | Grundlegende Eigenschaften von Befehlssätzen .....       | 11 |
| 1.3.2    | Registersätze und Programmiermodell .....                | 11 |
| 1.3.3    | Unterscheidung von Befehlssätzen nach Registerbreite ... | 12 |
| 1.3.4    | Angabe von Operanden und Ergebnis .....                  | 13 |
| 1.3.5    | Adressierungsarten .....                                 | 15 |
| 1.3.6    | Befehlsformate .....                                     | 16 |
| 1.3.7    | Befehlstypen .....                                       | 19 |
| 1.3.8    | Parallelverarbeitung auf Ebene des Befehlssatzes .....   | 23 |
| 1.3.9    | Exkurs: Stackmaschinen .....                             | 24 |
| <b>2</b> | <b>Leistungsmessung und Bewertung</b>                    |    |
| 2.1      | Kenngrößen von Prozessoren .....                         | 29 |
| 2.1.1    | Taktfrequenz .....                                       | 29 |
| 2.1.2    | Million Instructions per Second .....                    | 30 |
| 2.1.3    | Floating Point Operations per Second .....               | 30 |
| 2.1.4    | Cycles per Instruction und Instructions per Cycle .....  | 30 |
| 2.1.5    | Leistungsaufnahme .....                                  | 30 |
| 2.2      | Benchmarks .....                                         | 31 |
| 2.3      | Amdahls Gesetz .....                                     | 35 |
| <b>3</b> | <b>Pipelining</b>                                        |    |
| 3.1      | Die klassische Fünf-Stufen-Pipeline .....                | 39 |
| 3.2      | Pipeline-Hemmnisse .....                                 | 43 |
| 3.2.1    | Strukturelle Hemmnisse .....                             | 44 |
| 3.2.2    | Hemmnisse durch Datenabhängigkeiten .....                | 46 |
| 3.2.3    | Ablaufbedingte Hemmnisse .....                           | 47 |
| 3.2.4    | Behandlung von Interrupts .....                          | 50 |
| 3.3      | Weiterentwicklungen .....                                | 51 |
| 3.3.1    | Längere Pipelines .....                                  | 51 |
| 3.3.2    | Parallele Pipelines .....                                | 51 |

|          |                                                         |     |
|----------|---------------------------------------------------------|-----|
| <b>4</b> | <b>Superskalarität</b>                                  |     |
| 4.1      | Parallele Ausführungseinheiten .....                    | 55  |
| 4.2      | Superskalare Pipelines .....                            | 58  |
| 4.3      | Konflikte durch Datenabhängigkeiten.....                | 60  |
| 4.4      | Ablaufsteuerung .....                                   | 61  |
| 4.5      | Spekulative Befehlsausführung .....                     | 69  |
| 4.6      | Umbenennung von Registern .....                         | 71  |
| 4.7      | Behandlung von Speicherzugriffen.....                   | 75  |
| 4.8      | Interrupts bei superskalaren Pipelines.....             | 76  |
| 4.9      | Zusammenfassung .....                                   | 77  |
| 4.10     | Superskalare Pipelines in der Praxis.....               | 77  |
| 4.10.1   | Pentium Pipelines für X86-Befehle .....                 | 77  |
| 4.10.2   | Die Pipeline des PowerPC 970 .....                      | 79  |
| <b>5</b> | <b>Experimente mit dem MMIX-Meta-Simulator</b>          |     |
| 5.1      | Konfiguration des Simulators .....                      | 85  |
| 5.1.1    | Der Fetch Buffer .....                                  | 85  |
| 5.1.2    | Ausführungseinheiten .....                              | 86  |
| 5.1.3    | Der Umsortierpuffer .....                               | 89  |
| 5.1.4    | Der Schreibpuffer .....                                 | 92  |
| 5.1.5    | Register .....                                          | 92  |
| 5.2      | Interna des Pipeline-Simulators .....                   | 93  |
| 5.3      | Fallstudien.....                                        | 94  |
| <b>6</b> | <b>Sprungvorhersage</b>                                 |     |
| 6.1      | Statische Vorhersage .....                              | 98  |
| 6.2      | Auswirkungen der Sprungvorhersage .....                 | 100 |
| 6.3      | Dynamische Vorhersage mit Zählern .....                 | 105 |
| 6.4      | Vorhersage unter Berücksichtigung der Vorgeschichte.... | 112 |
| 6.5      | Implementierungsaspekte.....                            | 115 |
| 6.6      | Sprungvermeidung .....                                  | 116 |
| 6.7      | Sprungvorhersage bei MMIX .....                         | 117 |
| <b>7</b> | <b>Speichersysteme</b>                                  |     |
| 7.1      | Die verschiedenen Speichertypen .....                   | 121 |
| 7.1.1    | Nicht-volatiler Speicher (ROM).....                     | 121 |
| 7.1.2    | Dynamisches und statisches RAM .....                    | 122 |
| 7.1.3    | Neuere Entwicklungen (MRAM und FRAM) .....              | 123 |
| 7.1.4    | Von der Speicherzelle zum Modul .....                   | 123 |
| 7.1.5    | Datentransfer .....                                     | 126 |
| 7.1.6    | Die Modellierung von Speicher bei MMIX.....             | 130 |

|              |                                                          |            |
|--------------|----------------------------------------------------------|------------|
| <b>7.2</b>   | Cache-Speicher .....                                     | <b>133</b> |
| <b>7.2.1</b> | Speicher-Hierarchien .....                               | <b>133</b> |
| <b>7.2.2</b> | Cache-Organisation.....                                  | <b>135</b> |
| <b>7.2.3</b> | Verdrängungsstrategien .....                             | <b>138</b> |
| <b>7.2.4</b> | Schreibende Cachezugriffe .....                          | <b>141</b> |
| <b>7.2.5</b> | Caches in der Praxis.....                                | <b>142</b> |
| <b>7.2.6</b> | Caches bei MMIX .....                                    | <b>143</b> |
| <b>8</b>     | <b>Virtueller Speicher</b>                               |            |
| <b>8.1</b>   | Organisation des virtuellen Speichers bei MMIX .....     | <b>153</b> |
| <b>8.2</b>   | Page Table Entries.....                                  | <b>155</b> |
| <b>8.3</b>   | Standardkonfiguration des Meta-Simulators .....          | <b>157</b> |
| <b>8.4</b>   | Page Table Pointer .....                                 | <b>158</b> |
| <b>8.5</b>   | Schnelle Adressumsetzung - Translation Lookaside Buffer  | <b>158</b> |
| <b>8.5.1</b> | Translation Lookaside Buffer bei MMIX .....              | <b>160</b> |
| <b>8.5.2</b> | Virtuelle Adressierung in der Praxis .....               | <b>160</b> |
| <b>9</b>     | <b>Moderne Techniken zur Parallelverarbeitung</b>        |            |
| <b>9.1</b>   | Prozessorkopplung (Mehrprozessorsysteme) .....           | <b>165</b> |
| <b>9.2</b>   | Das MESI-Protokoll .....                                 | <b>165</b> |
| <b>9.3</b>   | Simultaneous Multithreading .....                        | <b>168</b> |
| <b>9.4</b>   | Mehrkern-Prozessoren.....                                | <b>170</b> |
| <b>9.5</b>   | Abschließende Wertung .....                              | <b>170</b> |
| <b>A</b>     | <b>Anhang</b>                                            |            |
| <b>A.1</b>   | Lösung der Übungsaufgaben .....                          | <b>175</b> |
| <b>A.2</b>   | MMIX-Essentials.....                                     | <b>185</b> |
| <b>A.3</b>   | Beispielprogramme.....                                   | <b>187</b> |
| <b>A.3.1</b> | Darstellung der Mandelbrotmenge .....                    | <b>188</b> |
| <b>A.3.2</b> | Quicksort .....                                          | <b>190</b> |
| <b>A.4</b>   | Die Visualisierungsumgebung für MMIX .....               | <b>195</b> |
| <b>A.5</b>   | Beispielkonfigurationsdatei für <code>mmmix</code> ..... | <b>195</b> |
|              | <b>Literaturverzeichnis .....</b>                        | <b>201</b> |
|              | <b>Index .....</b>                                       | <b>205</b> |