

## Vivado Simulator

In Vivado, simulation is handled by **XSim**, the built-in simulator fully integrated into the Vivado GUI. This allows you to run HDL simulations directly within the environment, without needing to launch external tools like ModelSim. While external simulators can still be used if preferred, XSim provides a convenient and efficient solution for most simulation tasks, seamlessly fitting into the Vivado design flow.

**Vivado provides two main methods for simulating VHDL designs:**

### 1. Simulation without a Testbench (Manual Signal Forcing)

This method is useful for very simple circuits and quick demonstrations. You write your VHDL module (e.g., an AND gate), then use Vivado's built-in simulation environment to manually set input signals and observe the output directly.

**This is suitable when:**

- You want to test individual logic gates or small modules
- You don't need automated test cases
- You're learning basic VHDL behavior

**Example:** Simulating a simple AND gate by manually forcing inputs a and b, and observing the output y.

### 2. Simulation with a Testbench

In this method, you write a separate VHDL file (testbench) that generates input signals and checks the output. You can also write test benches the same way as you did in ModelSim no syntax change. This is the recommended approach for larger systems, where testing needs to be automated and reproducible.

**This is used when:**

- Your design includes multiple components
- You want to run multiple test cases quickly
- You need to validate logic and timing in a structured way

The testbench instantiates the design under test (DUT) and applies various input combinations over time.

## Other Simulation Tools (Optional)

Vivado comes with a built-in simulator, but it is also possible to use external simulators such as ModelSim. However, using ModelSim from within Vivado requires a separate license, and is not available by default in all Vivado installations.

### Now we will go through the two methods of simulation in Vivado.

The previous project (AND Gate) can also be used to simulate with manual constant forcing.

To start click on **Run Simulation** in the project manager menu and then **Run Behavioral Simulation**.



The waveform window of the simulated file now appears, showing undefined signals (U).



We need to define the signals, and we do that by right clicking on each signal and selecting **Force Constant and**.



Now a window will appear showing:

- **Signal name:** The signal to be forced (here: /and\_gate/a)
- **Value radix:** The number format (Hexadecimal, Binary, etc.)
- **Force value:** The value you want to set (1 or 0)
- **Starting after time offset:** When the value should start (e.g., 0ns)
- **Cancel after time offset:** (Optional) When to stop forcing the value

In this case for signal **(a)** the value will be **(1)**.



Click **OK** to apply.

And the same thing for the signal **(b)** because it and gate.



This image shows the simulation time control bar in Vivado's waveform viewer. Here's a simple explanation:

## Simulation Time Control (Vivado)

- **Play buttons:** Used to run or step through the simulation.
- **Time box (1000 ns):** Specifies how much simulation time to run when stepping forward (here: 1000 nanoseconds), it will be 100 ns in this case.
- **Time unit** Next to the time box here you can **change** the time unit (e.g., ns, μs, ms).
- **Reload/Rerun button:** Restarts the simulation from the beginning.

After changing the simulation time click on **Run** or (**Shift+F2**).



If the **a** and **b** have the value **(1)** then the output signal **y** will be **(1)** as shown in the image below.

| Name | Value |
|------|-------|
| a    | 1     |
| b    | 1     |
| y    | 1     |

Now let's change the value of one of the inputs to **(0)**.

| Name | Value |
|------|-------|
| a    | 1     |
| b    | 0     |
| y    | 0     |

The output **y** is currently **(0)**, which is correct.

To repeat this process of changing the value we will force the clock this time to do this choose a signal and left click on it then select **Force Clock**.



This image shows the "**Force Clock**" dialog in a simulation environment (likely Vivado or ModelSim), where you can apply a periodic clock-like signal to a selected input signal in this case input **a**. You can change the period if you want to, I changed it to 20ns. Click when you are done.

### Simple explanation:

- **1** on the rising edge (start of pulse)
- **0** on the falling edge (end of pulse)
- **Start time:** 0 ns
- **Period:** 20 ns
- **Duty cycle:** 50% (equal time for 1 and 0)

Now the signal **a** will toggle between 1 and 0 every 20 ns, and the value of **y** will change accordingly as shown in the image below.



In general, every action you perform in the simulation GUI (such as forcing signals, running the simulation, or setting waveforms) automatically translated into **Tcl commands** behind the scenes. These commands appear in the **Tcl Console**.

```
add_force {/and_gate/b} -radix hex {0 0ns}
run 100 ns
add_force {/and_gate/b} -radix hex {1 0ns}
run 100 ns
add_force {/and_gate/a} -radix hex {1 0ns} {0 10000ps} -repeat_every 20000ps
run 100 ns
run 100 ns
run 100 ns
```

The screenshot shows the **Tcl Console** window with a history of commands. The commands listed are used to force signal **a** to 1 for 100 ns, then 0 for 100 ns, and then repeat this sequence every 20000 ps. The console also includes standard navigation buttons like back, forward, and search.

## What does this mean?

- add\_force: Sets a value to a signal.
- {1 0ns} : The signal is 1 at time 0 ns.
- {0 10000ps} : The signal becomes 0 at 10 ns.
- -repeat\_every 20000ps: This pattern (1 → 0) repeats every 20 ns (i.e. a clock).
- run 100 ns: Run the simulation for 100 ns.

## Why is this useful?

- You can **run simulations using only commands**, without using the GUI.
- It's great for **automation or repeating tests**.
- You can **copy commands** from the transcript and reuse them (I'll show you how in the demo video).

Even if you prefer using the GUI, always check the **Tcl transcript**. It shows you exactly what's happening behind the scenes and gives you full control when you need it.

(More on Tcl will be in a separate document).

Now we are done with the first simulation method. Click on the link below to watch the first demo video for simulation in Vivado.

[https://www.youtube.com/watch?v=99KIT\\_HBI74](https://www.youtube.com/watch?v=99KIT_HBI74)

## Simulation with a Testbench

Right click on **Simulation Sources** then **Add Sources** To add or create a testbench to your design.



Now you choose **Add or create simulation sources** and click **Next**.



If you already have a testbench you want to use, click on **Add Files**.



**Specify simulation set:** The currently active simulation fileset is the default fileset to add simulation files to. However, you can also select another existing sim\_set or create a new simulation fileset for the project. Selecting Create Simulation Set will open the Create Simulation Set dialog box letting you specify the name for the new simulation fileset.

In this case we will not add or change the simulation set.

Click on **Create File** to create a testbench.



Change the language and give a name for the file, click on **OK** and **Finish**.

The same window that appears when creating any file will now appear to help you create a ready-made template. However, this time you will skip it because no ports need to be defined in a testbench.



Click on **OK** and **Yes**.

Now your empty testbench has been added to the simulation sources and you can start writing your test cases in it.



Click on **Save** when you are done

```

1 process
2 begin
3     -- Reset i början
4     reset_n <= '0';
5     wait for 20 ns;
6     reset_n <= '1';
7
8     -- Kör i 200 ns
9     wait for 200 ns;
10
11    -- Stoppa simuleringen
12    wait;
13 end process;
14 end Behavioral;

```

Everything is ready now to simulate the design, click on **Run Simulation** and **Run Behavioral Simulation**.



Click on the Restart icon and change the simulation time if you want to.



Click on the **Start** button to run the simulation.



In the toolbar of the Wave window, you can zoom in and out as you like.



Click on the link below to watch the demo video for this part.

<https://www.youtube.com/watch?v=1Ur5L09UKSU&t=2s>

**Congratulations!** Now you can simulate in Vivado using two methods: Manual Signal Forcing and Simulation with testbench.