

# Hochschule Augsburg University of Applied Sciences

Hardwaresysteme Kürprojekt

Fakultät für Informatik

Studienrichtung M.Sc. Informatik

Mathias Schoppe Entwicklung eines integrierten Schaltkreises - Konzeptionierung und Umsetzung

Betreuer: Prof. Dr.-Ing. Gundolf Kiefer Abgabe der Arbeit am: 09.07.2023

Hochschule für angewandte Wissenschaften Augsburg University of Applied Sciences

An der Hochschule 1 D-86161 Augsburg

Telefon +49 821 55 86-0 Fax +49 821 55 86-3222 www.hs-augsburg.de info@hs-augsburg.de

Fakultät für Informatik Telefon +49 821 5586-3450 Fax +49 821 5586-3499

Verfasser der Ausarbeitung: Mathias Schoppe Matr. Nr.: 000000 M. Sc. Informatik Teamkollegen: Sascha Testname und Timo Winklbauer

## **Abstract**

# Inhaltsverzeichnis

| 1 | Einleitung                   |                                           | 1 |
|---|------------------------------|-------------------------------------------|---|
|   | 1.1                          | Motivation                                | 1 |
|   | 1.2                          | Zielsetzung                               | 1 |
|   | 1.3                          | Struktur der Arbeit                       | 1 |
| 2 | Gru                          | ındlagen                                  | 3 |
|   | 2.1                          | Linear rückgekoppeltes Schieberegister    | 3 |
|   | 2.2                          | Hardware Timer                            | 4 |
| 3 | Schaltkreis Entwurf          |                                           | 5 |
|   | 3.1                          | Das Reaktionsspiel                        | 5 |
|   | 3.2                          | Register-Transfer-Ebene                   | 5 |
|   | 3.3                          | Gatter-Ebene, Verdrahtung und Platzierung | 5 |
|   | 3.4                          | Simulation                                | 5 |
| 4 | Bewertung                    |                                           | 5 |
|   | 4.1                          | Zieleinhaltung                            | 5 |
|   | 4.2                          | Interpretation der Ergebnisse             | 5 |
| 5 | Zusammenfassung und Ausblick |                                           | 5 |
| 6 | 6 Abkürzungsverzeichnis      |                                           | 5 |
| 7 | Lite                         | raturverzeichnis                          | 6 |

1 EINLEITUNG 1

## 1 Einleitung

#### 1.1 Motivation

In dieser Ausarbeitung liegt der Fokus auf der Entwicklung eines eigenen integrierten Schaltkreises (IC) mithilfe des Tiny-Tapeout-Projekts[TT]. Der Prozess des IC-Designs ist äußerst komplex und erfordert spezialisierte Kenntnisse sowie teure Ausrüstung und Ressourcen. Das Tiny-Tapeout-Projekt hat es geschafft, ein besonderes Konzept zu entwickeln, das es selbst Anfängern ermöglicht, ihre eigenen IC-Designs zu realisieren. Es bietet eine kostengünstige Möglichkeit, ein eigenen IC fertigen zu lassen und eröffnet somit neue Möglichkeiten für kreative Ideen und individuelle Schaltungen. Dieser Teil der Ausarbeitung behandelt Aspekte, welche für ein solches Vorhaben zu beachten sind und bezieht sich dabei auf die konkrete Umsetzung eines Reaktionsspiels als IC.

### 1.2 Zielsetzung

Das Ziel der Arbeit besteht darin, ein eigenes IC-Design für ein Reaktionsspiel zu entwerfen und zu simulieren. Hierbei wird darauf geachtet, dass maximal 500 Logikgatter und ausschließlich die Ein- und Ausgänge des Tiny-Tapeout Evaluationsboards für die Umsetzung benötigt werden. Durch die Realisierung dieses Projekts sollen grundlegende Kenntnisse im IC-Design erlangt und praktische Erfahrungen in der Entwicklung von elektronischen Schaltungen gesammelt werden.

#### 1.3 Struktur der Arbeit

Die Struktur, Kapitel und die jeweiligen Unterpunkte sind im Inhaltsverzeichnis übersichtlich dargestellt. Dieser Abschnitt fasst kurz zusammen, was in den fünf Hauptpunkten beschrieben wird:

#### 1 Einleitung

Die Einleitung verschafft einen Überblick über das zu behandelnde Thema und stellt die Motivation für die Verfassung der Arbeit dar.

#### 2 Grundlagen

Das Kapitel Grundlagen legt die verwendeten Theorien und Konzepte dar, welche für die Umsetzung des Projektes unabdingbar sind.

2

- 3 Schaltkreis Entwurf
- 4 Bewertung
- 5 Zusammenfassung und Zukunftsausblick

2 GRUNDLAGEN 3

## 2 Grundlagen

Das nachfolgende Kapitel befasst sich mit grundlegenden Themen, welche für die Umsetzung der Arbeit unabdingbar sind. Die Themenbereiche werden zusammengefasst und so erläutert, dass auch Lesende ohne Vorerfahrung im Bereich der Hardwareentwicklung alle Aspekte der Arbeit nachvollziehen können. Es wird ausschließlich auf Grundlagen, welche relevant für die konkrete Umsetzung des Projekts sind, eingegangen.

## 2.1 Linear rückgekoppeltes Schieberegister

Ein linear rückgekoppeltes Schieberegister (engl. linear feedback shift register (LFSR)) ist eine Schaltung, die aus einer Reihe von Flip-Flops (digitale Speicherelemente) besteht, die in einer Kette miteinander verbunden sind. Die Rückkopplung erfolgt, indem das Ausgangssignal eines Flip-Flops mit dem Eingang eines vorherigen Flip-Flops verbunden wird. Dadurch bildet sich ein geschlossener Rückkopplungs-Pfad.[fox2008linear]

Die Anzahl der Flip-Flops in einem Schieberegister bestimmt die Anzahl der Speicherplätze oder Zustände, die es halten kann. Ein 4-Bit-Schieberegister kann beispielsweise 16 verschiedene Zustände einnehmen, während ein 8-Bit-Schieberegister 256 verschiedene Zustände einnehmen kann.



Abbildung 1: Abbildung eines Fibonacci-LFSR, angelehnt an [LFSRWiki]

In Abbildung 1 ist ein 8-Bit Fibonacci-LFSR dargestellt. Dabei repräsentiert CLK den Takteingang und Y den Ausgang des LFSR. Bei jedem Taktimpuls wird der gespeicherte Wert der Flip-Flops eine Stelle weiter geschoben. Bei jedem Taktimpuls wird das Rückkopplungs-Bit in das erste Flip-Flop des Schieberegisters eingespeist, alle anderen Bits werden zum nächsten Flip-Flop geschoben. Dies bedeutet, dass das Ausgangssignal des ersten Flip-Flops als Eingangssignal des zweiten Flip-Flops dient, das Ausgangssignal des zweiten Flip-Flops als Eingangssignal des dritten Flip-Flops und so weiter. Das Fibonacci-LFSR zeichnet sich durch das in Gleichung 1 dargestellte primitive Generatorpolynom aus. Dies

2.2 Hardware Timer 4

ermöglicht dem Schieberegister die Generierung von Pseudozufallszahlen.

$$pf(x) = x^8 + x^6 + x^5 + x^4 + 1 \tag{1}$$

#### 2.2 Hardware Timer

Der Hardware Timer ist eine Schaltungskomponente, die verwendet wird, um Zeit zu messen oder Zeit basierte Ereignisse zu erzeugen. Er besteht aus einem internen Zähler, der bei jedem Taktimpuls inkrementiert oder dekrementiert wird und so die Grundlage für die Zeiterfassung bildet. Der Hardware Timer wird durch Steuersignale gesteuert, welche das starten, stoppen und zurücksetzen ermöglichen. Diese Steuersignale können entweder von einer externen Steuerung oder durch interne Logik generiert werden.

Damit durch den Hardware Timer eine bestimmte Zeit in Sekunden überbrückt wird, betrachten wir folgende Zusammenhänge. Die Taktfrequenz f gibt an, wie viele Taktzyklen pro Sekunde auftreten. Um eine bestimmte Zeit t in Sekunden zu warten, muss die Anzahl der Takte berechnet werden, die während dieser Zeit vergehen. Dazu wird in Gleichung 2 die Zeit t mit der Taktfrequenz f multipliziert.

Anzahl der Takte = 
$$t * f$$
 (2)

Es ist wichtig zu beachten, dass diese Berechnung auf der idealisierten Annahme basiert, dass die Taktfrequenz und der Takt stabil und präzise sind. In der Praxis können jedoch Ungenauigkeiten auftreten, die die Zeitmessung beeinflussen.

- 3 Schaltkreis Entwurf
- 3.1 Das Reaktionsspiel
- 3.2 Register-Transfer-Ebene
- 3.3 Gatter-Ebene, Verdrahtung und Platzierung
- 3.4 Simulation
- 4 Bewertung
- 4.1 Zieleinhaltung
- 4.2 Interpretation der Ergebnisse
- 5 Zusammenfassung und Ausblick
- 6 Abkürzungsverzeichnis
- IC integrierter Schaltkreis
- LFSR linear rückgekoppeltes Schieberegister

# 7 Literaturverzeichnis