# Modelsim und VHDL Einführung

VHDL (Very High Speed Integrated Circuit Hardware Description Language) ist eine Sprache zur Beschreibung von digitalen Schaltungen. Modelsim ist eine Simulationssoftware der Firma Mentor Graphics mit der das Verhalten von VHDL Beschreibungen simuliert werden kann.

Diese Einführung beginnt mit zwei einfachen VHDL Dateien, die eine einfache Schaltung beschreibt.

### Vorbereitung

Kopieren Sie die VHDL Dateien in ein Verzeichnes mit dem Namen "first".

Die beiden VHDL Dateien sind:

first.vhd - Die Beschreibung der Schaltung

first\_tb.vhd - Die Beschreibung einer Testumgebung (Testbench)

#### Aufbau der VHDL Dateien - Entity und Architecture

Die Datei "first.vhd":

```
LIBRARY ieee;
USE ieee.std_logic_1164.all;
```

```
-- Simple module that connects the SW switches to the LEDR lights

ENTITY first IS

PORT ( SW : IN STD_LOGIC_VECTOR(9 DOWNTO 0);

LEDR : OUT STD_LOGIC_VECTOR(9 DOWNTO 0)); -- red LEDS

END first;

ARCHITECTURE Structure OF first IS

BEGIN

LEDR <= SW;

END Structure;
```

Die Datei enthält eine Entity- und eine Architecturebeschreibung. Entity und Architecture beschreiben zusammen ein Schaltungsmodul. Die Entity beschreibt die Schnittstellen des Moduls, während die Architecture den Inhalt des Moduls beschreibt. Aus der Entitybeschreibung von "first.vhd" kann man ersehen

a) Das Modul hat den Namen "first"

b) Es gibt einen Eingangsport mit dem Namen "SW", der 10 Bit breit und vom Typ std\_logic\_vector ist.

c) Es gibt einen Ausgangsport mit dem Namen "LEDR", der auch 10 Bit breit ist und ebenfalls vom Typ std\_logic\_vector ist.

Aus der Architecture kann man entnehmen:

a) Diese Architektur hat den Namen "structure" und gehört zum Modul first

b) Dem Ausgangsport "LEDR" wird der Wert des Eingangsports "SW" zugewiesen. Der Operator "<=", weißt dem Signal auf der linken Seite vom Operator, den Wert des Signals auf der rechten Seite zu.

Diese Schaltung verbindet also den Eingang SW einfach mit dem Ausgang LEDR.

### Typen - std\_logic und std\_logic\_vector

Jedes Signal hat einen Typen. Der Typ eines Signals gibt an, welche Werte das Signal annehmen kann. In dem Beispiel first haben die Eingangs- und Ausgangsports den Typen "std\_logic\_vector". "std\_logic\_vector" ist eine Zusammenfassung (ein Bus) von mehreren Signalen vom Typ std\_logic.

Der Typ std\_logic kann Werte annehmen, die den Zuständen von Leitungen in einer digitalen Schaltung entsprechen. Die wichtigsten sind "0" und "1". Es gibt aber noch weitere Zustände, wie beispielsweise "U", das für "undefined" steht, wenn ein Signal keinen definierten Zustand hat. Dieser Zustand tritt beispielsweise bei einem Flipflop auf, das noch nicht zurückgesetzt oder getaktet wurde.

#### Die Testbench

Die andere VHDL Datei ist "first tb.vhd": library ieee; use ieee.std\_logic\_1164.all; -- Testbench for the first switch/led module -- The switches are switched... entity first\_tb is end; architecture beh of first tb is -- This is the component declaration component first port ( in std\_logic\_vector(9 downto 0); SW: out std\_logic\_vector(9 downto 0) LEDR: ); end component; -- Signal declaration for the switches and the leds signal switch, ledr : std\_logic\_vector(9 downto 0) := "0000000000"; begin -- Here the device under test is instantiated first\_i0 : first port map ( SW => switch, => ledr); LEDR -- This is the process where the switch is switched. Note that the process -- always starts from the beginning. This process is not synthesizable because -- of the wait statement. schalter : process begin wait for 1 us; switch <= "000000001";</pre>

```
end process schalter;
end; -- architecture
```

switch <= "100000000";</pre>

wait for 3 us;

Auch die Datei "first\_tb.vhd" hat eine Entity und eine Architecture. Aus der Entitybeschreibung kann man entnehmen

a) Das Modul heißt: first\_tb

b) Das Modul hat keine Eingänge und keine Ausgänge.

Aus der Architecturebeschreibung kann man entnehmen

a) Es gibt eine Komponente "first" mit den Ein- und Ausgangssignalen, die aus der Entitybeschreibung von "first" bekannt sind.

b) Es gibt zwei Signale "switch" und "ledr" mit 10 Bit Breite vom Typen std\_logic\_vector. Die Signale werden auf den Wert "0000000000" initialisiert.

c) Es wird eine Instanz "first\_i0" des Moduls "first" instantiiert. Der Eingang "SW" des Moduls wird an das Signal "switch" angeschlossen. Der Ausgang "LEDR" wird an das Signal "ledr" angeschlossen.

d) Es gibt einen Prozess "schalter" und in diesem Prozess wird

- 1. Für den Zeitraum von 1 Mikrosekunde gewartet
- 2. Dann dem Signal "switch" der Wert "0000000001" zugewiesen
- 3. Für 3 Mikrosekunden gewartet
- 4. Dem Signal "switch" der Wert "1000000000" zugewiesen.

Diese Testbench "first\_tb" enthält also das Modul "first" und einen Prozess, in dem dem Signal switch nacheinander verschiedene Werte zugewiesen werden. Dieses Signal ist an das Eingangssignal "SW" des Moduls angeschlossen.

#### Modelsim

Starten Sie Modelsim.

Linux: Wechseln Sie in das Verzeichnis first und starten Sie mit "vsim"

Sie sehen:



Wählen Sie: "Create a Project". Geben Sie dem Projekt den Namen "first".



Wählen Sie "Add Existing File" und fügen Sie "first.vhd" und "first\_tb.vhd" zu dem Projekt hinzu.



Wählen Sie dann "Compile->Compile All".

Mit diesem Schritt kompilieren Sie die VHDL Dateien. Dieser Schritt ist notwendig um anschliessend die Simulation durchführen zu können. Die Dateien werden in eine Bibliothek mit dem Namen "work" kompiliert.

Wählen Sie danach "Simulate->Start Simulation". Es erscheint eine Übersicht der verschiedenen Bibliotheken.

| Name                      | Туре       | Path                                   |      |  |  |  |  |  |  |
|---------------------------|------------|----------------------------------------|------|--|--|--|--|--|--|
| 🖃 🏦 work                  | Library    | /home/beckmann/design/first/wo         | ri 👘 |  |  |  |  |  |  |
| 🚊 Ē first                 | Entity     | ty /home/beckmann/design/first/firs    |      |  |  |  |  |  |  |
| A structure               | Architectu | Architecture                           |      |  |  |  |  |  |  |
| E first_tb                | Entity     | /home/beckmann/design/first/firs       | t i  |  |  |  |  |  |  |
| A) beh                    | Architectu | Architecture                           |      |  |  |  |  |  |  |
| 🖅 抗 220model              | Library    | y \$MODEL_TECH//altera/vhdl/22         |      |  |  |  |  |  |  |
| 🖅 抗 220model_ver          | Library    | Library \$MODEL_TECH//altera/verilog/a |      |  |  |  |  |  |  |
| 🖅 🏨 altera                | Library    | \$MODEL_TECH//altera/vhdl/al           | te   |  |  |  |  |  |  |
| ∓⊸ <b>ilti.</b> altera mf | l ibrarv   | \$MODEL_TECH/_/altera/vhdl/al          | he 🔽 |  |  |  |  |  |  |
| <                         |            |                                        | 2    |  |  |  |  |  |  |
| Design Unit(s)            |            | Resolution                             |      |  |  |  |  |  |  |
| work.first tb(beh)        |            | default                                | T    |  |  |  |  |  |  |
| · · · · · ·               |            |                                        |      |  |  |  |  |  |  |
| Optimization              |            |                                        |      |  |  |  |  |  |  |
| Enable ontimization       |            | Ontimization Ontions                   |      |  |  |  |  |  |  |

Wählen Sie die Architecture "first\_tb(beh)" aus. Es erscheint eine Übersicht der Schaltungsstruktur und ein Waveformdisplay.

| Anwendungen C                                       | orte System 🙋                      | ?             | 2                  |                                       | 🌢 Darstellung | Virtuell         | e Maschine     | Fenster | ll eckr      | mann ტ    | )                                       |        | ۰ 🕨            | <b>∠</b> = <b>1</b> , | Do, 11. Nov, 23:40 |
|-----------------------------------------------------|------------------------------------|---------------|--------------------|---------------------------------------|---------------|------------------|----------------|---------|--------------|-----------|-----------------------------------------|--------|----------------|-----------------------|--------------------|
| 😣 😔 🔗 🛛 Model Si                                    | m ALTERA STA                       | ARTER EDIT    | ION 6.5e           |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| <u>F</u> ile <u>E</u> dit <u>V</u> iew <u>C</u> omp | oile <u>S</u> imulate A <u>d</u> o | d Structure   | T <u>o</u> ols Lay | o <u>u</u> t <u>W</u> indow           |               |                  |                |         |              |           |                                         |        |                |                       | Help               |
|                                                     | 🐰 📭 🏙 🐑                            | 🗠   🛤 🗄       | - ₽a M             | 🦘 🖽 🛺 🖹                               | 1 🛛 🛧 🦛       | 🔶   EF           | 100 ps 🛊 [     |         | (4) 🕅        | 0 0 T     | e i i i i i i i i i i i i i i i i i i i | ) X >) | ( <u>P</u> ] ] | 20 ×                  |                    |
| Layout Simulate                                     |                                    |               |                    | ]♦ →[] ]₊ ]}                          | E F GR.       | 67. 67° 67       | N 1 6          |         |              | 310       |                                         |        | r              |                       | 1                  |
| a sim :                                             |                                    |               | Wave -             | hann mar hann "Ann                    |               | w ov w           | w i *i         |         | • • • • • •  | ····••    |                                         |        |                |                       |                    |
| <ul> <li>Instance</li> </ul>                        | Design unit                        | Design ur     |                    | Messages                              |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| 🖃 📕 first_tb                                        | first_tb(beh)                      | Architecti    |                    | , , , , , , , , , , , , , , , , , , , |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| 🕀 📕 first_i0                                        | first(structure                    | e) Architectu |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| schalter                                            | first_tb(beh)                      | Process       |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| standard                                            | standard<br>std. logic, 1          | Package       |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| ata_logic_1104                                      | std_logic_1.                       | I dekage      |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
|                                                     |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       | <u>N</u>           |
|                                                     |                                    |               | ≙ 🛒 ⊛              | Now                                   | 0 ps          | 1111111111<br>19 | 200 n          |         | 400 1        | ns        | 111111111111<br>008                     | ns.    |                | IIIIII<br>BOO ns      | 100                |
|                                                     |                                    |               | ê & O              | Cursor 1                              | 0.00 ns       | 0 ps             | <u>200 p</u> . |         |              |           |                                         | P*     |                | 000 pv                |                    |
| 👖 Library 🛅 Project                                 | 🛺 sim                              | • >           |                    |                                       |               | 4                |                |         |              |           |                                         |        |                |                       |                    |
| A Transcript                                        |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       | + # ×              |
| / Loading ieee.std logic_1164(body)                 |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| # Loading work firs                                 | t_tb(ben)<br>t(structure)          |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| VSIM 25                                             |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       |                    |
| V 01141 C/                                          |                                    |               |                    |                                       |               |                  |                |         |              |           |                                         |        |                |                       | 🖬                  |
|                                                     |                                    |               |                    | 0 ps to 1 ns                          |               | Now: 0 ps        | Delta: 0       | Proj    | ject : first | Now: 0 ps | Delta: 0                                |        | si             | m:/first_             | tb //.             |
| 🔲 🗈 beckmann                                        | 🗈 beckmar                          | n@ 🗈 b        | eckmann            | . 📝 i2c.vhd                           | (~/p ⊵ bec    | kmann            | T Mode         | Sim     | 9            |           |                                         |        |                |                       |                    |

Gehen Sie im Fenster "sim" auf first\_tb und wählen Sie mit der rechten Maustaste

"Add->ToWave->All Items in Design"

Es erscheinen im Waveformdisplay die Signale "switch" und "ledr" sowie SW und LEDR. Der Wert von LEDR und ledr ist "U", also undefined.

| Anwendungen Orte Sys                                                                                                                                                      | item 🍪 👔                                                                                 | 2                                                                    | 2                                   |                                                                        | 🌢 Darstell   | ung Virt             | uelle Maschir | ne Fenste   | er 🕕 eck | cmann           | )       | _       | ♦ 🖂 | t, Do | o, 11. Nov, 23:45 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------------------------------------------------------------|-------------------------------------|------------------------------------------------------------------------|--------------|----------------------|---------------|-------------|----------|-----------------|---------|---------|-----|-------|-------------------|
| 😣 📀 🔗 🛛 ModelSim ALTE                                                                                                                                                     | RA START                                                                                 | ER EDITI                                                             | ON 6.5e                             |                                                                        |              |                      |               |             |          |                 |         |         |     |       |                   |
| <u>F</u> ile <u>E</u> dit <u>V</u> iew <u>C</u> ompile <u>S</u> imu                                                                                                       | ilate A <u>d</u> d '                                                                     | W <u>a</u> ve T <u>o</u> o                                           | ls Layo <u>u</u> t                  | <u>W</u> indow                                                         |              |                      |               |             |          |                 |         |         |     |       | <u>H</u> elp      |
| 🗋 • 🚅 🖬 🛸 🖨   🐰 🕅                                                                                                                                                         | h 🛍 🖄 🖆                                                                                  | 2   #4 🗄                                                             | B M                                 | - 🎋 🖽 🛺 🛽                                                              | 1 @ <b>1</b> | 🍁   🛙                | 100 ps        |             | 😫 🌋   79 | 0 0 0           | 9 🔟 🔟 🤊 | 🖱 🛛 🗶 🕨 | Xn  | *     |                   |
| Layout Simulate 🗨                                                                                                                                                         | N 🖪 🕸                                                                                    | • • • • • • • •                                                      | 보고                                  | 1 + + ₹ ₹                                                              | F F          | q.q                  | 🤹 🖂           | M Q         | ର୍ 🔍 🔍   |                 |         |         | r   |       |                   |
| 💭 sim                                                                                                                                                                     |                                                                                          | + # × ]                                                              | 🖬 Wave 🖂                            |                                                                        | 12           |                      | 12            |             |          |                 |         |         |     |       | + 7 ×             |
| Instance Des                                                                                                                                                              | sign unit 🛛 🛛                                                                            | Design ur                                                            |                                     | Messages                                                               |              |                      |               |             |          |                 |         |         |     |       |                   |
| first_tb     first_i0     first_i0     first_i0     first_i0     first     first_i0     first     first     schalter     first     standard     stan     standard     sta | Ltb(beh) / /<br>((structure) /<br>((structure) /<br>t_tb(beh) F<br>ndard F<br>_logic_1 F | Architecti<br>Architecti<br>Process<br>Process<br>Package<br>Package | B ↔ /fir:<br>B ↔ /fir:<br>B ↔ /fir: | :t_tb/switch<br>:t_tb/iadr<br>:t_tb/first_i0/sw<br>:t_tb/first_i0/ledr |              |                      |               |             |          |                 |         |         |     |       | X                 |
|                                                                                                                                                                           |                                                                                          |                                                                      |                                     |                                                                        |              |                      |               |             |          |                 |         |         |     |       |                   |
|                                                                                                                                                                           |                                                                                          |                                                                      | ≝ 🛒 ⊕                               | Now                                                                    | 0            | ps 111111            |               | 0 ns        | 400      | 111111111<br>ns |         | ns      | 800 | ns    | 100               |
|                                                                                                                                                                           |                                                                                          |                                                                      | ê & 0                               | Cursor 1                                                               | 0            | ps <mark>0 ps</mark> | 20            | - p-        | 400      | - PO            | 000     | P0      |     | - PO  |                   |
|                                                                                                                                                                           |                                                                                          | <u> 12  </u>                                                         |                                     |                                                                        | ы            |                      |               |             |          |                 |         |         |     |       |                   |
| <pre>Transcript # Loading work.first_tb(beh # Loading work.first(struct add wave -r /*</pre>                                                                              | i)<br>zure)                                                                              |                                                                      |                                     |                                                                        |              |                      |               |             |          |                 |         |         |     |       |                   |
| VSIM 3>                                                                                                                                                                   |                                                                                          |                                                                      |                                     |                                                                        |              |                      |               |             |          |                 |         |         |     |       |                   |
| 0 ps to 1 ns                                                                                                                                                              | Now: 0 ps                                                                                | Delta: 0                                                             |                                     | Project : first N                                                      | ow: 0 ps Def | ta: O                | si            | m:/first_tb |          |                 |         |         |     |       |                   |
| 📑 🗈 beckmann 🗈 b                                                                                                                                                          | eckmann@                                                                                 | 9 🗈 be                                                               | eckmann.                            | 📝 i2c.vh                                                               | d (~/p 🗈     | beckman              | n <u>ल</u> Mo | delSim      | 0        |                 |         |         |     | м     |                   |

| 1   | 5us 🕈 🖹 | E 🗄 🗱   74 |
|-----|---------|------------|
| 3 🔹 | 3+   🐐  | Q Q Q Q 7  |
|     |         |            |

Nun kann man die Simulationszeit (hier 5 Mikrosekunden) einstellen und den Knopf "Run" drücken. Danach kann man im Waveformdisplay zoomen und sich das Ergebnis der Simulation anschauen.



Nach einer Mikrosekunde ändert sich der Wert von SW und LEDR von "000000000" auf "0000000001" und nach weiteren 3 Mikrosekunden auf "1000000000".

Mit "Simulate->End Simulation" kann man den Simulator verlassen.

## Debugging

In diesem Beispiel kommt es zu keinen Fehlern beim kompilieren des VHDL Codes. Wenn es doch zu Fehlern kommt, dann kann man im Fenster "Transcript" nachsehen, warum es zu Problemen gekommen ist.

Öffnen Sie das Fenster "Project" mit "View->Project" und Doppelklicken Sie auf "first.vhd". Es erscheint ein Fenster mit dem Sourcecode. Bauen Sie einen Fehler in den Code.

Starten Sie das Kompilieren mit "Compile -> Compile All".

Öffnen Sie das Transcript Fenster mit "View->Transcript".



Beim Übersetzen der Datei "first.vhd" ist es zu einem Fehler gekommen. Sie können jetzt auf die rot markierte Fehlerzeile doppelklicken.



Es erscheint ein Fenster mit den Fehlern bei der Übersetzung. Im Beispiel hier ist ein Fehler bei der Übersetzung der Datei "first.vhd" in Zeile 12 aufgetreten (Unknown identifier swe). Durch Doppelklicken auf diesen Fehler, wird der Fehler im Sourcecode angezeigt.



In diesem Beispiel hatte ich "SW" durch "SWe" ersetzt. Nach dem Korrigieren des Fehlers ist es notwendig, den Code neu zu übersetzen, bevor man eine neue Simulation durchführen kann.