block: stufen => stages, usw
[calu.git] / 4_block / blockdesc.tex
1 \section{Allgemein}
2 %\abbildung{pipeline.png}{so schaut unsre Architektur aus}{fig:pipeline}{1.4\textwidth}{90}
3 \abbildung{pipeline.png}{Schematische Darstellung der Pipeline}{fig:pipeline}{0.95\textheight}{90} %0.95 weil sonst warning!
4 Die Pipeline gliedert sich in 4 getrennte Stages. Jene sind Fetch, Decode, Execute und Writeback.
5 \section{Fetch-Stage}
6 Die Aufgaben der Fetch-Stage sind relativ simple in
7 \begin{itemize}
8         \item Anlegen der Instruktionsadresse an den Instruktions-Speicherbus. Daraufhin erh\"alt die Decode-Stage die gew\"unschte Instruktion im n\"achsten Zyklus.
9         \item Die Instruktionsadresse ist entweder der inkrementierte Programmcounter, Jump-Result oder das Ergebnis der statischen Branchprediction
10 \end{itemize}
11 gegliedert.
12 \section{Decode-Stage}
13 Die Aufgaben der Decode-Stage fallen schon etwas komplexer aus und sind in
14 \begin{itemize}
15         \item Decodieren der dichten Instruktion in eine aufgespaltene Form.
16         \item Laden der Operanden aus dem Registerfile und \"ubergeben der jeweiligen Adressen.
17         \item Laden von Immediates in die Operanden.
18         \item   Evaluierung der Branchprediction. R\"uckf\"uhrung der statischen Sprungadresse
19                                 und NOP insertion falls die ALU/Writeback springt.
20 \end{itemize}
21 gegliedert.
22 \section{Execute-Stage}
23 Neben den Berechnungen beinhaltet diese Stage auch die Forward-Unit welche s\"amtlichen
24 Konflikte behandelt.
25 \begin{itemize}
26         \item Ausf\"uhrung der einzelnen Instruktionen auf die Operanden
27         \item Signalisieren eines Sprungs (ret vs. jmp). Die Jumpadresse kommt entweder vom Datenbus oder aus dem ALU-Ergebnis.
28         \item Signalisieren eines Registerschreibzugriffs, wobei dieses Ergebnis wieder vom Result oder Datenbus kommt.
29         \item Ansprechen des Datenbusses (RAM, Extension-Module, read, write) und des Statuswortes sowie des Stackpointers.
30 \end{itemize}
31
32
33 Die Forward-Unit muss s\"amtliche Konflikte behandeln und veraltete Operanden durch die letzten Ergebnisse ersetzen. Sie besteht aus
34 \begin{itemize}
35         \item 2-Register um \"Anderungskonflikte an Registern zu l\"osen.
36         \item   Zusammensetzen eines dieser zwei Register mit dem Wert vom Datenbus (load byte etc.).
37 \end{itemize}
38
39 Die Extensionmodule werden vom Prozessor aus wie der Speicher behandelt. Jedes Modul besitzt einen spezifischen Adressbereich.
40 Ein eigener Controller mapped die Adressbereiche auf die Extensionmodule und leitet die entsprechenden Daten \"uber ein Register auf das Modul weiter. 
41 Beim Lesezugriff auf einen dieser Speicherbereiche legt das Extensionmodul einen Zyklus sp\"ater seinen Output auf den Datenbus. 
42
43
44 \section{Writeback-Stage}
45
46 Die Writeback-Stage \"ubernimmt die Werte aus dem Ergebnisregister der ALU oder aus der Forward-Unit (Registerzusammensetzung) und schreibt diese in das Registerfile zur\"uck. 
47 Des weiteren kann die ALU das Jump Result nicht direkt an die Decode-Stage zur\"uckgeben, da dieses erst im Folgezyklus vorhanden ist (im Falle eines branch-returns).
48 Somit muss dies auch von der Writeback-Stage erledigt werden.