2480-9450

Klaus Fricke

## Digitaltechnik

Lehr- und Übungsbuch für Elektrotechniker und Informatiker

Mit 147 Abbildungen und 86 Tabellen



## Inhaltsverzeichnis

| 1 | Einleitung                                           | 1  |
|---|------------------------------------------------------|----|
| 2 | Codierung und Zahlensysteme                          | 3  |
|   | 2.1 Codes                                            | 3  |
|   | 2.2 Binärcode                                        | 4  |
|   | 2.3 Festkomma-Arithmetik im Binärsystem              |    |
|   | 2.3.1 Ganzzahlige Addition im Binärsystem            |    |
|   | 2.3.2 Addition von Festkommazahlen                   |    |
|   | 2.3.3 Einerkomplementdarstellung                     |    |
| - | 2.3.4 Zweierkomplementdarstellung                    |    |
|   | 2.3.5 Subtraktion in Zweierkomplementdarstellung     |    |
|   | 2.3.6 Bereichsüberschreitung                         |    |
|   | 2.3.7 Multiplikation                                 |    |
|   | 2.3.8 Division                                       |    |
|   | 2.4 Hexadezimalcode                                  |    |
|   | 2.5 Oktalcode                                        |    |
|   | 2.6 Graycode                                         |    |
|   | 2.7 BCD-Code                                         |    |
|   | 2.8 Alphanumerische Codes                            |    |
|   | 2.9 Übungen                                          | 13 |
|   | •                                                    |    |
| 3 | Schaltalgebra                                        | 15 |
|   | 3.1 Schaltvariable und Schaltfunktion                |    |
|   | 3.2 Zweistellige Schaltfunktionen                    |    |
|   | 3.3 Rechenregeln                                     |    |
|   | 3.4 Kanonische disjunktive Normalform (KDNF)         |    |
|   | 3.5 Kanonische konjunktive Normalform (KKNF)         |    |
|   | 3.6 Darstellung von Funktionen mit der KKNF und KDNF |    |
|   | 3.7 Minimieren mit Hilfe der Schaltalgebra           |    |
|   | 3.8 Vereinfachte Schreibweise                        |    |
|   | 3.9 Schaltsymbole                                    |    |
|   | 3.9.1 Grundsätzlicher Aufbau der Symbole             |    |
|   | 3.9.2 Die Abhängigkeitsnotiation                     |    |
|   | 3.9.3 Die UND-Abhängigkeit (G)                       |    |
|   | 3.9.4 Die ODER-Abhängigkeit (V)                      |    |
|   | 3.9.5 Die EXOR-Abhängigkeit (N)                      |    |
|   | 3.9.6 Die Verbindungs-Abhängigkeit (Z)               |    |
|   | 3.9.7 Die Übertragungs-Abhängigkeit (X)              |    |
|   | 3.10 Übungen                                         | 30 |
|   |                                                      |    |
| 4 | Verhalten logischer Gatter                           | 31 |
|   | 4.1 Positive und negative Logik                      | 32 |

| 11 Schieberegister                                 | 133 |
|----------------------------------------------------|-----|
| 11.1 Zeitverhalten von Schieberegistern            | 134 |
| 11.1.1 Schieberegister 74194                       |     |
| 11.2 Rückgekoppelte Schieberegister                | 137 |
| 11.2.1 Moebius-Zähler, Johnson-Zähler              | 138 |
| 11.2.2 Pseudo-Zufallsfolgen                        |     |
| 11.3 Übungen                                       |     |
| 12 Arithmetische Bausteine                         | 143 |
| 12.1 Volladdierer                                  | 143 |
| 12.2 Serienaddierer                                |     |
| 12.3 Ripple-Carry-Addierer                         |     |
| 12.4 Carry-Look-Ahead Addierer                     |     |
| 12.4.1 Kaskadierung von Carry-Look-Ahead-Addierern |     |
| 12.4.2 Vergleich der Addierer                      |     |
| 12.5 Arithmetisch-logische-Recheneinheiten (ALU)   |     |
| 12.5.1 Beispiele für Operationen                   |     |
| 12.6 Komparatoren                                  |     |
| 12.6.1 2-Bit-Komparator                            |     |
| 12.6.2 Kaskadierbare Komparatoren                  |     |
| 12.7 Übungen                                       |     |
| 12.7 Counges (                                     |     |
| 13 Digitale Speicher                               | 161 |
| 13.1 Prinzipieller Aufbau von Speicherbausteinen   |     |
| 13.2 ROM                                           |     |
| 13.3 PROM                                          |     |
| 13.4 EPROM                                         |     |
| 13.5 EEPROM                                        |     |
| 13.6 EAROM                                         |     |
| 13.7 NOVRAM                                        |     |
| 13.8 RAM                                           |     |
| 13.8.1 Statisches RAM                              |     |
| 13.8.2 Beispiel RAM                                |     |
| 13.9 Dynamisches RAM                               |     |
| 13.10 Quasistatisches DRAM                         |     |
| 13.11 Eimerkettenspeicher                          |     |
| 13.11.1 Beispiel eines FIFOs                       |     |
| 13.12 Kaskadierung von Speichern                   |     |
| 13.13 Erweiterung der Wortlänge                    |     |
| 13.14 Erweiterung der Speicherkapazität            |     |
| 13.14.1 Volldekodierung                            |     |
| 13.14.2 Teildekodierung                            |     |
| 13.14.3 Lineare Dekodierung                        |     |
| 13.15 Übungen                                      |     |
| 10110 0000501                                      | ,   |
| 14 Programmierbare Logikbausteine                  | 191 |
|                                                    |     |

| 14.2 Programmierbare Logik-ICs (PLD)                          | 194 |
|---------------------------------------------------------------|-----|
| 14.2.1 PLD-Typen                                              | 194 |
| 14.3 ROM, EPROM, EEPROM                                       | 195 |
| 14.4 PLA                                                      | 196 |
| 14.5 PAL                                                      | 203 |
| 14.6 GAL                                                      | 205 |
| 14.7 Programmierung von PLD-Bausteinen                        | 208 |
| 14.7.1 Test                                                   |     |
| 14.8 Field Programmable Gate Arrays (FPGA)                    | 210 |
| 14.8.1 Aufbau eines FPGAs                                     | 210 |
| 14.8.2 Konfigurierbare Logik-Blöcke (CLB)                     | 211 |
| 14.8.3 IO-Block                                               | 212 |
| 14.8.4 Verbindungsleitungen                                   | 213 |
| 14.8.5 Programmierung eines FPGAs                             | 214 |
| 14.9 EPLD                                                     | 214 |
| 14.9.1 Beispiel EPLD: CY7C343                                 | 214 |
| 14. 10 Gate-Arrays                                            | 215 |
| 14.10.1 Aufbau von Channeled Gate-Arrays                      | 216 |
| 14.11 Standardzellen-ASIC                                     | 219 |
| 14.12 Vollkundendesign-ASICs                                  | 219 |
| 14.13 Übungen                                                 | 220 |
|                                                               |     |
| 15 Entwicklungs-Software                                      | 221 |
| 15.1 Entwurfsverfahren für digitale Schaltungen               |     |
| 15.2 ABEL                                                     |     |
| 15.2.1 ABEL-Programm: Adressdekoder                           | 223 |
| 15.2.2 ABEL-Programm: Schaltwerk                              |     |
| 15.3 Übungen                                                  | 228 |
| 16 Deineir des Milynenyersesses                               | 229 |
| 16 Prinzip des Mikroprozessors 16.1 Kooperierende Schaltwerke |     |
| 16.2 Der von Neumann-Rechner                                  |     |
| 16.3 Operationswerke                                          |     |
| 16.3.1 Architektur von Operationswerken                       |     |
| 16.3.2 Bussysteme                                             |     |
| 16.4 Leitwerke                                                |     |
| 16.5 Mikroprogrammierung                                      |     |
| 16.6 Übungen                                                  |     |
| 10.0 Couligen                                                 | 230 |
| 17 Der Mikroprozessor 8085A                                   | 237 |
| 17 Der Mikroprozessor 8085A 17.1 Aufbau des 8085A             | 237 |
| 17.2 Anschlüsse des 8085.                                     |     |
| 17.3 Speicher- und Peripherie                                 |     |
| 17.4 Peripheriebausteine                                      | 243 |
| 17.5 Die Parallelschnittstelle 8255                           | 244 |
| 17.6 Funktionsabläufe bei der Befehlsausführung               |     |
| 17.6.1 Der Operationcode -Fetch-Zyklus (OF)                   |     |
|                                                               |     |

| 17.6.2 Der Memory-Read-Zyklus (MR)                    | 248 |
|-------------------------------------------------------|-----|
| 17.6.3 Der Memory Write-Zyklus (MW)                   |     |
| 17.6.4 Beispiel für eine Befehlsausführung            | 250 |
| 17.7 Interruptsteuerung                               |     |
| 17.8 Assembler-Programmierung                         |     |
| 17.9 Befehlssatz                                      |     |
| 17.10 Transferbefehle                                 | 253 |
| 17.10.1 Adressierung "Register"                       | 253 |
| 17.10.2 Adressierung "Register Indirekt"              | 254 |
| 17.10.3 Adressierung "Immediate"                      |     |
| 17.10.4 Adressierung "Direkt"                         |     |
| 17.11 Arithmetische Befehle                           |     |
| 17.12 Logische Operationen                            | 258 |
| 17.13 Setzen und Löschen des Carry-Flags              |     |
| 17.14 Schiebebefehle                                  |     |
| 17.15 Programmverzweigungen                           | 259 |
| 17.15.1 Beispiel für einen Sprung                     |     |
| 17.16 Befehle für Unterprogramme                      |     |
| 17.17 Befehle für die Prozessorsteuerung              |     |
| 17.18 Assemblerbefehle                                | 266 |
| 17.19 Programmbeispiele                               | 268 |
| 17.19.1 Programmierung der Parallelschnittstelle 8255 | 268 |
| 17.19.2 Datenübergabe an Unterprogramme               | 270 |
| 17.20 Übungen                                         |     |
| A Anhang                                              | 273 |
| A.1 Die Abhängigkeitsnotation                         | 273 |
| A.2 Befehlssatz des 8085A                             | 277 |
| Lösungen der Aufgaben                                 | 283 |
| Literatur                                             | 305 |
| Sachwortregister                                      | 309 |