## Simulation in der Xilinx ISE Umgebung mit Modelsim

## 1. Möglichkeiten des Erstellens eines VHDL TestbenchFiles

In der Xilinx Entwicklungsumgebung kann mit einem Wizzard ein VHDL Testbench File Erstellt werden. Dies enthält aber nur einen Kopf mit Signalnamen und es ist erheblicher Editieraufwand erforderlich, um eine Simulation zum Laufen zu bringen.

Schneller geht es über den Weg des Erstellens eines "Testbench Waveform" Files mit einem Wizzard, bei dem bei Erstellen zusätzlich die Möglichkeit besteht ein oder mehrere Clocksignale zu definieren.

Danach können dann noch in einem Waveform Viewer per Mausklick alle vorkommenden Signale zu bestimmten Zeitpunkten auf bestimmte Werte gesetzt werden.

Hier gibt es die Einschränkung, dass dieses immer nur für genau 1 bis n-Perioden passieren kann, und dass auch keine automatische Überprüfung der Simulation möglich ist, so das diese Art der Simulation nur sehr grob ist.

Für den Fall, das diese Simulation nicht reicht, kann aber auf einfache Art und Weise aus dem "Testbench Waveform" File ein "VHDL Testbench" File erstellt werden, in der die Stimulidaten aus dem "Testbench Waveform" File enthalten sind.

Dieses wird im Folgenden beschrieben.

2. Erstellen eines "Testbench Waveform" Files

Dazu im Fenster "Sources in Project" auf das VHDL Modul gehen für das eine Testdatei erstellt werden soll. Hier Rechte Maustaste betätigen und "New Source auswählen"

| 📚 Xilinx - Project Navigator - C:\Sprint3\G | iKI2\PLD\V260207\GKI\GKI.ise    |
|---------------------------------------------|---------------------------------|
| File Edit View Project Source Process 3     | 5imulation Window Help          |
|                                             |                                 |
|                                             | X                               |
| Sources in Project:                         |                                 |
| GKI.ise                                     |                                 |
| 🗄 🛄 xc95144xl-10tq100                       |                                 |
| 📄 🖄 👷 gki_top-gki_top_arch (gki_top.vhd)    |                                 |
| 🚽 🔄 testgkitop (testgkitop.tbw)             |                                 |
| gkilv.ucf                                   |                                 |
| 🖃 🖤 💟 statembi-statembi_arch (statemt       | pi, vhd)                        |
| compining-archi (inreg.vng                  | New Source                      |
| estoutreg-benavioral (o                     | Add Source Insert               |
| statemechtzeit-statemechtzeit               | Add Copy of Source Shift+Insert |
| •                                           | Remove Delete                   |
| 🗖 📲 Module View 💼 Snapshot 🖺 Lit            | Move to Library                 |
|                                             | Open                            |
| Processes for Source: "compinreg-archi"     | Toggle Paths                    |
| Add Existing Source                         | Properties,                     |
| Create New Source                           |                                 |
| Create Schematic Symbol                     |                                 |
| Bild 1                                      |                                 |

Im folgenden Fenster "Test Bench Waveform auswählen" und einen Filenamen für die Simulationsdatei wählen. Hier im Beispiel "testInReg"

| <ul> <li>Implementation Constraints File</li> <li>Schematic</li> <li>State Diagram</li> <li>Test Bench Waveform</li> <li>User Document</li> <li>Verilog Module</li> <li>Verilog Test Fixture</li> <li>VHDL Library</li> <li>VHDL Module</li> <li>VHDL Package</li> <li>VHDL Test Bench</li> </ul> | Eile Name:<br>testInreg<br>Logation:<br>C:\Sprint3\GKI2\PLD\V26020 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                   | Add to project                                                     |



| iource rile | gki_top                                               |  |
|-------------|-------------------------------------------------------|--|
|             | statembi<br>compinieg<br>compoutreg<br>statemechtzeit |  |
|             |                                                       |  |
|             |                                                       |  |
|             |                                                       |  |
|             |                                                       |  |

Nach Button Weiter erschein Fenster "Select"

Bild 3

Hier ist bereits das Modul markiert das beim Auswählen in Sources in Project" gewählt wurde.

Für diese Modul wird beim Klick auf "Weiter" und nach Bestätigen des folgenden Fensters "New Source Information" das Fenster "Initialize Timing angezeigt"

| Initialize Timing                                                                                                                                                                 | ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Maximum<br>output delay<br>Clock<br>high for                                                                                                                                      | Minimum ▲<br>input<br>setup →<br>Clock<br>low for                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Clock Timing Information<br>Inputs are assigned at "Input Setup Time" and<br>outputs are checked at "Output Valid Delay".<br>Rising Edge C Falling Edge<br>Dual Edge (DDR or DET) | Clock Information<br>Single Clock INCLK<br>Multiple Clocks<br>C Combinatorial (or internal clock)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Clock Time High100nsClock Time Low100nsInput Setup Time15nsOutput Valid Delay15nsInitial Offset0ns                                                                                | Combinatorial Timing Information         Inputs are assigned, outputs are decoded then         checked. A delay between inputs and outputs avoids         assignment/checking conflicts.         Check Outputs       50         ns       After Inputs are Assigned         Assign Inputs       50         ns       After Outputs are Checked                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Global Signals<br>PRLD (CPLD)<br>High for Initial:                                                                                                                                | Initial Length of Test Bench:       1000       ns         Time Scale:       ns       Image: Comparison of the second se |

## Bild 4

In diesen Fenster können nun die Signale definiert werden, bei den in der Simulation ein regelmäßiger Takt erscheinen soll.

Nach Klick von Button "OK" wird ein Fenster mit allen in dem Modul vorkommenden Signalen angezeigt.

| testInreg.tbw        |      |        |        |        |        | » <u>- 0</u> 2 |
|----------------------|------|--------|--------|--------|--------|----------------|
| 1 ሐ ሶ ሳ ዊ            | 9.20 |        |        |        |        |                |
| End Time:<br>1000 ns |      | 100 ns | 300 ns | 500 ns | 700 ns | 900 ns         |
|                      | 0    |        |        |        |        |                |
| 🕕 SData              | 0    |        |        |        |        |                |
| 🗄 秋 InReg(13:0)      | 0    |        |        | 0      |        | 10.6e          |
|                      |      |        |        |        |        |                |
|                      |      |        |        |        |        |                |
|                      |      |        |        |        |        |                |
|                      |      |        |        |        |        |                |
|                      |      |        |        |        |        |                |
|                      |      |        |        |        |        |                |
|                      |      |        |        |        |        |                |



In diesem Fenster kann durch Klick auf die entsprechende Position im Signal der Verlauf des Signals ab der Stelle geändert werden. Einfach probieren. Die Gesamtzeit der Simulation kann durch Rechtsklick auf "End Time:" und folgendem Auswählen von "Set End of Testbench" eingestellt werden.



Damit sind die Möglichkeiten der Grafischen Eingabe weitgehend ausgeschöpft.

Jetzt muss die Testbench Waveform noch abgespeichert werden durch Klick auf oder CTRL+S.

Im Fenster "Sources in Project" erscheint nun ein neuer Eintrag mit der Testbench Waveform Datei. Hier im Beispiel die Datei "testInreg(TestInreg.tbw"



Die neue Datei anwählen und unten im Fenster (Bild 7 :siehe Mauszeiger) auf "Process View" kicken.

ACHTUNG: An dieser Stelle aufpassen, dass das "Testbench Waveform" File selektiert wird und nicht z.B. das VHDL Modul, sonst läuft im folgenden Modelsim zwar auch los, aber es wird nichts simuliert.

Es erscheint folgende Ansicht:



Bild 8

Hier kann nun die Simulation durch Klick auf "Simulate Behavioral VHDL Model" gestartet werden.

In Modelsim wird dann das Ergebnis der Simulation angezeigt.

Bis hier hin ist dies der normale Ablauf zum Simulieren einer "Testbench Waveform"

3. Erstellen eines "VHDL Testbench" Files aus dem zuvor erstellten Testbench Waveform" File.

Wenn die Simulation gestartet wird, wird von der Xilinx Entwicklungsumgebung im Design Directory ein File mit der Endung "vhw" angelegt, hier im Beispiel das File "testInReg.vhw".

Dies entspricht dem zuvor definierten Simulationsfile, ist aber ein VHDL Testbench File.

ACHTUNG: Die einzige Angabe die nicht in dem File steht, ist Gesamtzeit der Simulation, diese muss später in den Eigenschaften von "Simulate Behavioral VHDL Model" eingetragen werden.

Dies File nun mit Explorer oder einem anderen Dateimanger umbenennen in "\*.vhd" also hier im Beispiel in "testInreg.vhd".

Dann in Fenster "Sources in Project" (Bild 7) gehen und das vorher definierte File "testInreg(TestInreg.tbw") mit Taste "Entf" aus Project löschen.

Nun geht's wieder los wie am Anfang mit dem Fenster, "Sources in Project" (Bild1) nur das im Folgenden "Add Source" gewählt wird.





"\*.vhd" (hier im Beispiel "testInreg.vhd") angezeigt wird.

Diese auswählen, dann erscheint folgendes Fenster



Bild 10

Hier "VHDL Testbench File" auswählen und bestätigen.

Nun taucht das gewählte File an passender Position im "Sources in Project" Fenster auf.



Im unteren Fenster "Processes for Source" könnte nun schon durch Doppelklick auf "Simulate Behavioral Model" die Simulation gestartet werden, da aber die Gesamtsimulationszeit nicht im "VHDL Testbench" File steht, muss diese noch wie gewünscht eingestellt werden.

Dazu im Fenster "Processes for Source" mit rechter Maustaste auf "Simulate Behavioral Model" klicken und dann "Properties" anwählen.

| Processes for Source: "testinreg-testbench | arch''                |
|--------------------------------------------|-----------------------|
| Add Existing Source                        |                       |
| Create New Source                          |                       |
| 📄 🖻 🍟 ModelSim Simulator                   |                       |
| Simulate Behavioral Mod                    | Rup                   |
| Simulate Post-Fit VHDL N                   | Rerup                 |
|                                            | Rerup All             |
|                                            | Stop                  |
|                                            | Open Without Updating |
|                                            |                       |
|                                            | Properties.           |
|                                            |                       |
|                                            |                       |
|                                            |                       |
|                                            |                       |
|                                            |                       |
|                                            |                       |
|                                            |                       |
|                                            |                       |
|                                            |                       |

Bild 12

Im folgenden Fenster kann dann die Gesamtsimulationszeit in der Zeile "Simulation Run Time" eingestellt werden.

| simulation Properties | Display Properties             |          |
|-----------------------|--------------------------------|----------|
| Р                     | roperty Name                   | Value    |
| Ise Custom Do File    |                                |          |
| ustom Do File         |                                | N/A      |
| Ise Automatic Do File | •                              |          |
| imulation Run Time    |                                | 1 000ns  |
| JUT Instance Name     |                                |          |
|                       |                                |          |
|                       | <u>P</u> roperty display level | Standard |

Bild 13

Fenster schließen und durch Doppelklick auf "Simulate Behavioral Model" nun die Simulation starten.

Das \*.vhd Testbench File (hier z.B. testInreg.vhd) kann jetzt um sämtliche Kommandos, die in der "Modelsim Command Reference" beschrieben sind erweitert werden.