### Grundlagen der Technischen Informatik 2 Digitaltechnik Rechneraufbau Prof. Dr. U. Kebschull Technische Informatik kebschull@informatik.uni-leipzig.de





## II Kebschull -

0 Einleitung Der Entwurf elektronischer Systeme ist gekennzeichnet durch: O Zunahme der Komplexität und Integrationsdichte O höhere Packungsdichten aufgrund geringerer Strukturgrößen

Übersicht

O Ein minimaler Rechner

O Aufbau von Rechnersystemen

Arbeitsweise und Programmierung

⇒ Komponenten eines Rechnersystems

Prinzipieller Aufbau eines Mikroprozessors

Steuerwerk und Mikroprogrammierung

⇒ Befehlssatz

⇒ Realisierung

⇒ Rechenwerk

Das Adresswerk



⇒ externe Busse

⇒ Parallele Schnittstellen

Analoge Ein- und Ausgabe

⇒ Serielle Schnittstellen

Prinzip der Datenein-und -ausgabe

O E/A-Steuerungen

Peripheriegeräte

⇒ Tastatur





Abstraktion und Detaillierung

### Die Entwicklung elektronischer Systeme ist bei der heutigen Komplexität nur durch eine strukturierte Vorgehensweise beherrschbar! U. Kebschull

O steigende Anforderungen (Platzbedarf, Taktrate, Leistungsverbrauch, Zuverlässigkeit) O kurze Entwicklungszeiten (time to market) ○ Wiederverwendung von Entwurfsdaten (Re-use)

# system function fTeil function $f_1$ $f_{11}$ $f_{12}$ Takanak bikmak 2 System function $f_2$ $f_{21}$ $f_{22}$ U. Kebschull

### Technische Kriterien für den Entwurf von Schaltnetzen

- O Korrekte Realisierung unter Beachtung des statischen und dynamischen Verhaltens der verwendeten Bauelemente
- Berücksichtigung technischer Beschränkungen (Anzahl der Eingänge, begrenzte Belastbarkeit der Ausgänge, zur Verfügung stehende Bausteine (Bausteinbibliothek), Temperaturgrenzen, Speicherplatz (bei PLAs), Taktfrequenz)
- Gewährleistung hoher Systemzuverlässigkeit (leichte Testbarkeit, Selbsttest, Fehlertoleranz, zuverlässiger Betrieb)
- O Berücksichtigung von Forderungen an die Gebrauchseigenschaften (universelle Einsatzmöglichkeit, großer Funktionsumfang)
- Berücksichtigung technologischer Nebenbedingungen (Kühlung, Versorgungsspannung)
- Vermeidung von Störeinflüssen (elektromagnetische Felder)

U. Kebschull
chrische Informatik 2
Stand SS 02

### Ökonomische Kriterien für den Entwurf von Schaltnetzen

- O Geringe Kosten für den Entwurf (Entwurfsaufwand)
  - ⇒ Lohnkosten
- Rechnerbenutzung, Softwarelizenzen
- O Geringe Kosten für die Realisierung (Realisierungsaufwand)
  - ⇒ Bauelemente, Gehäuseformen
  - ⇒ Kühlung
- O Geringe Kosten für die Inbetriebnahme
  - ⇒ Kosten f¨ur den Test
- Fertigstellung programmierbarer Bauelemente
- O Geringe Kosten für den Betrieb
  - ⇒ Wartung
  - **⇒** Stromverbrauch

U. Kebschull

Usensche Informatik 2

Stand SS 02

U. Kebschull

### Entwurfsziele

- O Manche Kriterien stehen im Widerspruch
  - ⇒ zuverlässigere Schaltungen erfordern einen höheren Realisierungsaufwand
  - ⇒ Verringerung des Realisierungsaufwand erfordert eine Erhöhung der Entwurfskosten
- Ziel des Entwurfs ist das Finden des günstigsten Kompromisses aus
  - Sorrektheit der Realisierung
  - ⇒ Einhaltung der technologischen Grenzen
  - ⇒ ökonomische Kriterien
- Wir betrachten in dieser Vorlesung nur die Minimierung des Realisierungsaufwands

U. Kebschull

### 1 Minimierungsverfahren

(Wdh.)

(Wdh.)

- O Finden von Minimalformen Boolescher Funktionen
  - ohne Betrachtung der Zieltechnologie
  - ight mit Betrachtung der Zieltechnologie
- O Drei Minimierungsansätze
  - algebraische Verfahren
  - praphische Verfahren
  - rische Verfahren
- Man unterscheidet

O Boolesche Variable

- exakte Minimierungsverfahren (z.B. Quine McCluskey), deren Ergebnis das absolute Minimum einer Schaltungsdarstellung
- heuristische Minimierungsverfahren auf der Basis von iterativen Minimierungsschritten

U. Kebschull

### Darstellung Boolescher Funktionen durch Funktionstabellen

(Wdh.)

- Darstellung des Verhaltens einer Booleschen Funktion mit Hilfe einer vollständigen Funktionstabelle
  - Jeder Belegung der Booleschen Variablen wird ein Funktionswert zugeordnet
  - $\Rightarrow f(x_2, x_1, x_0) \rightarrow y$ , mit  $x_i, y \in \{0,1\}$

| Index | $\mathbf{x}_{2}$ | $\mathbf{x}_1$ | $\mathbf{x}_{0}$ | У |
|-------|------------------|----------------|------------------|---|
| 0     | 0                | 0              | 0                | 0 |
| 1     | 0                | 0              | 1                | 0 |
| 2     | 0                | 1              | 0                | 1 |
| 3     | 0                | 1              | 1                | 0 |
| 4     | 1                | 0              | 0                | 1 |
| 5     | 1                | 0              | 1                | 0 |
| 6     | 1                | 1              | 0                | 1 |
| 7     | 1                | 1              | 1                | 1 |

 $f(x_2, x_1, x_0) = x_1 \overline{x}_0 \lor x_2 x_1 \lor x_2 \overline{x}_1 \overline{x}_0$ 

nische Informatik 2 Stand SS 02 15

### Wichtige Funktionen

(Wdh.)



### Zusammenfassung der wichtigsten Begriffe aus TI1

Variable, die den Wert wahr (1) oder falsch

(0) annehmen kann

O Produktterm: UND-Verknüpfung von Booleschen

Variablen

O Implikant: Produktterm, der eine oder mehrere "1"-

Stellen einer booleschen Funktion beschreibt

(impliziert)

O Implikat: Disjunktion (ODER-Verknüpfung) von

Literalen

O Minterm: Implikant, der genau eine "1"-Stelle einer

booleschen Funktion beschreibt

O Maxterm: Implikat, des genau eine "0"-Stelle einer

booleschen Funktion beschreibt

O disjunktive Normalform: Darstellung der Funktion, die nur aus

Mintermen besteht (DNF)

O konjunktive Normalform: Darstellung der Funktion, die nur aus

Maxtermen besteht (KNF)

nische Informatik 2 Stand SS 02

# Beispiel (Wdh.) Implikant $x_2 \wedge x_0 \stackrel{x_2 \wedge x_1 \wedge x_0}{\swarrow} x_2 \wedge \overline{x_1} \wedge x_0$ O DNF $f(x_2, x_1, x_0) = x_2 x_1 x_0 \vee x_2 \overline{x_1} x_0 \vee \overline{x_2} x_1 \overline{x_0} \vee \overline{x_2} \overline{x_1} \overline{x_0}$ Minterm Maxterm O KNF $f(x_2, x_1, x_0) = (x_2 \vee x_1 \vee x_0) \wedge (x_2 \vee x_1 \vee \overline{x_0}) \wedge (x_2 \vee \overline{x_1} \vee \overline{x_0})$



### 1.4 Das Verfahren nach Ouine-McCluskev

- O KV-Diagramme mit mehr als 6 Variablen werden sehr groß und unübersichtlich
  - ⇒ dieses Problem wurde zuerst von Quine und McCluskey erkannt und gelöst
  - A das Verfahren nach Quine-McCluskev ist ein tabellarisches Verfahren
  - ⇒ es führt auf eine DMF (disjunktive minimale Form)
- O Ausgangspunkt ist die Funktionstabelle der Funktion
  - nur die Minterme werden berücksichtigt
- O Der Suchraum wird eingeschränkt, weil der Satz 1.1 gilt:
  - ⇒ zu jeder Booleschen Funktion f gibt es eine minimale Überdeckung aus Primimplikanten
- O Verfahren nach Quine McCluskev in 2 Schritten:
  - 1. Schritt: berechne alle Primimplikanten
  - 2. Schritt: suche eine minimale Überdeckung aller Minterme

### Beispiel: Die vollständige Funktionstabelle

| Nr. | edcba     | У | Nr. | edcba     | Y |
|-----|-----------|---|-----|-----------|---|
| 0   | 0 0 0 0 0 | 0 | 16  | 1 0 0 0 0 | 0 |
| 1   | 00001     | 0 | 17  | 1 0 0 0 1 | 0 |
| 2   | 0 0 0 1 0 | 1 | 18  | 10010     | 1 |
| 3   | 0 0 0 1 1 | 0 | 19  | 10011     | 0 |
| 4   | 0 0 1 0 0 | 1 | 20  | 10100     | 0 |
| 5   | 0 0 1 0 1 | 1 | 21  | 10101     | 0 |
| 6   | 0 0 1 1 0 | 1 | 22  | 10110     | 1 |
| 7   | 0 0 1 1 1 | 0 | 23  | 10111     | 0 |
| 8   | 0 1 0 0 0 | 0 | 24  | 1 1 0 0 0 | 0 |
| 9   | 0 1 0 0 1 | 0 | 25  | 1 1 0 0 1 | 0 |
| 10  | 0 1 0 1 0 | 1 | 26  | 1 1 0 1 0 | 1 |
| 11  | 0 1 0 1 1 | 0 | 27  | 1 1 0 1 1 | 0 |
| 12  | 0 1 1 0 0 | 1 | 28  | 11100     | 0 |
| 13  | 0 1 1 0 1 | 1 | 29  | 1 1 1 0 1 | 0 |
| 14  | 0 1 1 1 0 | 1 | 30  | 1 1 1 1 0 | 1 |
| 15  | 0 1 1 1 1 | 0 | 31  | 11111     | 0 |
|     |           |   |     |           |   |

### 1. Schritt: Berechnung aller Primimplikanten

- Schreibweise
  - ⇒ 1 steht für eine nicht negierte Variable
  - steht für eine negierte Variable
- steht für eine nicht auftretende Variable
- O Man betrachtet nur die Minterme
  - ⇒ 1-Stellen der Funktion
- O Die Minterme werden geordnet
- ⇒ Gruppen mit der gleichen Anzahl von Einsen
- innerhalb der Gruppen: aufsteigende Reihenfolge
- ⇒ man erhält die 1. Quinesche Tabelle, 0. Ordnung
- O Minterme benachbarter Gruppen die sich nur in 1 Variable unterscheiden werden gesucht
  - ⇒ diese können durch Streichen der Variable zusammengefaßt
  - nan erhält die 1. Quineschen Tabellen höherer Ordnung

### Beispiel: 1. Ouinesche Tabelle

| Nr. | edcba     | Nr. edcba       | Nr. edcba               |
|-----|-----------|-----------------|-------------------------|
| 2   | 0 0 0 1 0 | 2,6 00-10       | 2,6,10,14 0 1 0         |
| 4   | 0 0 1 0 0 | 2,10 0 - 0 1 0  | 2,6,18,22 - 0 - 1 0     |
| 5   | 0 0 1 0 1 | 2,18 - 0 0 1 0  | 2,10,18,26 0 1 0        |
| 6   | 0 0 1 1 0 | 4,5 0010-       | 4,5,12,13 0 - 1 0 - $A$ |
| 10  | 0 1 0 1 0 | 4,6 001-0       | 4,6,12,14 0 - 1 - 0 B   |
| 12  | 0 1 1 0 0 | 4,12 0 - 1 0 0  | 6,14,22,30 1 1 0        |
| 18  | 10010     | 5,13 0 - 1 0 1  | 10,14,26,30 - 1 - 1 0   |
| 13  | 0 1 1 0 1 | 6,14 0 - 1 1 0  | 18,22,26,30 1 1 0       |
| 14  | 0 1 1 1 0 | 6,22 - 0 1 1 0  | 2. Ordnung              |
| 22  | 10110     | 10,14 0 1 - 1 0 | 21 Oraniang             |
| 26  | 1 1 0 1 0 | 10,26 - 1 0 1 0 |                         |
| 30  | 1 1 1 1 0 | 12,13 0 1 1 0 - |                         |
|     | O         | 12,14 0 1 1 - 0 |                         |
| U.  | Ordnung   | 18,22 1 0 - 1 0 | Nr. edcba               |
|     |           | 18,26 1 - 0 1 0 | 2,6,10,14               |
|     |           | 14,30 - 1 1 1 0 | 18,22,26,30 1 0         |
|     |           | 22,30 1 - 1 1 0 | 3. Ordnung              |
|     |           | 26,30 1 1 - 1 0 |                         |
|     |           | 1. Ordnung      |                         |
| _   |           |                 | U. Kebschull            |

### 2. Schritt: Suche einer minimalen Überdeckung

- O Aufstellen der 2. Quineschen Tabelle
  - ⇒ alle Primimplikanten werden zusammen mit der Nummer des Minterms aus dem sie hervorgegangen sind in eine Überdeckungstabelle eingetragen
- O Kosten für einen Primimplikanten:
  - Anzahl der UND-Eingänge (Anzahl der Variablen des Terms)

| Primimplikant | 2 | 4 | 5 | 6 | 10 | 12 | 13 | 14 | 18 | 22 | 26 | 30 | Kosten |
|---------------|---|---|---|---|----|----|----|----|----|----|----|----|--------|
| A             |   | x | х |   |    | x  | х  |    |    |    |    |    | 3      |
| В             |   | х |   | х |    | х  |    | х  |    |    |    |    | 3      |
| С             | x |   |   | x | x  |    |    | x  | x  | x  | x  | x  | 2      |

O Aufgabe: Finden einer Überdeckung aller Minterme mit minimalen Kosten

II Kebschull -

### Systematische Lösung des Überdeckungsproblems

- O Aufstellung einer Überdeckungsfunktion ü.
  - $\Rightarrow w_A, w_B$  und  $w_C$  sind Variablen, die kennzeichnen, ob ein entsprechender Primimplikant in der vereinfachten Darstellung aufgenommen wird, oder nicht
  - Sonjunktive Form über alle den jeweiligen Minterm überdeckenden Primimplikanten

Primimplikant 2 4 5 6 10 12 13 14 18 22 26 30 х х х х x x x R х х x x x x x

 $\ddot{u}_f = w_C(w_A \vee w_B)w_A(w_B \vee w_C)w_C(w_A \vee w_B)w_A(w_B \vee w_C)w_Cw_Cw_Cw_C$ 

- $= w_C(w_A \vee w_R)w_A(w_R \vee w_C)$
- $= (w_C w_A \vee w_C w_B)(w_A w_B \vee w_A w_C)$
- $= w_C w_B w_A \vee w_A w_C$

### Systematische Lösung des Überdeckungsproblems

- O Ergebnis nach der Vereinfachung:  $\ddot{u}_f = w_C w_B w_A \vee w_A w_C$
- O Damit f ganz überdeckt ist, muss  $\ddot{u}_t$  eine Tautologie sein
  - man sucht einen konjunktiven Term mit minimalen Kosten

$$w_C w_B w_A$$
 Kosten: 3+3+2=8  
 $w_A w_C$  Kosten: 3+2=5

O Als Endergebnis der Minimierung für die Funktion f erhält man

$$f(e,d,c,b,a) = \overline{e}c\overline{b} \vee b\overline{a}$$

### Vereinfachung des Überdeckungsproblems

- O Die Primimplikantentabelle kann reduziert werden, indem essentielle Primterme (Kernprimimplikanten) und die von ihnen überdeckten Minterme gestrichen werden
  - ⇒ tragen mit einem einzigen "X" zu einer Spalte bei
  - ⇒ müssen auf jeden Fall in der Überdeckung enthalten sein
- O In diesem Beispiel sind dies die beiden Primimplikanten A und C Primimplikant 2 4 5 6 10 12 13 14 18 22 26 30 Kosten



- ⇒ A: 5, 13
- ⇒ C: 2, 10, 18, 22, 26, 30
- B ist vollständig überdeckt und kann ebenfalls gestrichen

### Aufwandsbetrachtungen

- O Alle Verfahren benötigen 2 Schritte
  - ⇒ 1. Erzeugen aller Primimplikanten (Primimplikate)
  - ⇒ 2. Auswahl der Primiplikanten (Primimplikate), welche die Minterme (Maxterme) mit minimalen Kosten überdecken
- O Die Anzahl der Primimplikanten (Primimplikaten) kann exponentiell steigen
  - $\Rightarrow$  Es gibt Funktionen mit  $\frac{3^n}{n}$  Primimplikanten
- O Das Überdeckungsproblem ist NP-Vollständig
- 🗢 es besteht wenig Hoffnung einen Algorithmus zu finden, der dieses Problem polynomial mit der Zahl der Eingabevariablen

### Heuristische Verfahren

- O Heuristische Minimierungsverfahren werden eingesetzt,
  - wenn die zweistufige Darstellung optimiert werden muss, aber
  - $\Rightarrow$  nur begrenzte Rechenzeit und Speicherplatz zur Verfügung steht
- Die meisten heuristischen Minimierungsansätze basieren auf einer schrittweisen Verbesserung der Schaltung
- O Unterschiede zu exakten Verfahren:
  - ⇒ man wendet eine Menge von Transformationen direkt auf die Überdeckung des ON-Sets an
  - ⇒ man definiert die Optimierung als beendet, wenn diese Transformationen keine Verbesserungen mehr bringen
- Mehr dazu in der Vorlesung "Entwurf hochintegrierter Schaltungen"

hnische Informatik 2 Stand SS 02

U. Kebschull -

### 1.5 Laufzeiteffekte in Schaltnetzen

- Bisher wurden Schaltnetze mit idealen Verknüpfungsgliedern betrachtet
- □ die Verknüpfungsgliedern besaßen keine Signallaufzeit
- Bei realen Verknüpfungsgliedern dürfen Signallaufzeiten nicht vernachlässigt werden
  - Schaltvariablen können Werte annehmen, die theoretisch oder bei idealen Verknüpfungsgliedern nie auftreten könnten
- O Solche Störimpulse nennt man Hazards
  - ⇒ sie treten als Antwort auf die Änderung der Werte der Eingangsvariablen auf

U. Kebschull
Stand 88 02
Stand 88 02

### **Entstehung von Hazards**



### Statische Hazards

- Statische Hazards sind Störimpulse aus einer Verknüpfung, die theoretisch konstant Null oder Eins liefern müsste
- $X_t \wedge \overline{X}_{t-k}$  müsste Null liefern statischer 1-Hazard bei einem Übergang von X: 0 $\to$ 1
- $X_t \vee \overline{X}_{t-k}$  müsste Eins liefern statischer 0-Hazard bei einem Übergang von X: 1 $\to$ 0

II Kebschull

### **Dynamische Hazards**

- Dynamische Hazards entstehen als zusätzliche Übergänge beim Ausgang eines Schaltnetzes
- $X_t \wedge \overline{X}_{t-k} \vee X_l$ , mit l > k
  - ⇒ bei einem Übergang von X=0 →X=1 darf am Ausgang nur ein zu  $X_{t,t}$  synchroner 0 →1 Übergang auftreten
  - $\Rightarrow$  durch den vorgeschalteten statischen Hazard kommt es aber zu einer zusätzlichen  $0 \rightarrow 1$  Flanke
- $X_t \wedge (\overline{X}_{t-k} \vee X_l)$ , mit l > k
  - $\Rightarrow$  bei einem Übergang von X=0  $\rightarrow$ X=1 darf am Ausgang nur ein zu X. synchroner 0  $\rightarrow$ 1 Übergang auftreten
  - $\Rightarrow$  durch den vorgeschalteten statischen Hazard kommt es aber zu einer zusätzlichen  $0 \rightarrow 1$  Flanke

U. Kebschull
siische Informatik 2
Stand SS 02

### Klassifikation von Hazards



### **Behebung von Hazards**

- O Hazards können die Funktion von Schaltnetzen stören
  - ⇒ falsche Werte können an den Eingang eines Schaltnetzes zurückgekoppelt werden
- Um solche Fehler zu vermeiden werden taktflankengetriggerte Speicherglieder in die Rückkopplung eingefügt
- Die Signale werden erst übernommen, wenn die Hazards abgeklungen sind
  - nur stabile, gültige Werte werden übernommen
  - ⇒ synchrone Schaltwerke: Schaltwerke, die durch einen zentralen Takt gesteuert werden
- Hazards haben einen Einfluss auf die maximale Schaltgeschwindigkeit
  - naximaler Takt
  - ⇒ Entfernung von Hazards führt zu einer Erhöhung der Geschwindigkeit einer Schaltung

### 2 Speicherglieder

- Speicherglieder dienen der Aufnahme, Speicherung und Abgabe von Schaltvariablen
  - ⇒ Ein Speicherglied ist ein bistabiles Kippglied
  - ➡ Flipflop
- Zwei Zustände

  - ⇒ Zustand 0: Rücksetzzustand
- O Übernahme des Zustands kann erfolgen
  - taktunabhängig (nicht taktgesteuert)
  - ⇒ taktabhängig (taktgesteuert)
    - taktzustandsgesteuert
    - taktflankengesteuert
- Die unterschiedlichen Arten der Ansteuerungen führen zu unterschiedlichen Flipflop-Typen

U. Kebschull 

sische Informatik 2 Stand SS 02 

4

### Funktionsprinzip



- Rückkopplung
  - ⇒ Wirkprinzip aller bistabilen Kippschaltungen
  - $\Rightarrow$  Ein Kippvorgang eines stabilen Zustands in den anderen wird durch  $E_{stl}$  und  $E_{st2}$  ausgelöst

### **Funktionsprinzip**

- $\bigcirc$  Nach dem Anlegen von  $U_B$  sei  $T_2$  leitend,  $T_I$  sperrt
  - $\Rightarrow$   $A_1$  besitzt H-Pegel und  $A_2$  besitzt L-Pegel
  - dieser Zustand ist stabil
- Wird E<sub>st</sub> auf H-Pegel gesetzt, so
  - $\Rightarrow$  wird  $T_i$  leitend,  $A_i$  geht auf L-Pegel
  - $\Rightarrow$  T, sperrt und A, geht auf H-Pegel
  - ⇒ dieser Zustand ist ebenfalls stabil
- Wird E<sub>--</sub>, auf H-Pegel gesetzt, so
  - $\Rightarrow$  wird  $T_2$  leitend,  $A_2$  geht auf L-Pegel
  - $\Rightarrow$   $T_i$  sperrt und  $A_i$  geht auf H-Pegel
  - ⇒ dieser Zustand ist wiederum stabil
- $\bigcirc$  Werden  $E_{ext}$  und  $E_{ext}$  auf H-Pegel gesetzt, so
  - ⇒ leiten beide Transistoren, die Rückkopplung wird unwirksam
  - dieser Zustand ist nicht stabil
  - ⇒ unzulässige Eingangsbelegung

Technische Informatik

U. Kebschull

### RS-Flipflop

- Bistabile Kippschaltungen können aus rückgekoppelten
  - ⇒ Transistoren
  - ⇒ NOR-Gattern
  - ⇒ NAND-Gattern
- gebaut werden

  RS-Flipflop
  - wenn die Eingänge den Wert 0 haben, bleibt der vorherige Zustand stabil
  - $\Rightarrow$  wird S =1, wird O=1 und  $\overline{O}$ =0
- ⇒ wird R=1, wird O=0 und Ō=1
- ⇒ S=1 und gleichzeitig R=1 sind nicht zulässig



Schaltzeichen für ein RS-Flipflop nach DIN

U. Kebschull

echnische Informatik 2

S 02

### Funktionstabelle der Ausgänge $A_1$ und $A_2$ $E_1 \qquad E_2 \qquad A_1 \qquad A_2$

0 0 (wie vorher) speichern 0 1 1 0 1 0 0 1 1 1 (0 0) unzulässig

O Liegt an einem Eingang eines NOR-Gatters eine 1 an, so geht der

entsprechende Ausgang auf 0

an, so bleiben die Ausgänge

O Liegen an beiden Eingängen eine 0

≥1

Technische Informatik 2

erhalten

U. Kebschull

### RS-Flipflop aus NOR-Gattern

O Ein RS-Flipflop entsteht durch Vertauschen der Ausgänge

### Funktionstabelle

| S | R | Q    | $\overline{\mathbf{Q}}$ |
|---|---|------|-------------------------|
| 0 | 0 | (wie | vorher) speiche         |
| 0 | 1 | 0    | 1                       |
| 1 | 0 | 1    | 0                       |
| 1 | 1 | (0   | 0) unzulässig           |
|   |   | 1    |                         |



U. Kebschull

### **RS-Flipflop aus NAND-Gattern**

- O Liegt an beiden Eingängen eines NAND-Gatters eine 1 an, so geht der entsprechende Ausgang auf 0
- Liegen an beiden Eingängen der Schaltung eine 1 an, so bleiben die Ausgänge erhalten



Funktionstabelle der Ausgänge  $\mathbf{A}_1$  und  $\mathbf{A}_2$ 

| 0      | 0      | (1 1) (unzulässig)                                   | В      | Α      | $\overline{A \wedge B}$ |
|--------|--------|------------------------------------------------------|--------|--------|-------------------------|
| 0<br>1 | 1<br>0 | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | 0      | 0      | 1                       |
| 1      | 1      | (wie vorher) speichern B                             | 1<br>1 | 0<br>1 | 1 0                     |
|        |        |                                                      | II Ka  | hook   | .11 —                   |

### RS-Flipflop aus NAND-Gattern

RS-Flipflop aus NOR-Gattern

OEin RS-Flipflop entsteht durch Negation der Eingänge

### Funktionstabelle

| S | R | $\overline{\mathbf{S}}$ | $\overline{\mathbf{R}}$ | $Q \overline{Q}$       |
|---|---|-------------------------|-------------------------|------------------------|
| 0 | 0 | 1                       | 1                       | (wie vorher) speichern |
| 0 | 1 | 1                       | 0                       | 0 1                    |
| 1 | 0 | 0                       | 1                       | 1 0                    |
| 1 | 1 | 0                       | 0                       | (1 1) unzulässig       |



Technische Informatik 2 Stand SS 02 51

### Zustandsfolgetabelle

- O Das Ausgangssignal ändert sich zeitversetzt nach der Signaländerung am Eingang
- O Zeitverhalten wird in einer Zustandsfolge dargestellt
  - $\Rightarrow Q_n$  ist der Wert vor der Signaländerung
  - Q<sub>n+1</sub> ist der Wert nach der Signaländerung

| $\boldsymbol{S}$ | R | $Q_n$ | $Q_{n+I}$ |            |
|------------------|---|-------|-----------|------------|
| 0                | 0 | 0     | 0         | speichern  |
| 0                | 0 | 1     | 1         | speichern  |
| 0                | 1 | 0     | 0         | rücksetzen |
| 0                | 1 | 1     | 0         | rücksetzen |
| 1                | 0 | 0     | 1         | setzen     |
| 1                | 0 | 1     | 1         | setzen     |
| 1                | 1 | 0     | -         | unzulässig |
| 1                | 1 | 1     | -         | unzulässig |



 $Q_{n+1} = S \vee (\overline{R} \wedge Q_n)$ 

- O Diese Gleichung heißt auch Funktionsgleichung oder Übergangsfunktion eines RS-Flipflops
  - das Verhalten eines Flipflops kann durch eine Schaltfunktion beschrieben werden

U. Kebschull

52



### RS-Flipflop mit Zustandssteuerung

- O Beim RS-Flipflop wird der Ausgang sofort nach Anlegen der Eingangssignale gesetzt
  - ⇔ zur Vermeidung von Hazards wird häufig gefordert, dass ein Flipflop seinen Wert nur zu bestimmten Zeitpunkten ändert
  - Synchrone Schaltwerke
  - ⇒ Einführung eines Taktsignals



U. Kebschull

Stand 88 02

5

### RS-Flipflop mit Zustandssteuerung

Funktionstabelle C S R  $Q_n | Q_{n+1}$ keine Änderung 0 Ausgangszustands 0 0 Speichern speichern speichern rücksetzen riicksetzen setzen 1 0 1 1 setzen 1 1 0 unzulässig 1 1 1 1 - unzulässig

O Aus der Übergangsfunktion des RS-Flipflos

 $Q_{n+1} = S \vee (\overline{R} \wedge Q_n)$  **mit**  $S = (C \wedge S')$  **und**  $R = (C \wedge R')$ 

 $Q_{n+1} = (C \wedge S') \vee ((\overline{C \wedge R'}) \wedge Q_n)$ 

### Impulsdiagramm für Taktzustandssteuerung



### **D-Flipflop mit Zustandssteuerung**

O Das D-Flipflop entsteht aus einem RS-Flipflop mit Zustandssteuerung, durch die Negation des Setzsignals S



### Master-Slave D- Flipflop

- O Probleme beim Verketten von Flinflons
  - ⇒ bei C=1 rutschen die Eingänge bis zum Ausgang durch
  - Anwendung: Schieberegister, Zähler
- O Lösung: (positiv) flankengesteuertes Flipflop
  - ⇒ zwei D-Flipflops werden hintereinander geschaltet
  - ⇒ das erste Flipflop erhält den negierten Takt
  - ⇒ Master-Slave-Prinzip



### Impulsdiagramm des Master-Slave D-Flipflops



### Impulsdiagramm des Master-Slave D-Flipflops



### JK-Flipflop

- O Neben den Funktionen speichern, setzen und rücksetzen, macht es Sinn für die undefinierte Belegung R=S=1 die weitere Funktion wechseln zu definieren
  - Man erreicht dies durch Rückführung der Ausgänge an den Eingang



### Master-Slave T-Flipflop

- - ⇒ ist dieser gleich 1, wechselt das Flipflop seinen Wert
  - ⇒ T steht für toggle





Schaltung

Schaltzeichen

Q<sub>n</sub> speichern Q<sub>n</sub> wechseln Funktionstabelle

### 3 Schaltwerke

### 3.1 Formale Grundlagen

- Schaltnetze
  - ig die Ausgabe einer Schaltung hängt nur von den Werten der Eingabe zum gleichen Zeitpunkt ab
  - nan nennt sie auch kombinatorische Schaltungen
- Schaltwerke
  - ⇒ die Ausgabe einer Schaltung kann von den Werten der Eingabe zu vergangenen Zeitpunkten abhängen
  - alle Abhängigkeiten von Werten der Vergangenheit werden in einem Zustand zusammengefaßt
  - sie sind Implementierungen von deterministischen endlichen Automaten

### Beschreibung von endlichen Automaten

- O Andere Namen für endliche Automaten sind:
  - ⇒ finite state machine, FSM
  - sequentielle Schaltungen
  - Schaltungen mit Speicherverhalten
- O Aus der Automatentheorie:

Ein endlicher Automat ist ein Quintupel  $A=(X, Y, S, \delta, \lambda, s_0)$ 

- $\Rightarrow$  eine endliche Menge von Eingangsbelegungen, X
- ⇒ eine endliche Menge von Ausgangsbelegungen, Y
- ⇒ eine endliche Menge von Zuständen, S
- $\Rightarrow$  eine Zustandsübergangsfunktion  $\delta: X \times S \rightarrow S$
- eine Ausgabefunktion

 $\lambda: X \times S \longrightarrow Y$  (Mealy Verhalten)

(Moore Verhalten)

und er besitzt einen Startzustand s

- O Ein T-Flipflop besitzt wie das D-Flipflop nur einen Eingang

### Mealy- und Moore-Automaten

- O Die Zustände eines endlichen Automaten werden in Flipflops gespeichert
  - ⇒ möglich sind D-, T-, JK-, RS-Flipflops
- O Der aktuelle Zustand wird an die Eingänge der Schaltung rückgekoppelt
- O Man unterscheidet Mealy- und Moore- und Medvedev-Automaten:
- O Mealy:
  - ⇒ Ausgangsleitungen können sich ändern, auch wenn keine Taktflanke aufgetreten ist
- O Moore:
  - ⇒ Änderung von Ausgangsleitungen nur mit Änderung eines Taktimpulses
- Medvedev:
  - Spezialfall des Moore-Automaten
  - ⇒ die Ausgänge sind die Zustandsbits der Flipflops

ische Informatik 2 Stand SS 02

### Struktur eines Mealy-Automaten



### Struktur eines Moore-Automaten



### 3.2 Darstellung endlicher Automaten

- Die Aufgabenstellung liegt meist in einer nicht formalisierten Form vor
- Um beim Entwurf von Schaltwerken systematische und möglichst auch rechnergestützte Entwurfsverfahren einsetzen zu können, muss eine formalisierte Beschreibung verwendet werden
- O Häufig verwendete Darstellungsformen sind:
  - ⇒ Zeitdiagramm
  - Automatengraph
  - ⇒ Ablauftabelle
  - ⇒ Schaltfunktionen
  - Automatentabelle

U. Kebschull

### **Beispiel: Selbsthalteschaltung**

- O Beschreibung der Funktion:
  - ⇒ an den Eingängen befinden sich zwei Tasten : (Start und Stopp)
  - ⇒ die Schaltung liefert ein Ausgangssignal, mit dem ein Gerät einoder ausgeschaltet werden kann
  - ⇒ wird die Starttaste gedrückt, soll das Gerät eingeschaltet werden
  - ⇒ es soll eingeschaltet bleiben, auch wenn die Starttaste wieder losgelassen wird
  - ⇒ das Gerät soll ausgeschaltet werden, sobald die Stopptaste betätigt wird
- o zu klären ist:
  - ⇒ was passiert, wenn beide Tasten gleichzeitig betätigt werden?
  - ⇒ was passiert, wenn die Starttaste gedrückt wird, obwohl das Gerät eingeschaltet ist?
  - was passiert, wenn das Gerät ausgeschaltet ist und die Stopptaste gedrückt wird?

U. Kebschull uche Informatik 2 Stand SS 02

### Zeitdiagramm



- O Damit lassen sich 2 Zustände festlegen:
  - $\Rightarrow$  **Zustand**  $s_0$ : **Ausgabe von** Motor=0 **und warten auf** Start=1 **und** Stopp=0
  - ⇒ Zustand s<sub>1</sub>: Ausgabe von Motor=1 und warten auf Stopp=1

U. Kebschull

### Mealy und Moore Verhalten



Automatengraph



### Ablauftabelle

### Mealy-Ablauftabelle

| Eingang | Zustand | Folgezustand | Ausgang |
|---------|---------|--------------|---------|
| -, 1    | S0      | S0           | 0       |
| 0, 0    | S0      | S0           | 0       |
| 1, 0    | S0      | S1           | 1       |
| -, 0    | S1      | S1           | 1       |
| -, 1    | S1      | S0           | 0       |

### Moore-Ablauftabelle

| Eingang | Zustand / | Folgezustand |
|---------|-----------|--------------|
|         | Ausgang   | -            |
| -, 1    | S0/ 0     | S0           |
| 0, 0    | S0/ 0     | S0           |
| 1, 0    | S0/ 0     | S1           |
| -, 0    | S1/ 1     | S1           |
| -, 1    | S1/ 1     | S0           |

### Interpretation der Ablauftabelle

Wenn wir im Zustand 0 sind

undzusätzlich Start = 1 und Stop = 0 gilt,

wird Motor an zu 1 dann

wir gehen mit dem nächsten Takt in den Zustand 1 und

### Schaltfunktionen

O Aus der Ablauftabelle lassen sich die die Ausgabe- und die Zustandsübergangsfunktion ablesen:

| $x_1, x_2$ | Zustand S | Folgezustand S+ | Ausgang y |
|------------|-----------|-----------------|-----------|
| -, 1       | S0        | S0              | 0         |
| 0, 0       | S0        | S0              | 0         |
| 1, 0       | S0        | S1              | 1         |
| -, 0       | S1        | S1              | 1         |
| -, 1       | S1        | S0              | 0         |

**O** Übergangsfunktion:  $s_0^+ = (x_2 \wedge s_0) \vee (\overline{x}_1 \wedge \overline{x}_2 \wedge s_0) \vee (x_2 \wedge s_1)$ 

 $s_1^+ = (x_1 \wedge \overline{x}_2 \wedge s_0) \vee (\overline{x}_2 \wedge s_1)$ 

Ausgabefunktion:  $y = (x_1 \wedge \overline{x}_2 \wedge s_0) \vee (\overline{x}_2 \wedge s_1)$  Mealy-Automat

Moore-Automat

II Kebschull -

### Automatentabelle

|         | Fol   | lgezu | stan  | d     | 1       |         |                   |             |           | Folgezustand/ Ausgang |   |  |  |  |  |
|---------|-------|-------|-------|-------|---------|---------|-------------------|-------------|-----------|-----------------------|---|--|--|--|--|
| Zustand |       |       |       |       | Ausgang | Zustand |                   | Start/Stopp |           |                       |   |  |  |  |  |
|         | 0/0   | 0/1   | 1/0   | 1/1   |         |         | 0/0               | 0/1         | 1/0       | 1/1                   | _ |  |  |  |  |
| $s_0$   | $s_0$ | $s_0$ | $s_1$ | $s_0$ | 0       | $s_0$   | s <sub>0</sub> /0 | $s_0/0$     | $s_{1}/1$ | $s_0/0$               |   |  |  |  |  |
| $s_1$   | $s_1$ | $s_0$ | $s_1$ | $s_0$ | 1       | $s_1$   | $s_{1}/1$         | $s_0/0$     | $s_1/1$   | $s_0/0$               |   |  |  |  |  |

Moore-Automat

Mealy-Automat

- O In der Automatentabelle werden die Zustände senkrecht und alle möglichen Eingangsbelegungen waagrecht dargestellt
- ⇒ an den Schnittpunkten werden die Folgezustände eingetragen
- ⇒ Moore-Automat: Die Ausgabe wird dem Zustand zugeordnet
- ⇒ Mealy-Automat: Die Ausgabe wird dem Folgezustand zugeordnet

### Medvedev- und Moore-Automaten

- O Auch Moore-Automaten können während des Übergangs Fehlimpulse (Glitches, Hazards) auslösen
  - ⇒ unterschiedliche Laufzeiten in der Schaltung
  - ⇒ 01 nach 10 Übergänge der Zustandsübergangsfunktion ohne Änderung des Ausgangswerts
- O Medvedev-Automaten besitzen am Ausgang ein Flipflop
  - ⇒ keine Fehlimpulse
  - Ausgangswert muss einen Takt früher berechnet werden

| Eingang | Zustand /<br>Ausgang | Folgezustand | Eingang | Zustand /<br>Ausgang | Folgezustand |
|---------|----------------------|--------------|---------|----------------------|--------------|
| -, 1    | S0/ 0                | S0           | -, 1    | S0/ 0                | S0           |
| 0, 0    | S0/ 0                | S0           | 0, 0    | S0/ 0                | S0           |
| 1, 0    | S0/(0)               | S1           | 1, 0    | S0/(1)               | S1           |
| -, 0    | S1/ 1                | S1           | -, 0    | S1/ 1                | S1           |
| 1       | S1/(1)               | S0           | 1       | S1/(0)               | S0           |

Moore-Automat

Medvedev-Automat

II Kebschull

### 3.3 Analyse und Entwurf von Schaltwerken

Grundlegende Realisierung von Automaten

- O Asynchrone Realisierung
  - ⇒ Zustandsspeicher durch Rückkopplung
  - se gibt keinen zentralen Takt
  - ⇒ die Zustandsspeicher (Flipflops) können zu jedem Zeitpunkt ihren Wert ändern
  - ⇒ self-timed
- O Synchrone Realisierung
  - Rückkopplung nur durch flanken- oder pegelgetriggerte
  - ⇒ die Taktleitungen aller Flipflops sind miteinander verbunden (oder hängen nach einem festen Zeitschema voneinander ab)
- Obwohl asynchrone Realisierungen auch eine gewisse praktische Bedeutung besitzen, werden hier nur synchrone Realisierungen betrachtet

II Kebschull -

### 3.3.1 Analyse von Schaltwerken

- O Ein Schaltwerk zu analysieren bedeutet, sein Schaltverhalten durch
  - ⇒ eine Zustandstabelle
  - dessen Schaltfunktion oder
  - ⇒ einen Zustandsgraph zu beschreiben
- O Prinzipielles Vorgehen:
  - ⇒ von einem gegebenen Schaltplan werden zunächst die Ausgabe und Übergangsfunktion abgeleitet
- ⇒ ein Anfangszustand wird angenommen
- nit den Werten der Eingangsvariablen werden die Folgezustände abgeleitet
- ⇒ auf diese Weise entstehen die Ablauftabellen
- aus den Ablauftabellen kann der Automatengraph abgeleitet werden

### Beispiel: Ausgangspunkt - der Schaltplan

### O Grundlegende

### Charakterisierungen

- synchrones Schaltwerk
- $\Rightarrow$  Eingang x und Ausgang y bestehen je aus einer Variablen
- ⇒ das Schaltwerk enthält 2 D-Flipflops
- ⇒ es kann maximal 4 Zustände besitzen
- Das Schaltwerk ist ein Mealy-Automat



### Die Schaltfunktion

- O Aus dem Schaltplan läßt sich ablesen:
  - ⇒ für die Übergangsfunktion

$$z_0^+ = (\overline{z}_0 \wedge \overline{x}) \vee (\overline{z}_1 \wedge x)$$
  

$$z_1^+ = (z_0 \wedge \overline{z}_1) \vee (z_0 \wedge x) \vee (\overline{z}_0 \wedge z_1 \wedge \overline{x})$$

⇒ für die Ausgabefunktion

$$y = (z_0 \wedge z_1 \wedge \overline{x}) \vee (\overline{z}_0 \wedge z_1 \wedge x)$$

### Die Ablauftabelle und der Automatengraph

- O Aufstellen der Ablauftabelle über die Auswertung der Funktionen für  $z_0, z_1$ und v
  - ⇒ alle Belegungen der Eingangsvariablen
  - ⇒ alle Belegungen der Zustandsvariablen
- 0 0

0 0

- O Aufstellen des Automatengraphen über die Auswertung der Ablauftabelle
  - Beschriftung der Zustände und Übergänge nicht vergessen!



0

### 3.3.2 Entwurf von Schaltwerken

- O Prinzipielles Vorgehen:
  - ⇒ festlegen der Zustandsmenge
    - · daraus ergibt sich die Anzahl der erforderlichen Speicherglieder
  - ⇒ festlegen des Anfangszustands
  - Definition der Ein- und Ausgangsvariablen
  - Darstellung der zeitlichen Zustandsfolge in Form eines Zustandsgraphen
  - aufstellen der Ablauftabelle
  - ⇒ Herleitung der Übergangs- und Ausgabefunktionen
  - Darstellung der Übergangs- und Ausgabefunktionen in einem KV-Diagramm und Minimierung
  - Darstellung des Schaltwerks in einem Schaltplan

### Beispiel: ein umschaltbarer Zähler

- O Es soll ein zweistelliger Grav-Code-Zähler entworfen werden. der sowohl vorwärts als auch riickwärts zählen kann
- O Die Umschaltung der Zählrichtung erfolgt über die Eingangsvariable x
  - ⇒ für x=0 ist die Zählfolge 00 - 01 - 11 - 10
- ⇒ für x=1 ist die Zählfolge 00 - 10 - 11 - 01
- O Die Ausgangsvariablen sind Zustandsvariablen, da der Zählerstand angezeigt werden
  - ➡ Moore-Automat



Automatengraph

### 0 0

Ablauftabelle und die Übergangsfunktionen

- O Die Ablauftabelle kann direkt aus dem Automatengraph abgeleitet werden
  - ⇒ die linke Seite enthält alle Wertekombinationen, die zo. z. und x einnehmen können
  - ⇒ die rechte Seite enthält die Werte der Folgezustände



- O Aus der Ablauftabelle können die KV-Diagramme für zo und z aufgestellt werden
- O Aus den KV-Diagrammen lassen sich die minimierten Übergangsfunktionen ablesen



 $=(\overline{z}_0 \wedge x) \vee (z_0 \wedge \overline{x})$ 

 $=(\overline{z}_1 \wedge \overline{x}) \vee (z_1 \wedge x)$ 

### Das Schaltwerk

O Die minimierten Übergangsfunktionen können schließlich in einem Schaltplan gezeichnet werden

$$z_0^+ = (\overline{z}_0 \wedge x) \vee (z_0 \wedge \overline{x})$$

$$z_1^+ = (\overline{z}_1 \wedge \overline{x}) \vee (z_1 \wedge x)$$



II Kebschull

### 3.4 Technische Realisierung von Schaltwerken

- O Realisierung mit diskreten Bauelementen
  - ⇒ Verknüpfungsglieder
  - ⇒ Speicherglieder
- O Die Bauelemente werden entsprechend der Aufgabenstellung durch eine feste Verdrahtung miteinander verbunden
- O Solche Schaltwerksrealisierungen können nur eine feste Aufgabe erfüllen
  - das Schaltwerk ist nicht flexibel
  - ⇒ bei einem Fehler in der Verdrahtung kann keine Korrektur vorgenommen werden
- O Die Bauelemente stehen als integrierte Schaltkreise zur Verfügung

II Kebschull -

### Realisierung mit einem PLA

- O Programmable Logic Array
  - ⇒ technische Realisierung der DMF
  - UND- und ODER-Matrix sind frei programmierbar



Realisierung mit einem PAL

- O Programmable Array Logic
  - ⇒ die ODER-Matrix ist vorgegeben
  - s es steht eine feste Anzahl von Implikanten pro Ausgang zur Verfügung
- **⇒** die UND-Matrix ist programmierbar



Realisierung mit einem ROM

- O Technische Realisierung durch ein PROM, EPROM, EEPROM
- O Die UND-Matrix ist durch den Adressdekodierer vorgegeben
  - alle Minterme sind implementiert
  - direkte Implementierung der Funktionstabelle

| 0 | 0 | 0 | 0   |   |
|---|---|---|-----|---|
| 0 |   |   | U   | 1 |
|   | 0 | 1 | 1   | 1 |
| 0 | 1 | 1 | 1   | 0 |
| 0 | 1 | 0 | 0   | 0 |
| 1 | 0 | 0 | 1   | 0 |
| 1 | 1 | 0 | - 1 | 1 |
| 1 | 1 | 1 | 0   | 1 |
| 1 | 0 | 1 | 0   | 0 |



### Realisierung mit einem ROM

- O Auch die Ausgabefunktion kann mit einem ROM realisiert werden
  - ⇒ Wortorientierung des ROMs wird ausgenutzt
  - ➡ Mikroprogramm
- ⇒ mögliche Implementierung des Steuerwerke in Mikroprozessoren





- O Für die Implementierung komplexer Schaltungen werden häufig immer wieder kehrende Bausteintypen verwendet
- O Typische Schaltnetze sind
  - ⇒ Multiplexer/Demultiplexer
  - ⇒ Vergleicher
  - ⇒ Addierer
  - ➡ Multiplizierer
- O Typische Schaltwerke sind
  - ⇒ Register
  - ⇒ Schieberegister
  - ⇒ Zähler

### Multiplexer

- O Mehrere Eingänge, ein Ausgang
- O über n Steuerleitungen können 2n Eingänge ausgewählt und an den Ausgang durchgeschaltet werden



### **Demultiplexer**

O Ein Eingang wird auf einen aus 2n Ausgängen durchgeschaltet



### Vergleicher (Komparatoren)

- Vergleich zweier Zahlen
  - ⇒ A=B, A<B, A>B
- O Gleichheit bedeutet, dass alle Bits übereinstimmen



O 1-Bit Komparator mit Größenvergleich

| a | b | $y_{a>b}$ | ya= b | $y_{a < t}$ |
|---|---|-----------|-------|-------------|
| 0 | 0 | 0         | 1     | 0           |
| 0 | 1 | 0         | 0     | 1           |
| 1 | 0 | 1         | 0     | 0           |
| 1 | 1 | 0         | 1     | 0           |



### Komparatoren

O Serielle Erweiterung



O Parallele Erweiterung



### Addierer

Halbaddierer





### Addition mit seriellem Übertrag

O Der Übertrag des Volladdierers ü, wird mit c,, verbunden



### Addierer mit paralleler Übertragslogik

O Allgemein:

$$c_i = a_i b_i \vee (a_i \oplus b_i) c_{i-1}$$



### Multiplizierer

O Parallele Multiplikation durch Addierwerk

$$p = x \cdot y = \left(\sum_{i=0}^{n-1} x_i \cdot 2^i\right) \cdot \left(\sum_{i=0}^{n-1} y_j \cdot 2^j\right) = \sum_{i=0}^{n-1} \sum_{i=0}^{n-1} \cdot 2^{i+j} x_i y_j$$

O für n=3:  $(x_iy_i \text{ steht für } x_i \text{ UND } y_i)$ 





O Speicherung einer n-stelligen Zahl durch n Flipflops



### Schieberegister

- O Kette von Flipflons
- O Anwendungen:
  - Serien-Parallel-Wandlung
  - Parallel-Serien-Wandlung
  - FIFO oder Stapel-Speicher
  - ⇒ Multiplikation mit 2 oder Division durch 2
  - in mit Rückkopplung zur Erzeugung komplexer Signalfolgen (Sequenzer)



### Zähler

- O Einfacher Dualzähler durch Rückkopplung
- O Asynchroner Ripple Carry Zähler



O Synchroner Dualzähler durch Carry-Look-Ahead-Logik



### Zähler

O Praktische Ausführung eines Zählers



Kaskadierung eines Zählers



II Kebschull -

### Aufbau einer ALU



### **Bauelemente eines Rechnersystems**

- O Multiplexer und Demultiplexer zur Steuerung des Datenflusses
- O Zähler für die Programmsteuerung
- O ALU
  - ⇒ Register
  - ⇒ Addierer
  - ➡ Multiplizierer
  - ⇒ Schieberegister
- Speicherzellen
  - ⇒ RAM

⇒ ROM

### 5 Rechnerarithmetik

- O Die Rechnerarithmetik behandelt
  - die Darstellung von Zahlen
  - ⇒ Verfahren zur Berechnung der vier Grundrechenarten
  - Schaltungen, die diese Verfahren implementieren

### **5.1 Formale Grundlagen**

- O Menschen rechnen und denken im Dezimalsystem
- O Die meisten Rechner verwenden das Dualsystem
  - ⇒ man benötigt Verfahren der Konvertierung, die sich algorithmisch umsetzen lassen

### 7.1.1 Zahlensysteme

- Stellenwertsysteme
  - ⇒ jeder Position i der Ziffernreihe ist ein Stellenwert zugeordnet welcher der Potenz bi der Basis b eines Zahlensystems  $\textbf{entspricht} \qquad z_n z_{n-1} ... z_1 z_0 .z_{-1} z_{-2} z_{-m}$

 $\Rightarrow$  der Wert  $X_b$  ergibt sich aus der Summe der Werte aller Einzelstellen

$$X_b = z_n b^n + z_{n-1} b^{n-1} + \dots + z_1 b + z_0 + z_{-1} b^{-1} + z_{-2} b^{-2} + z_{-m} b^{-m} = \sum_{i=-m}^{n} z_i b^{i}$$

### Die wichtigsten Zahlensysteme

| b  | Zahlensystem      | Ziffern                       |
|----|-------------------|-------------------------------|
| 2  | Dualsystem        | 0, 1                          |
| 8  | Oktalsystem       | 0, 1, 2, 3, 4, 5, 6, 7        |
| 10 | Dezimalsystem     | 0, 1, 2, 3, 4, 5, 6, 7, 8, 9  |
| 16 | Hexadezimalsystem | 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, |
|    |                   | A, B, C, D, E, F              |

- O Dualsystem kann direkt auf 2-wertige Logik umgewandelt werden
- Oktal- und Hexadezimalsystem sind Kurzschreibweisen der Zahlen im Dualsystem
- ⇒ sie lassen sich leicht in Zahlen des Dualsystems umwandeln

### Umwandlung vom Dezimalsystem in ein Zahlensystem zur Basis b

### O Euklidischer Algorithmus

⇒ die einzelnen Ziffern werden sukzessive berechnet

$$\begin{split} Z &= z_n 10^n + z_{n-1} 10^{n-1} + ... + z_1 10 + z_0 + z_{-1} 10^{-1} + z_{-2} 10^{-2} + z_{-m} 10^{-m} \\ &= y_p b^p + y_{p-1} b^{p-1} + ... + y_1 b + y_0 + y_{-1} b^{-1} + y_{-2} b^{-2} + y_{-q} b^{-q} \end{split}$$

Algorithmus

- 1. Berechne P gemäß der Ungleichung  $b^{p-1} \le Z < b^p$
- 2. Ermittle  $y_n$  und den Rest  $R_n$  durch Division von Z durch  $b^p$  $y_p = Z \operatorname{div} b^p$ ;  $R_p = Z \operatorname{mod} b^p$ ;  $y_n = \{0, 1, ..., b-1\}$
- 3. Wiederhole 2. für i = p-1 und ersetze dabei nach jedem Schritt Z durch  $R_i$ , bis  $R_i$ =0 oder bis  $b_i$  klein genug ist

### Beispiel

Umwandlung von 15741.233., ins Hexadezimalsystem

| 1. Schritt | $16^3 \le 15741,233_{10} < 16^4$ | höchste Potenz 163 |
|------------|----------------------------------|--------------------|
| 2. Schritt | $15741,233_{10}:16^3=3$          | Rest 3453,233      |
| 3. Schritt | $3453,233:16^2 = D$              | Rest 125,233       |
| 4. Schritt | 125,233 : 16 = 7                 | Rest 13,233        |
| 5. Schritt | 13,233 : 1 = D                   | Rest 0,233         |
| 6. Schritt | $0,233:16^{-1}=3$                | Rest 0,0455        |
| 7. Schritt | $0,0455:16^{-2}=B$               | Rest 0,00253       |
| 8. Schritt | $0,00253:16^{-3}=A$              | Rest 0,000088593   |
| 9. Schritt | 0,000088593:16-4=5               | Rest 0,000012299   |
|            |                                  | Fehl               |

**Ergebnis:**  $15741,233_{10} = 3D7D,3BA5_{16}$ 

II Kebschull -

### Umwandlung vom Dezimalsystem in eine Zahl zur Basis b

- O Horner-Schema
  - $\Rightarrow$  Eine ganze Zahl  $X_b$  kann auch in der folgenden Form dargestellt werden:

$$X_b = ((...(((y_nb + y_{n-1})b + y_{n-2})b + y_{n-3})b...)b + y_1)b + y_0$$

- O Die gegebene Dezimalzahl wird sukzessive durch die Basis b dividiert
- Die jeweiligen ganzzahligen Reste ergeben die Ziffern der Zahl X<sub>b</sub>
- ⇒ Reihenfolge: niederwertige zur höchstwertige Stelle
- O Beispiel: Umwandlung von 15741<sub>10</sub> ins Hexadezimalsystem

| $15741_{10}: 16 = 983$ | Rest 13 | $(D_{16})$         |
|------------------------|---------|--------------------|
| $983_{10}:16=61$       | Rest 7  | (7 <sub>16</sub> ) |
| $61_{10}: 16 = 3$      | Rest 13 | $(D_{16})$         |
| $3 \cdot 16 = 0$       | Rest 3  | (3)                |

**Ergebnis:**  $15741_{10} = 3D7D_{16}$ 

### Umwandlung des Nachkommateils

O Der Nachkommateil einer Zahl X, kann in der folgenden Form dargestellt werden

$$Y_b = ((...((y_{-m}b^{-1} + y_{-m+1})b^{-1} + y_{-m+2})b^{-1} + ... + y_{-2})b^{-1} + y_{-1})b^{-1}$$

- O sukzessive Multiplikation des Nachkommateils der Dezimalzahl mit der Basis b des Zielsystems ergibt nacheinander die  $y_{.i}$
- O Beispiel: Umwandlung von 0,233<sub>10</sub> ins Hexadezimalsystem

| 0,233 * 16 | = 3,728  | $z_{-1} = 3$ |
|------------|----------|--------------|
| 0,728 * 16 | = 11,648 | $z_{-2} = 1$ |
| 0,648 * 16 | = 10,368 | $z_{-3} = 1$ |
| 0.368 * 16 | = 5,888  | $z_A = 3$    |

**Ergebnis:**  $0,233_{10} = 0,3BA5_{16}$ 

II Kebschull -

### Umwandlung einer Zahl zur Basis b ins Dezimalsystem

- O Werte der einzelnen Stellen werden mit deren Wertigkeit multipliziert und aufsummiert
- O Beispiel: Umwandlung von 101101,1101 ins Dezimalsystem 101101,1101

$$\begin{array}{rcl}
 1 * 2^{4} & = & 0.0625 \\
 0 * 2^{2} & = & 0 \\
 1 * 2^{2} & = & 0.25 \\
 1 * 2^{1} & = & 0.5 \\
 1 * 2^{0} & = & 1 \\
 0 * 2^{1} & = & 0 \\
 1 * 2^{2} & = & 4 \\
 1 * 2^{3} & = & 8 \\
 0 * 2^{4} & = & 0 \\
 1 * 2^{5} & = & 32
 \end{array}$$

II Kebschull -

45,812510

### Weitere Umwandlungen

- O Umwandlung zwischen zwei beliebigen Zahlensystemen
  - ⇒ zwei Schritte: Umwandlung ins Dezimalsystem und danach vom Dezimalsystem ins Zielsystem
- O Spezialfall: Eine Basis eine Potenz der anderen Basis
  - Umwandlung erfolgt durch Zusammenfassen der Stellen
  - ⇒ Beispiel: Umwandlung von 0110100,110101, ins Hexadezimalsystem

0011 0100, 1101 0100 4, D

### 5.1.2 Kodierung zur Zahlen- und Zeichendarstellung

- O Die Dezimalzahlen können auch ziffernweise in eine Binärdarstellung überführt werden
  - ⇒ um die 10 Ziffern 0 bis 9 darstellen zu können, benötigt man
  - ⇒ eine solche 4er-Gruppe wird Tetrade genannt
  - ⇒ Pseudotetraden: 6 der 16 Kodierungen stellen keine gültigen Ziffern dar
- O BCD
  - Binary Coded Decimals
  - nan verwendet das Dualäquivalent der ersten 10 Dualzahlen
  - Beispiel:

 $8127_{10} = 1000\ 0001\ 0010\ 0111_{BCD} = 1111110111111_2$ 

- Nachteile der BCD-Kodierung
  - · höherer Platzbedarf
  - · aufwändige Implementierung der Rechenoperationen

### **Grav-Kodierung**

| O Einschrittige Kodierung | Dezimalzahl | Gray-Codierung |
|---------------------------|-------------|----------------|
| ⇒ bei benachbarten Zahlen | 0           | 0000           |
| ändert sich nur ein       | 1           | 0001           |
| Binärzeichen              | 2           | 0011           |
|                           | 3           | 0010           |
| O Vorteil                 | 4           | 0110           |
| keine Hazards bei der     | 5           | 0111           |
| Analog/Digitalwandlung    | 6           | 0101           |
| und bei Abtastern         | 7           | 0100           |
| O Nachteil                | 8           | 1100           |
| ⇒ keine Stellenwertigkeit | 9           | 1101           |
| ⇒ aufwändige              | 10          | 1111           |
| Rechenoperationen         | 11          | 1110           |
| Rechenoperationen         | 12          | 1010           |
|                           | 13          | 1011           |
|                           | 14          | 1001           |
|                           | 15          | 1000           |

### Kodierung von Zeichen

- O American Standard Code for Information Interchange (ASCII)
  - ⇒ 7 Bit-Kodierung für 128 Zeichen
  - ⇒ 2\*26 Zeichen, 10 Ziffern und
  - 32 Kommunikationssteuerzeichen
- Umlaute und Sonderzeichen sind nicht enthalten
  - ⇒ 8-Bit Erweiterungen unterschiedlicher Computerhersteller
  - Andere Verwendung des 8. Bits: Paritätsprüfung

U. Kebschull

115

### ASCII-Tabelle

|      | 000 | 001  | 010   | 011 | 100 | 101 | 110 | 111 |
|------|-----|------|-------|-----|-----|-----|-----|-----|
| 0000 | NUL | DLE  | SPACE | 0   | @   | P   | ,   | p   |
| 0001 | SOH | DC I | 1     | 1   | A   | Q   | a   | q   |
| 0010 | STX | DC 2 |       | 2   | В   | R   | ь   | r   |
| 0011 | ETX | DC 3 | #     | 3   | С   | S   | С   | s   |
| 0100 | EOT | DC 4 | \$    | 4   | D   | T   | d   | t   |
| 0101 | ENQ | NAK  | %     | 5   | Е   | U   | e   | u   |
| 0110 | ACK | SYN  | &     | 6   | F   | V   | f   | v   |
| 0111 | BEL | ETB  | ,     | 7   | G   | W   | g   | w   |
| 1000 | BS  | CAN  | (     | 8   | Н   | Х   | h   | x   |
| 1001 | HT  | EM   | )     | 9   | I   | Y   | i   | у   |
| 1010 | LF  | SUB  | *     | :   | J   | Z   | j   | z   |
| 1011 | VT  | ESC  | +     | ;   | K   | [   | k   | {   |
| 1100 | FF  | FS   |       | <   | L   | 1   | 1   | 1   |
| 1101 | CR  | GS   | -     | =   | M   | ]   | m   | }   |
| 1110 | so  | RS   |       | >   | N   | ^   | n   |     |
| 1111 | SI  | US   | 1     | ?   | 0   | _   | 0   | DEL |

Die höchstwertigen Bits der Kodierung eines Zeichens sind in der Kopfzeile abzulesen, die niederwertigen Bits in der ersten Spalte (Beispiel: A  $\rightarrow$  100 0001<sub>2</sub>).

### Paritätsprüfung

- O Problem:
  - ⇒ Erkennung von Übertragungsfehlern
- - ⇒ die 7-Bit Kodierung wird beim Sender so auf 8 Bit ergänzt. dass stets eine gerade (ungerade) Anzahl von Einsen ergänzt
  - gerade (ungerade) Parität
  - ⇒ beim Empfänger wird diese Eigenschaft überprüft
  - falls bei der Übertragung ein Bitfehler auftritt, wird dieser



### 5.1.3 Darstellung negativer Zahlen

- O Für die Darstellung von Zahlen in Rechnern werden vier verschiedene Formate benutzt
  - Darstellung mit Betrag und Vorzeichen
  - Stellenkomplement (Einerkomplement)
  - ⇒ Zweierkomplement
  - ⇒ Offset-Dual-Darstellung (Charakteristik)

### Darstellung mit Betrag und Vorzeichen

- O Die erste Stelle der Zahl wird als Vorzeichen benutzt
  - O: Die Zahl ist positiv
  - ⇒ 1: Die Zahl ist negativ
- O Beispiel:
  - □ 0001 0011 = + 19
  - ⇒ 1001 0011 = 19
- O Nachteile dieser Darstellung
  - ⇒ bei Addition und Subtraktion müssen die Vorzeichen getrennt betrachtet werden
  - ⇒ es gibt 2 Repräsentanten der Zahl 0
    - · positives und negatives Vorzeichen

II Kebschull

### **Einerkomplement**

- O Jede Ziffer der Binärzahl wird negiert
- negative Zahlen werden ebenfalls durch eine 1 an der 1. Stelle gekennzeichnet
- O Vorteil:
  - Die 1. Stelle muss bei Addition und Subtraktion nicht gesondert betrachtet werden
- O Beispiel:

|   | 2  | 0010   |              |       |
|---|----|--------|--------------|-------|
| + | -3 | + 1100 | (Komplement: | 0011) |
| = | -1 | = 1110 | (Komplement: | 0001) |

- O Nachteil:
  - ⇒ es gibt 2 Repräsentanten der Zahl 0:
    - · 0000 und 1111

II Kebschull -

### Zweierkomplement

- O Addiert man zum Einerkomplement noch 1 hinzu, dann fallen die beiden Darstellungen der Zahl 0 durch den Überlauf wieder aufeinander
  - Die Zahl 0 0000
  - ⇒ Einerkomplement 1111
  - ⇒ Zweierkomplement 1111 + 0001 = 0000
- Vorteile
  - ⇒ das 1. Bit enthält das Vorzeichen
  - ⇒ direkte Umwandlung der Zahl Z über die Stellenwertigkeit
- **Deispiel**  $Z = -z_n \cdot 2^n + z_{n-1} \cdot 2^{n-1} + ... + z_1 \cdot 2 + z_0$
- Die Zahl 54 = 00110110,
- nit Vorzeichenbit  $-54_{10} = 10110110_{2}$
- = 11001001, **⇒** Einerkomplement
- ⇒ Zweierkomplement = 11001010,

II Kebschull

### Addition im Zweierkomplement

### O Beispiel:

| = 19 | (1)00010011 |
|------|-------------|
| -54  | 11001010    |
| 73   | 01001001    |

O Beispiel:

| 37    | 00100101 |            |
|-------|----------|------------|
| -54   | 11001010 |            |
| = -17 | 11101111 | (00010001) |

Charakteristik

- O Hauptsächlich in der Darstellung von Exponenten für Gleitkommazahlen
  - der gesamte Zahlenbereich wird durch die Addition einer Konstanten so nach oben verschoben, dass die kleinste Zahl die Darstellung 0...0 erhält
- Übersicht der Zahlendarstellungen

| Dez. | Betrag mit Vorz. | Einerkomp.   | Zweierkomp. | Charakteristik |
|------|------------------|--------------|-------------|----------------|
| -4   |                  |              | 100         | 000            |
| -3   | 111              | 100          | 101         | 001            |
| -2   | 110              | 101          | 110         | 010            |
| -1   | 101              | 110          | 111         | 011            |
| 0    | 100 oder 000     | 000 oder 111 | 000         | 100            |
| 1    | 001              | 001          | 001         | 101            |
| 2    | 010              | 010          | 010         | 110            |
| 3    | 011              | 011          | 011         | 111            |

### **5.1.4 Fest- und Gleitkommazahlen**

- O Darstellung von Zahlen mit einem Komma
- Festkommadarstellung
  - Festlegung der Stelle in einem Datenwort

0 1 0 1 1 0 0 1 0 1 0 0 0 0

wird heute hardwareseitig nicht mehr eingesetzt

Gleitkommadarstellung

Angabe der Stelle des Kommas in der Zahlendarstellung

 $Z = +Mantisse \cdot h^{Exponent}$ ,  $h \in \{2.16\}$ 

negative Zahlen werden meist in Betrag und Vorzeichen dargestellt (kein Zweierkomplement)

sowohl für die Mantisse als auch für die Charakteristik wird eine feste Anzahl von Speicherstellen vorgesehen

Vz Charakteristik Mantisse

124

### Normalisierte Gleitkommadarstellung

 Eine Gleitkommazahl heißt normalisiert, wenn die folgende Beziehung gilt:

 $\frac{1}{2} \le \text{Mantisse} < 1$ 

- $\Rightarrow$  bei allen Zahlen außer der 0 ist die erste Stelle hinter dem Komma immer 1
- ⇒ legt man für die Zahl 0 ein festes Bitmuster fest, kann man die erste 1 nach dem Komma weglassen
- O Beispiel: Die Zahl 7135<sub>10</sub>
  - ⇒ Festkommazahl
  - 0 000 0000 0000 0000 0001 1011 1101 1111,
  - Gleitkommadarstellung, normiert

0 100 0110 1 110 1111 0111 1100 0000 0000

⇒ Gleitkommadarstellung, normiert, implizite erste 1

0 | 100 | 0110 | 1 | 101 | 1110 | 1111 | 1000 | 0000 | 0000 |

Fechnische Informatik 2

and SS 02

U. Kebschull

### IEEE Gleitkommadarstellung

- O Auch bei gleicher Wortbreite lassen sich unterschiedliche Gleitkommaformate definieren
  - Normung durch IEEE
  - ⇒ einfache Genauigkeit (32 Bit)

|    | 30 23          | 322 0    |
|----|----------------|----------|
| Vz | Charakteristik | Mantisse |

⇒ doppelte Genauigkeit (64 Bit)

- Eigenschaften
  - Basis b ist gleich 2
  - das erste Bit wird implizit zu 1 angenommen, wenn die Charakteristik nicht nur Nullen enthält
  - Es wird so normalisiert, dass das erste Bit vor dem Komma

U. Kebschul

Stand SS 02

### IEEE Gleitkommadarstellung

O Zusammenfassung des 32-bit IEEE-Formats:

| Charakteristik | Zahlenwert                                     |
|----------------|------------------------------------------------|
| 0              | (-1)Vz 0,Mantisse*2-126                        |
| 1              | (-1)Vz 1,Mantisse*2-126                        |
|                | (-1)Vz 1,Mantisse*2Charakteristik-127          |
| 254            | (-1) <sup>Vz</sup> 1,Mantisse*2 <sup>127</sup> |
| 255            | Mantisse = 0: overflow, (-1) <sup>Vz</sup> ∞   |
| 255            | Mantisse ≠ 0: NaN (not a number)               |

 Um Rundungsfehler zu vermeiden, wird intern mit 80 Bit gerechnet

U. Kebschu

### 5.2 Addition und Subtraktion

- Addition erfolgt Hilfe von Volladdierern wie im letzten Abschnitt beschrieben
  - Ripple-Carry oder Carry-Look-Ahead Addierer
- Für die Subtraktion können ebenfalls Volladdierer verwendet werden
  - $\Rightarrow$  X -Y = X + (-Y)
  - ⇒ Zweierkomplement berechnet sich über die Negation aller Bits mit einer 1 am ersten Übertrag des Addierers
- Bei Gleitkommazahlen müssen Mantisse und Exponent separat betrachtet werden
  - Angleichen der Exponenten: Bilde die Differenz der Exponenten und verschiebe die Mantisse, die zum kleineren Exponenten gehört um die entsprechende Anzahl nach rechts
  - Addition der Mantissen
  - ⇒ Normalisierung

U. Kebschull

### 5.3 Multiplikation und Division

- O Prinzip der Multiplikation: Schieben und Addieren
- O Multiplikation von Zahlen im Zweierkomplement:
  - die Zahlen werden in eine Form mit Betrag und Vorzeichen konvertiert
  - ⇒ die Beträge werden Multipliziert (kaskadiertes Addierwerk)
  - ⇒ das neue Vorzeichen wird berechnet (Exklusiv-ODER-Verknüpfung)
- O Prinzip der Division: Schieben und Subtrahieren
  - ⇒ zwei Sonderfälle:
    - · Division durch 0 muss eine Ausnahme auslösen
    - Die Division muss abgebrochen werden, wenn die vorgegebene Bitzahl des Ergebnisregisters ausgeschöpft ist

U. Kebschull
chrische Informatik 2
Stand SS 02

### 6 Ein einfacher Rechner

- O Erweiterung von Steuerwerken
  - ⇒ Ein Steuerwerk bestimmt den Ablauf der Berechnung
  - Der Datenpfad bestimmt den Fluss der Operanden und Ergebnisse
  - Daten und Programm stehen in einem gemeinsamen Speicher



- O VonNeumann Architektur
  - ⇒ Ein-/Ausgabe
  - ⇒ Speicher
  - ⇒ Rechenwerk
  - ⇒ Leitwerk (Steuerwerk)

U. Rebschull —

Stand SS 02 13:

### VonNeumann Architektur



### Befehlsablauf im vonNeumann-Rechner

- Lesen
  - ⇒ Einen neuen Programmzähler-Wert (PC) bestimmen
  - Bestimmung der Speicheradresse des Quelloperanden
  - Desezugriff auf den Speicher
  - ⇒ Speichern des gelesenen Wertes im Zielregister
- Schreiben
  - ⇒ Einen neuen Programmzähler-Wert (PC) bestimmen
  - ⇒ Bestimmung der Speicheradresse des Zieloperanden
  - Desezugriff auf das Quellregister
  - Schreibzugriff auf den Speicher

### Befehlsablauf im vonNeumann-Rechner

- Verknüpfung von Operanden
- ⇒ Einen neuen Programmzähler-Wert (PC) bestimmen
- Auslesen der Operanden aus dem Registerblock
- ⇒ Verknüpfung der Operanden in der ALU
- Schreiben des Ergebnisses in den Registerblock
- O Verzweigungen und Sprünge
- ⇒ Einen neuen Programmzähler-Wert (PC) bestimmen
- Berechnung der Adresse des Sprungziels
- Prüfung der Sprungbedingung (bei Verzweigungen)
- Überschreiben des Befehlszählers, wenn der Sprung ausgeführt werden soll

U. Kebschull U. Kebschull

### **Der Toy-Prozessor**

- O Implementierung einer einfachen VonNeumann-Architektur
  - Duelle: Phil Kopmann, Microcoded versus Hard-Wired Logic
  - ⇒ Byte Januar 87, S. 235
  - infacher aber vollständiger Mikrorechner
  - ⇒ einfacher Aufbau mit Standardbausteinen
- O RISC-Rechner
  - ⇒ alle Befehle in einem Takt (2 Phasen Takt)
  - ⇒ sehr einfacher Befehlssatz (12 Befehle)

U. Kebschull

Technirche Informatik 2

Stand SS 02

136

### Spezifikation des Toy-Rechners

- 1-Adress-Maschine (nur ein Register)
  - ⇒ Ein Quelloperand kommt aus dem Speicher
  - Der zweite Operand kommt aus dem Akku
  - ⇒ Zielregister ist immer der Akkumulator (ACCU)

OP-Code Speicher-Adresse

Befehlsformat

 OP-Code
 Adresse

 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0

O Komponenten (Speicher CPU)

RAM: 4096 \* 16 Bit ALU: 4 \* 74181 ALU-Baustein

ACC: Register
IR: Instruktionsregister
PC: Programmzähler

MUX: Multiplexer

U. Kebschull

### Blockschaltbild des Toy-Rechners



### Befehlssatz

| Opco | de Opera | tion                | Beschreibung                                          |
|------|----------|---------------------|-------------------------------------------------------|
| 0    | STO      | <adresse></adresse> | speichere den ACCU ins RAM an die Adresse             |
| 1    | LDA      | <adresse></adresse> | lade ACCU mit dem Inhalt der Adresse                  |
| 2    | BRZ      | <adresse></adresse> | springe nach Adresse, wenn der ACCU Null ist          |
| 3    | ADD      | <adresse></adresse> | addiere den Inhalt der Adresse zum ACCU               |
| 4    | SUB      | <adresse></adresse> | subtrahiere den Inhalt der Adresse vom ACCU           |
| 5    | OR       | <adresse></adresse> | logisches ODER des ACCUS mit dem Inhalt der Adresse   |
| 6    | AND      | <adresse></adresse> | logisches UND des ACCUS mit dem Inhalt der Adresse    |
| 7    | XOR      | <adresse></adresse> | logisches ExODER des ACCUS mit dem Inhalt der Adresse |
| 8    | NOT      |                     | logisches NICHT der Bits im ACCU                      |
| 9    | INC      |                     | inkrementiere den ACCU                                |
| 10   | DEC      |                     | dekrementiere den ACCU                                |
| 11   | ZRO      |                     | setze den ACCU auf NULL                               |
| 12   | NOP      |                     | nicht benutzt                                         |
| 13   | NOP      |                     | nicht benutzt                                         |
| 14   | NOP      |                     | nicht benutzt                                         |
| 15   | NOP      |                     | nicht benutzt                                         |

U. Kebschull

### Spezifikation der Befehle

| OpCode                  | Operation | Zyklus Beschreibung            |
|-------------------------|-----------|--------------------------------|
| 0                       | STO 1     | ADDR=IR; ALU=ACC; WRITE(RAM)   |
|                         | 2         | ADDR=PC; SET(IR); INC(PC)      |
| 1                       | LDA 1     | ADDR=IR; ALU=RAM; SET(ACC)     |
|                         | 2         | ADDR=PC; SET(IR); INC(PC)      |
| 2                       | BRZ 1     | SET[PC]                        |
|                         | 2         | ADDR=PC; SET(IR); INC(PC)      |
| 3                       | ADD 1     | ADDR=IR; ALU=ACC+RAM; SET(ACC) |
|                         | 2         | ADDR=PC; SET(IR); INC(PC)      |
|                         |           |                                |
| 9                       | INC 1     | ALU=ACC+1; SET(ACC)            |
|                         | 2         | ADDR=PC; SET(IR); INC(PC)      |
| •••                     |           |                                |
| 12-15                   | NOP 1     | ADDR=PC; SET(IR); INC(PC)      |
|                         | 2         |                                |
| Technische Informatik ? |           | U. Kebschull                   |
| ecnnische informatik 2  |           | Stand SS 02 14                 |

### Ablaufsteuerung



### **Komponente 1: Der Taktgenerator**



### Komponente 2: Die ALU



### Komponente 3: Der Befehlszähler



### Das Steuerwerk als ROM



### **Ablauf eines Maschinenbefehls**

O Ab der Speicherstelle \$0007 steht die Befehlssequenz:

\$0007: \$3020 ; ADD <\$20> \$0008: \$0030 ; STO <\$30>

- O Der Akkuinhalt ist \$1234.
- O Der Inhalt der Speicherstelle \$20 ist \$4321
- O Wie werden die Befehle abgearbeitet?

U. Kebschull 

technische Informatik 2 Stand SS 02 

U. Kebschull

### Ablauf eines Maschinenbefehls (Phase 1) ADDR=IR: ALU=ACC+RAM: SET(ACC) ACCU \$3020; ADD <\$20> 16 Bit Opcode \$1234 12 Bit WRITE[RAM] \$7 → WRITE[F → INC[PC] → SET[PC] → ADDR=IR → SET[IR] Steuerwerk SET[ACCU] ALUCIN Programm/ Mikroprogramm-ALUCIN ALUMODE ALU3 ALU2 ALU1 ALU1 Daten speicher 4K Worte zu je 16 Bit → ALU0 U. Kebschull

### Ablauf eines Maschinenbefehls (Phase 2)



### Assemblierung des Programms

| 0                   | 0    | STO | Beispiel: LDA <\$20>                             |
|---------------------|------|-----|--------------------------------------------------|
| 1                   | 1    | LDA |                                                  |
| 2                   | 2    | BRZ | 1 0 2 0                                          |
| 3                   | 3    | ADD |                                                  |
| 4                   | 4    | SUB |                                                  |
| 5                   | 5    | OR  |                                                  |
| 6                   | 6    | AND | \$1020                                           |
| 7                   | 7    | XOR |                                                  |
| 8                   | 8    | NOT |                                                  |
| 9                   | 9    | INC |                                                  |
| 10                  | A    | DEC | Assemblieren:                                    |
| 11                  | В    | ZRO | Assembler als Kommentar schreiben                |
| 12                  | С    | NOP | Adressen der Labels für Sprünge feststellen      |
| 13                  | D    | NOP |                                                  |
| 14                  | Е    | NOP | Adressen für Variablen festlegen                 |
| 15                  | F    | NOP | Hexcode aus OP-Codetabelle und aus Labels/Varia- |
|                     |      |     | blenadressen berechnen                           |
|                     |      |     | U Kebschull                                      |
| To bein be laforest | 1. 2 |     | Stand SS 02 149                                  |

### Ein Beispielprogramm

147

| ; Loopcou<br>: Labels: | ınt=\$20, Number=\$21 | (enthaelt zunaechst 0)                             |
|------------------------|-----------------------|----------------------------------------------------|
|                        | 2, end=\$b            |                                                    |
| ;                      | , ,                   |                                                    |
| \$0020                 | ; STO Loopcount       | <pre>; Auswerten des initialen ; Accuinhalts</pre> |
| \$200b                 |                       | ; Schon fertig?                                    |
| #<br>#loop:            |                       |                                                    |
| #100p.<br>\$1021       | · IDA Number          | ; nat. Zahl mitzaehlen                             |
| \$9000                 | ; INC                 | , nac. Bani miczaenien                             |
| \$0021                 | : STO Number          |                                                    |
| \$1020                 | ; LDA Loopcount       | ; Schleifenzaehler aktualisierer                   |
| \$a000                 | : DEC                 | , beniellenzaeniel aktualibielei                   |
| \$0020                 | ; STO Loopcount       |                                                    |
| \$200b                 | ; BRZ end             | ; Fertig?                                          |
| \$b000                 | : ZRO                 | ; Nein,                                            |
| \$2002                 | ; BRZ loop            | ; dann wieder von vorn                             |
|                        | ,                     |                                                    |
| #end:                  |                       |                                                    |
| \$b000                 | ; ZRO                 |                                                    |
| \$200c                 | ; BRZ end             | : Endlosschleife                                   |

### Unterschiede zu realen Rechnern

|                     | Toy Rechner           | reale Prozessoren         |
|---------------------|-----------------------|---------------------------|
| Wortlänge           | 16 BitDaten           |                           |
|                     | 12 Bit Adresssen      | bis 100 Bit               |
| Mikroinstruktionen  | 1 Routine             | mehrere Routinen          |
|                     | pro Maschinenbefehl   | pro Maschinenbefehl       |
| Umfang des          | 384 Bit               | 300 000 Bit               |
| Mikroprogramms      |                       |                           |
| Verzweigungsbefehle | 1 Verzweigungsbefehl  | 10-33 Verzweigungsbefehle |
| Adressierungsmodi   | 1 Addressierungsmodus | 1-21 Addressierungsmodi   |
| Befehlssatz         | 12 Befehle            | 100 - 300 Befehle         |
| Registersatz        | 1 Register (Akku)     | 32 - 512 Register         |

### 7 Aufbau von Rechnersystemen



### Hauptkomponenten der Zentraleinheit



ische Informatik 2 Stand SS 02 151







- O Ablaufsteuerung der Befehlsbearbeitung im Operationswerk
- O Synchrones Schaltwerk
- O Komponenten eines typischen Steuerwerks
- Befehlsdekodierer: analysiert und entschlüsselt den aktuellen Befehl
- ⇒ Steuerung: generiert die Signale für das Rechenwerk
- Befehlsregister: speichert den aktuellen Befehl
- ⇒ Steuerregister: liefert Bedingungen zur Entscheidung des Befehlsablaufs
- O Festverdrahtetes Steuerwerk
  - das Steuerwerk wird als System mehrstufiger logischer Gleichungen implementiert und minimiert
- O Mikroprogrammiertes Steuerwerk
  - das Steuerwerk wird in einem ROM implementiert
- O Mikroprogrammierbares Steuerwerk
  - ⇒ das Steuerwerk wird in einem RAM implementiert und wird beim Neustart des Prozessors geladen

U. Kebschull —
Informatik 2 Stand SS 02 156

### Mikroprogrammierung

- → Mikrooperationen
   ⇒ elementare Operationen wie das Setzen eines Registers
- Mikrobefehle
  - Zusammenfassung bestimmter Mikrooperationen, die zu einem Taktzeitpunkt gleichzeitig ausgeführt werden können
- Mikroprogrammierung
  - Realisierung der Maschinenbefehle durch durch eine Folge von Elementaroperationen



U. Kebschull

### Vertikale und horizontale Mikroprogrammierung



### Mischformen

 Unabhängige Teile des horizontalen Mikrobefehlsworts werden zusammengefaßt und vertikal kodiert



Das Steuerwerk des Intel 486



Das Rechenwerk

O ALU

⇒ berechnet alle Operationen

Akkumulator

speichert das Ergebnis einer Operation

⇒ stellt einen Operanden zur Verfügung

Hilfsregister

⇒ stellt den zweiten Operanden zur Verfügung

Statusregister

⇒ Speichert besondere Ergebnisse



### Das Statusregister

O Einzelne logisch unabhängige Bits

□ CF (Carry Flag) Übertrag

Cr (Carry Flag) Obertra

⇒ ZF (Zero Flag) Ergebnis der letzten Operation ist 0
 ⇒ SF (Sign Flag) negatives Ergebnis bei der letzten

Operation

⇒ OF (Overflow Flag) Überlauf bei der letzten Operation

⇒ EF (Even Flag) Gerades Ergebnis bei der letzten

Operation

⇒ PF (Parity Flag) ungerade Anzahl der ´1´-Bits

 $oldsymbol{\bigcirc}$  Diese Flags werden bei bedingten Sprüngen ausgewertet

### Transfer- und Ein-/Ausgabebefehle

| Mnemonic   | nic Bedeutung                                            |             |  |
|------------|----------------------------------------------------------|-------------|--|
| LD         | Laden eines Register                                     | (load)      |  |
| LEA        | Laden eines Registers mit der Adresse eines Operanden    |             |  |
|            | (load effects                                            | ve address) |  |
| ST         | Speichern des Inhalts eines Registers                    | (store)     |  |
| MOVE       | Übertragen eines Datums (in beliebiger Richtung)         |             |  |
| EXC        | Vertauschen der Inhalte zweier Register bzw.             |             |  |
|            | eines Registers und eines Speicherwortes                 | (exchange)  |  |
| TFR        | Übertragen eines Registerinhalts in ein anderes Register | (transfer)  |  |
| PUSH       | Ablegen des Inhalts eines oder mehrerer Register im Sta  | ck ,        |  |
| PULL (POP) | Laden eines Registers bzw. mehrerer Register aus dem S   |             |  |
| STcc       | Speichern eines Registerinhaltes, falls die Bedingung co |             |  |
|            | (nach Tabelle 1.14-11) erfüllt ist                       |             |  |

| Mnemonic   | Bedeutung                                                    |
|------------|--------------------------------------------------------------|
| IN, READ   | Laden eines Registers aus einem Peripheriebaustein           |
| OUT, WRITE | Übertragen eines Registerinhalts in einen Peripheriebaustein |

### Arithmetische und Logische Befehle

| Mnemonic | Bedeutung                                        |                   |
|----------|--------------------------------------------------|-------------------|
| ABS      | Absolutbetrag bilden                             | (absolute)        |
| ADD      | Addition ohne Berücksichtigung des Übertrags     | (add)             |
| ADC      | Addition mit Berücksichtigung des Übertrags      | (add with carry)  |
| CLR      | Löschen eines Registers oder Speicherwortes      | (clear)           |
| CMP      | Vergleich zweier Operanden                       | (compare)         |
| сом      | bitweises Invertieren eines Operanden            | (                 |
|          | (Einerkomplement)                                | (complement)      |
| DAA      | Umwandlung eines dualen Operanden in eine De     |                   |
|          |                                                  | decimal adjust A) |
| DEC      | Register oder Speicherwort dekrementieren        | (decrement)       |
| DIV      | Division                                         | (divide)          |
| INC      | Register oder Speicherwort inkrementieren        | (increment)       |
| MUL      | Multiplikation                                   | (multiply)        |
| NEG      | Vorzeichenwechsel im Zweierkomplement            | (negate)          |
| SUB      | Subtraktion ohne Berücksichtigung des Übertrags  |                   |
| SBC      | Subtraktion mit Berücksichtigung des Übertrags ( |                   |

| Mnemonic | Bedeutung                                 |                |
|----------|-------------------------------------------|----------------|
| AND      | UND-Verknüpfung zweier Operanden          |                |
| OR       | ODER-Verknüpfung zweier Operanden         |                |
| EOR      | Antivalenz-Verknüpfung zweier Operanden   | (exclusive or) |
| NOT      | Invertierung eines (Booleschen) Operanden |                |

U. Kebschull

### Flag- und Bit-Manipulationsbefehle

| Mnemonic   | Bedeutung                               |                  |
|------------|-----------------------------------------|------------------|
| SE <f></f> | Setzen eines Bedingungs-Flags           | (set)            |
| CL <f></f> | Löschen eines Bedingungs-Flags          | (clear)          |
| BSET       | Setzen eines Bits                       | (bit set)        |
| BCLR       | Rücksetzen eines Bits                   | (bit clear)      |
| BCHG       | Invertieren eines Bits                  | (bit change)     |
| TST        | Prüfen eines bestimmten Flags oder Bits | (test)           |
| BF         | Bitfeld-Befehle,<br>insbesondere:       |                  |
| BFCLR      | Zurücksetzen der Bits auf '0'           | (clear)          |
| BFSET      | Setzen der Bits auf '1'                 | (set)            |
| BFFFO      | Finden der ersten '1' in einem Bitfeld  | (find first one) |
| BFEXT      | Lesen eines Bitfeldes                   | (extract)        |
| BFINS      | Einfügen eines Bitfeldes                | (insert)         |

(<f> Abkürzung für ein Flag, z.B. C carry flag)

### Schiebe- und Rotationsbefehle

| Mnemonic | Bedeutung                                        |                           |
|----------|--------------------------------------------------|---------------------------|
| SHF      | Verschieben eines Registerinhaltes insbesondere: | (shift)                   |
| ASL      | arithmetische Links-Verschiebung                 | (arithm. shift left)      |
| ASR      | arithmetische Rechts-Verschiebung                | (arithm. shift right)     |
| LSL      | logische Links-Verschiebung                      | (logical shift left)      |
| LSR      | logische Rechts-Verschiebung                     | (logical shift right)     |
| ROT      | Rotation eines Registerinhaltes insbesondere:    | (rotate)                  |
| ROL      | Rotation nach links                              | (rotate left)             |
| RCL      | Rotation nach links durchs Übertragsbit          | (rotate with carry left)  |
| ROR      | Rotation nach rechts                             | (rotate right)            |
| RCR      | Rotation nach rechts durchs Übertragsbit         | (rotate with carry right) |
| SWAP     | Vertauschen der beiden Hälften eines Re          | gisters                   |

U. Kebschull

### Befehle zur Programmsteuerung

### Sprung und Verzweigungsbefehle

| Mnemonic | Bedeutung                                      |                 |
|----------|------------------------------------------------|-----------------|
| JMP      | unbedingter Sprung zu einer Adresse            | (jump)          |
| Bcc      | Verzweigen, falls die Bedingung cc erfüllt ist | (branch)        |
| BRA      | Verzweigen ohne Abfrage einer Bedingung        | (branch always) |

### Unterprogrammaufrufe und Rücksprünge, Software-Interrupts

| Mnemonic     | Bedeutung                                                                               |
|--------------|-----------------------------------------------------------------------------------------|
| JSR, CALL    | unbedingter Sprung in ein Unterprogramm (jump to subroutine                             |
| BSRcc        | Verzweigung in ein Unterprogramm, falls die Bedingung ee gilt<br>(branch to subroutine) |
| RTS          | Rücksprung aus einem Unterprogramm (return from subroutine                              |
| SWI,TRAP,INT | Unterbrechungsanforderung durch Software                                                |
|              | (software interrupt)                                                                    |
| RTI, RTE     | Rücksprung aus einer Unterbrechungsroutine                                              |
|              | (return from interrupt/exception)                                                       |

### Bedingungen für Sprünge

| cc     | Bedingung                | Bezeichnung                     |  |
|--------|--------------------------|---------------------------------|--|
| cs     | CF=1                     | branch on carry set             |  |
| CC     | CF=0                     | branch on carry clear,          |  |
| vs     | OF = 1                   | branch on overflow              |  |
| VC     | OF=0                     | branch on not overflow          |  |
| EQ     | ZF=1                     | branch on zero/equal            |  |
| NE     | ZF=0                     | branch on not zero/equal        |  |
| MI     | SF-1                     | branch on minus                 |  |
| PL     | SF=0                     | branch on plus                  |  |
| PA     | PF=1                     | branch on parity/parity even    |  |
| NP     | PF=0                     | branch on not parity/parity odd |  |
| nicht  | vorzeichenbehaftete Oper | anden                           |  |
| LO     | CF=1 (vgl. CS)           | branch on lower than            |  |
| LS     | CF v ZF = 1              | branch on lower or same         |  |
| н      | CF v ZF = 0              | branch on higher than           |  |
| HS     | CF=0 (vgl. CC)           | branch on higher or same        |  |
| vorzei | chenbehaftete Operander  |                                 |  |
| LT     | SF=OF = 1                | branch on less than             |  |
| LE     | ZF v (SF+OF) = 1         | branch on less or equal         |  |
|        |                          |                                 |  |
| GT     | $ZF \vee (SF + OF) = 0$  | branch on greater than          |  |

(Bezeichnungen: ‡ Antivalenz, v logisches ODER)

### Sonstige Befehle

| ystembereme |                                                                 |
|-------------|-----------------------------------------------------------------|
| Mnemonic    | Bedeutung                                                       |
| NOP         | keine Operation, nächsten Befehl ansprechen (no operation)      |
| WAIT        | Warten, bis ein Signal an einem speziellen Eingang auftritt     |
| SYNC        | Warten auf einen Interrupt                                      |
| HALT, STOP  | Anhalten des Prozessors, Beenden jeder Programmausführung       |
| RESET       | Ausgabe eines Rücksetz-Signals für die Peripherie-Bausteine     |
| svc         | (geschützter) Aufruf des Betriebssystem-Kerns (supervisor call) |

### Stringbefehle

| Mnemonic | Bedeutung                                     |                  |
|----------|-----------------------------------------------|------------------|
| MOVS     | Transferieren eines Blocks                    | (move string)    |
| INS      | Einlesen eines Blocks von der Peripherie      | (input string)   |
| OUTS     | Ausgabe eines Blocks an die Peripherie        | (output string)  |
| CMPS     | Vergleich zweier Blöcke                       | (compare string) |
| COPS     | Kopieren eines Blocks                         | (copy string)    |
| SCAS     | Suchen eines Zeichens (Wortes) in einem Block |                  |

Der Registersatz

 Datenregister □ Integerregister

Akkumulator

 Adressregister ⇒ Basisregister

➡ Indexregister

Speicher

Spezialregister

⇒ Statusregister

Programmzähler

⇒ Segmentregister

### Die Register im Intel 80x86

O AX (AH und AL)

Akkumulator

O BX (BH und BL)

⇒ base register

⇒ Basisregister zur Adressierung der Anfangsadresse einer Datenstruktur

O CX (CH und CL)

count register

Schleifenzähler, wird bei Schleifen und Verschiebeoperationen benötigt

Datenregister Register für den zweiten Operand

source register und destination register

⇒ Indexregister für die Adressierung von Speicherbereichen

stack pointer

⇒ Verwaltung eines Stapelbereichs



- O Nach den Vorgaben des Steuerwerks werden Speicheradressen gebildet
  - aus Registerinhalten
- aus Speicherzellen
- Adressaddierer
- O TR-Register speichert den Inhalt des aktuellen Adresszählers bei Spriingen
- O Adressprüfung bei Byte-, Halbwort-, Doppelwort- und Quadwort-Zugriffen



### Adressierungsarten



### Register- Adressierung



### Einstufige Adressierung

- Unmittelbare Adressierung
  - Der Befehl enthält den Operanden
  - Beispiel: LDA #\$A3
  - · load accu 316



- O Absolute Adressierung
  - Das Speicherwort das dem Befehls folgt enthält die
  - ⇒ Beispiel: JMP \$07FE



II Kebschull -175

### Seitenadressierung

- O Bei Prozessoren mit unterschiedlicher Daten- und Adressbusbreite
  - man spart Speicherplatz und Zeit des Lesens der höherwertigen Bits
- O Zero-Page Adressierung
  - schneller Zugriff auf die Speicherseite 0
  - ⇒ Beispiel: INC \$007F
    - erhöhe Speicherzelle \$7
- O Seiten-Register-Adressierung
  - ➡ Höherwertige Adressteil wird von einem Register zur Verfügung gestellt
  - ⇒ Beispiel: LDA R0, <\$7F



II Kebschull

### Register-Indirekte Adressierung

- O Auch Zeigeradressierung
- Der Inhalt eines Registers wird als Adresse des Operanden verwendet
- opostincrement: LD R1,(R0)+
  - Lade R1 mit dem Inhalt der Speicherzelle, auf die R0 zeigt, und incrementiere anschließend R0
- preincrement: INC + (R0)
- ⇒ Erhöhe zunächst das Register R0 um 1 und danach die Speicherzelle, auf die das neue R0 zeigt
- opostdecrement: LD R1,(R0)-
  - ⇒ Lade R1 mit dem Inhalt der Speicherzelle, auf die R0 zeigt, und decrementiere anschließend R0
- opredecrement: CLR -(R0)
  - Dekrementiere zunächst R0 und lösche die Speicherzelle, auf die das neue R0 zeigt

II Kebschull -

### Indizierte Adressierung

Stand SS 02

- O Speicher-relative Adressierung
  - Der Basiswert, der zum Indexregister addiert wird, ist im Befehlswort enthalten
  - ⇒ Beispiel ST R1, \$A704(R0)
    - · Speichere R1 an die Adresse, die sich aus der Summe des Inhalts des Registers R0 und \$A704 ergibt
- O Register-relative Adressierung mit Offset
  - Der Basiswert befindet sich in einem speziellen Basisregister
  - ein Offset wird zum Basiswert addiert autoincrement und autodecrement
  - ⇒ Beispiel: ST R1, \$A7(B0)(I0)+ Speichere R1 an die Adresse die sich durch Addition von BO 10 und dem
    - Offset ergibt und incrementiere I0 anschließend

### ⇒ Ein der Inhalt des Indexregister und U. Kebschull

178

### Programmzähler-relative Adressierung

- O Der im Befehlscode angegebene Offset wird zum aktuellen Befehlszähler hinzuaddiert
- O Beispiel: BCS \$47(PC)
  - ⇒ Verzweige an die Adresse PC+\$47 sofern das Carry-Flag gesetzt ist



### Zweistufige Speicheradressierung

- O Indirekte absolute Adressierung
  - Der Befehl enthält eine absolute Adresse, die auf ein Speicherwort zeigt. Dieses Speicherwort enthält die gesuchte Adresse
  - ⇒ Beispiel: LDA (\$A345)
    - · Lade den Accu mit dem Inhalt des Speicherworts, dessen Adresse in \$A345
- O Indirekte Register-indirekte Adressierung
  - Der Befehl bezeichnet ein Register, dessen Inhalt die Speicherzelle ist, deren Inhalt als Adresse für das Speicherwort verwendet wird
  - Beispiel: LD R1, ((R0))
    - · Lade R1 mit dem Inhalt der Adresse. die in in der Speicherzelle steht, auf die R0 zeigt



### Zweistufige Speicheradressierung

- O Indirekte indizierte Adressierung
  - Die Adresse des Speicherworts wird aus der Summe von Offset Basisregister und Indexregister gebildet. Dieses Speicherwort enthält die Adresse des Ziels
  - ⇒ Beispiel: INC (\$A7(B0)(I0))
  - · Erhöhe die Speicherzelle mit der Adresse \$A7+B0+I0 um 1
- Indizierte indirekte Adressierung
  - Die Adresse des Speicherworts wird aus dem 1. Offset und dem Basisregister gebildet. Der Inhalt dieses Speicherworts wird zum Indexregister und dem 2. Offset hinzuaddiert und bildet die Adresse des gesuchten Speicherworts
  - ⇒ Beispiel: INC \$A7(\$10(B0))(I2)
    - · Addiere den Offset \$10 zum Inhalt des Basisregisters, Der Inhalt dieser Speicherzell plus Indexregister und zweiter Offset \$A7 ergibt den Wert der gesuchten Adresse





### Zweistufige Speicheradressierung

- O Indirekte Programmzählerrelative Adressierung
  - Die Summe aus Programmzähler und Offset ergeben die Adresse, die auf das Ziel zeigt
  - ⇒ Beispiel: JMP (\$A7(PC))
    - · Springe an die Stelle die im Speicherwort mit der Adresse PC plus \$A7 steht



### 8 Rechner- und Gerätebusse

- O Busse verbinden Komponenten eines Rechnersystems 8 bis 64 Bit
  - Datenbus
  - 16 bis 64 Bit ⇒ Adressbus
  - ⇒ Steuerbus
- Rechnerbusse
- Busse, die rechnerinterne Komponenten verbinden PC/XT (8088/ 8086)
- ⇒ AT-Bus ⇒ ISA-Bus
  - AT (80286)
- **⇒** EISA 80386 und 80486
- ⇒ VESA ab 80486
- ⇒ PCI ab 80486 bis Pentium4

### Gerätebusse

- Busse, die externe Komponenten mit einem Rechnersystem
- verhinden ⇒ IEC
  - Gerätebus
- **⇒** EIDE Festplatten
- ⇒ SCSI Geräte und Festplattenbus

### **Interne Busse im PC**

- O lokaler Bus (Daten und Adressen)
- am Prozessor
- O Systembus (Daten und Adressen)
- zentraler Bus
- ⇒ Verbindung zu den Steckplätzen (ISA/EISA)
- O Speicherbus (Daten und Adressen)
  - ⇒ Verbindung des Systembusses mit den Speicherbausteinen
  - per gemultiplexte Adressen

II Kebschull -

### PC-Busstrukturen (PCI)



### Der PC/XT-Bus und der ISA-Bus



### **Der EISA-Bus**

- O Extended ISA
- O Evolutionäre Weiterentwicklung des ISA-Busses
- O 32 Bit Daten
- O 32 Bit Adressen
- O Zugriffe mit max. 8.33 MHz
- O Steckplatz ist kompatibel zu ISA Steckkarten
  - ⇒ ISA-Pins liegen tiefer und werden von den alten ISA-Karten nicht erreicht



187

### **Der PCI-Bus**

- O Entkopplung von Prozessor und Erweiterungsbus durch eine Bridge
- O 32-Bit-Standardbusbreite mit maximal 133MByte/s Transferrate
- O Erweiterung auf 64 Bits mit maximal 266MByte/s Übertragungsrate
- Unterstützung von Mehrprozessorsystemen
- O Burst-Transfers mit beliebiger Länge
- O Unterstützung von 5V- und 3,3V-Versorgungsspannungen
- O Write Posting und Read Prefetching
- Multimaster-Fähigkeit
- O Betriebsfrequenz von 0MHz bis maximal 33MHz
- O zeitlich gemultiplexter Adress- und Datenbus für geringe Pin-Anzahl
- O Unterstützung für ISA/EISA/MCA
- O Konfigurierung über Software und Register
- prozessorunabhängige Spezifikation

### Gerätebusse: Der SCSI-Bus

SCSI-Einhe

SCSI-Einhe

SCSI-Einhei

- O Small Computer Systems Interface
  - ⇒ Maximal 8 Einheiten
  - ⇒ 8 Bit Übertragung
  - ➡ Identifikation durch SCSI-ID
  - Terminierung durch Abschlußwiderstand
- O Weitere SCSI-Standards
- ⇒ SCSI-II
  - · Erster richtiger Standard, der am gleichen Bus auch andere Geräte außer Festplatten berücksichtigt
- ⇒ Fast SCSI
- maximale Taktfrequenz wurde auf 10 MHz erhöht
- ⇒ Wide SCSI
  - · 16 Bit und 32 Bit Erweiterung der Datenbreite





### Klassifizierung von Halbleiterspeichern



### Speicherzellen für maskenprogrammierbare Speicherelemente



### Speicherzellen für programmierbare Speicherelemente



- O Programmierung in Programmiergerät durch Überspannungen
  - ⇒ Schmelzsicherung
  - ⇒ Zerstören von Dioden (dauernd leitend)
- O Information ist nur einmal schreibbar und kann nicht verändert werden

U. Kebschull 193

U. Kebschull

### Löschbare Speicherelemente



### Elektrisch löschbare Speicherelemente



- O Dünne Isolierschicht des Floating Gates
  - ⇒ Lesen: Wenn das Floating Gate des Transistors geladen ist, sperrt
  - □ Löschen: Hohe Spannung (21 V) am Gate-Anschluss des Transistors lädt das Floating Gate  $(U_B = 0V)$
  - Programmieren: 0 V am Gate und eine hohe Spannung am Drain-Anschluss des Transistors entlädt einzelne Floating Gates (logisch 0)

II Kebschull

### **Statische MOS-Speicherelemente**



- 6-Transistorzelle
  - ⇒ Statt T2 und T3 können auch n-MOS-Transistoren oder Widerstände eingesetzt werden
  - T4 und T5 dienen zur Ankopplung an die Bitleitungen

### **NVRAM-Speicherelemente**



- O Kombination eines statischen mit einem EEPROM
  - wenn die Spannung abfällt oder das Gerät eingeschaltet wird, findet eine Übertragung von bzw. in die EEPROM-Zelle statt

### **Dynamische Speicherelemente**



- ⇒ vergrößerte Drain-Zone
- ⇒ isoliert zur Spannungsversorgung
- O Kapazität 0,1 bis 0,5 pF, 100.000 bis 150.000 Elektronen
  - Selbstentladung nach ca. 2 ms
- O Speichern entspricht dem Laden des Kondensators
- O Lesen entlädt den Kondensator
- Daten müssen wieder zurückgeschrieben werden

### **Organisation eines Speicherbausteins**



### **NVRAM-Bausteine**



### **Dynamische RAM-Bausteine**



### **Aufbau eines DRAM-Controllers**



### Pseudo-statische RAMs



### 10 E/A und Peripheriegeräte



### Die parallele Schnittstelle

- O Verbindung zum Drucker
  - ⇒ 8 Bit Daten
  - ip einfacher Aufbau
  - normalerweise nur Schreiben
  - ⇒ bei Lesezugriff auf das Datenregister werden die Werte im Datenregister mit den momentan anliegenden Daten mit ODER Verknüpft



### Serielle Datenübertragung

- O Baud: Schrittgeschwindigkeit
- O Aufbau einer Übertragungseinheit
- - Kennzeichnet den Anfang einer Übertragung
- Datenbits
  - · das zu übertragende Datum
  - · ASCII-Kodierung der Daten
- ⇒ Paritätsbit
  - Prüfbit zum Feststellen der Korrektheit der Übertragung
  - gerade Parität: die Zahl der 1en wird zu einer geraden Anzahl ergänzt
- ⇒ Stoppbit
  - Markiert das Ende einer Übertragungseinheit
- O Das Startbit wird mit 8-facher Rate abgetastet

matik 2 Stand 88 02

### Die RS232-Schnittstelle

- O RTS: request to send
  - Sendeteil einschalten
- O CTS: clear to send
  - ⇒ Übertragungseinrichtung sendebereit
- O DCD: data carrier detect
  - ➡ Trägersignal erkannt
- Empfangsteil einschalten
- O DSR: data set ready
  - ⇒ Übertragungseinrichtung betriebsbereit
- O DTR: data terminal ready
- Empfangseinrichtung betriebsbereit

### Anschluss eines Modems



### Anschluss eines Peripheriegeräts



### Verbindung zwischen zwei Computern

### Link-Kabel



### Tastatur



### Maus



### Graphikadapter



### **Prinzip eines Thermodruckers**



### **Prinzip eines Tintenstrahldruckers**



### Prinzip eines Laserdruckers



### Aufbau eines Floppy-Disk-Laufwerks



### **Floppy**



### Aufbau eines Festplatten-Laufwerks



### Größenverhältnisse im Festplatten-Laufwerk



Größenvergleich

chnische Informatik 2 Sund SS 02 U. Kebschull 220

### Sektoren einer Festplatte



### Prinzip der Datenspeicherung

- Das Prinzip der Datenaufzeichnung besteht darin, die Oberfläche der Platte informationsabhängig zu magnetisieren.
- Zur Unterscheidung der "0"- und "1"-Bits wird die Richtung der Magnetisierung verändert. Jede Änderung der Magnetisierungsrichtung wird als flusswechsel bezeichnet.



### Das Frequenzmodulations-Verfahren (FM)

- O Prinzip: Zu Beginn jeder Bitzelle wird ein Taktimpuls T abgespeichert. Nur wenn der Inhalt gleich "1" sein soll, folgt in der Mitte der Bitzelle das Datum D als weiterer Impuls.
- O Dieses Verfahren ist relativ langsam und Speicherplatzintensiv, da in jeder Bitzelle mit dem Datenbit auch der Takt aufgezeichnet werden muss. Es wird auch als Format mit einfacher Schreibdichte (single density) bezeichnet.



223

### Das modifizierte Frequenzmodulations-Verfahren (MFM)

- Prinzip: es wird nur in solchen Zellen ein Taktimpuls abgelegt, in denen auch ein "1"-Datenbit gespeichert werden soll. Dadurch benötigt jede Bitzelle nur noch den halben Platz auf der magnetischen Oberfläche (Double Density Format).
- O Soll eine "1" geschrieben werden, wird ein positiver Datenimpuls D in der Mitte geschrieben. Bei einer "0" wird ein Taktimpuls T am Anfang der Zelle abgelegt, wenn im Takt vorher nicht eine "1" geschrieben wurde.
- Damit wird bei einer Folge von "0"-Bits. Der Takt am Anfang einer jeden Bitzelle abgespeichert und ermöglicht so die Synchronisation beim Lesen der Daten.
- O Beim MFM-Format spricht man von einem Format mit doppelter Schreibdichte (double density).



|                | \$                                   |
|----------------|--------------------------------------|
| Datenbits      | 0 1 0 1 0 1 0 0 1 1                  |
| Lesetakt       |                                      |
| Leseimpulse    |                                      |
| Magnetisierung | +14 +14 +14                          |
| Bitzelle       |                                      |
| Rückgew        | rinnung der Daten beim MFM-Verfahren |

U. Kebschull
strik 2 Stand SS 02

### Das RLL-Verfahren

- Ziel dieses Verfahrens ist, die Aufzeichnung von "0"-Läufen zu begrenzen. Dies wird durch eine geeignete Kodierung der Daten erreicht.
- O RLL-(2,7) bedeutet, dass zwischen zwei "1"-Bits mindestens 2 jedoch höchstens 7 "0"-Bits liegen.
- Neben dem zu kodierenden Bit werden zusätzlich noch ein oder zwei folgende Bits berücksichtigt (kontextabhängig)



| Bitke<br>Bit | mbination<br>Kontext | RLL- | 2,7)-Code |
|--------------|----------------------|------|-----------|
| 1            | 0                    | 10   | 00        |
| 1            | 1                    | 01   | 00        |
| 0            | 00                   | 10   | 0100      |
| 0            | 10                   | 00   | 1000      |
| 0            | 11                   | 00   | 0100      |
| 0            | 010                  | 00   | 001000    |
| 0            | 011                  | 00   | 100100    |



### Vergleich des Speicherbedarfs der verschiedenen Aufzeichnungsverfahren



### Zusammenfassung

### O TI1

- ⇒ Elektrotechnische Grundlagen
  - Einfache physikalische Zusammenhänge, die verwendet werden um Schaltvorgänge in Rechnersystemen durchzuführen
- ⇒ Halbleitertechnologie
  - Funktionsweise von Dioden und Transistoren
  - · Einsatz von Transistoren als Schalter
  - · CMOS-Schaltungen
- Digitale Grundlagen
  - · Entwurf und Darstellung von Schaltnetzen

the Informatik 2 Stand SS 02 227

### Zusammenfassung

### O TI2

- Digitaltechnik
  - · Optimierung von Schaltnetzen und Schaltwerken
- ⇒ Komponenten digitaler Systeme
  - · Funktion und Aufbau komplexer Bausteine
  - · Komponenten aus denen Rechnersysteme aufgebaut sind
- ⇒ Rechnerarithmetik
- · Darstellung von Zahlen und Zeichen in Rechnersystemen
- Algorithmen zur Berechnung von Operationen wie die vier Grundrechenarten
- Aufbau und Funktionsweise einfacher Rechnersysteme
- Komponenten
- Busse
- Speicher
- Peripherie

ische Informatik 2 Stand SS (2 22)