

# Tutorial

## Running ModelSim From Within Quartus



EECS 3216, Digital Systems Engineering  
Modelling, Implementation and Validation

Winter 2021

By Jaspal Singh, Engineering Technologist,  
Lassonde School of Engineering. EECS  
York University, Toronto.

# 1 MODELSIM FROM WITHIN QUARTUS

---

This tutorial describes, how to run a ModelSim simulation (RTL) from within the Quartus SW IDE.

Follow the steps described here for running ModelSim from within the Quartus Software.

It is **assumed** that you have already Installed Quartus 20.1 Lite, the Max10 Device files and ModelSim simulator, as described in the '*Tutorial\_QuatusInstallAndVerify*' document, which describes steps to install the SW and test your setup.

## 1.1 SETUP WITHIN QUARTUS

---

1. Download and save the following three Verilog files provided on the eClass website.  
The files contain design of a Full Adder and a Test bench.

half\_adderV.v  
full\_adderV.v  
full\_adderV\_tb.v                          This is a simple testbench.

2. Now follow the instructions in the '*Tutorial\_QuatusInstallAndVerify*' document, to create a project using these files. Use a suitable *project directory*, *project name* however enter **full\_adderV** as your top\_level module.
3. Add three provided files in the project you created, following the steps in '*Tutorial\_QuatusInstallAndVerify*' document.
4. Make sure that **full\_adderV** is indeed the top level, by right clicking on the file name and selecting 'set as top level entity' as shown below.



5. Run the 'Analysis and Synthesis' which is a step within the Compile Design process.



Pay attention to any code or syntax related Error messages, before proceeding to RTL Simulation, for you will likely get them in ModelSim too.

## 1.2 START RTL SIMULATION

---

After your design compiles satisfactorily, you are ready to start ModelSim simulator.  
If encountered code or syntax related Error messages, try fixing them, before proceeding to RTL Simulation.

However before ModelSim can be run, it is required to specify the path, where the ModelSim executable is located. Specify it by going the **menu Tools -> Options** and the Selecting 'EDA Tool options' under the General settings and specify your specific path, where the executable is located.



After having specified the path, run ModelSim by selecting **menu -> Run Simulation Tool -> RTL Simulation**. If you followed all the steps correctly, including steps in '*Tutorial\_QuatusInstallAndVerify*', ModelSim would now start and you would see the following screen.



You would see both ‘full\_adderV’ and ‘half\_adderV’ in the ‘work’ library.

## 1.3 ADD TESTBENCH OR OTHER FILES

To also **add the testbench**, 'full\_adderV\_tb' go **menu Compile -> Compile...** which opens the 'Compile Source Files' window.

- By default it opens within the 'modelsim' folder of your Quartus project.
- Browse to the directory, i.e. your parent Quartus project directory, which contains your Design and the Testbench files.
- Since the two design files are already in the ModelSim library, just select the testbench file and click on Compile.
- After the compile operation, click Done, to close the window.



You will now see that 'full\_adderV\_tb' has also been compiled and added to the 'work' library and it has now become the Top level module.

## 1.4 START SIMULATION

Now you are ready to start simulating. Do **menu -> Simulate -> Start Simulation**. In the window which opens, select 'full\_adderV\_tb' and click OK, as shown below.



This runs the 'vsim' command, which starts the Simulator. You will now see

- A new 'Sim' tab, which shows your Top level module and the lower instances below it.
- An 'objects' window, which shows the 'Signals' as per the selected Instance, in the Sim tab.
- A 'Wave' window, to which the Signals can be added and on running the Simulation, results are seen as a waveform, on those signals.



## 1.5 ADD SIGNALS

We now add the signals to the Waveform window, before running the Simulation, as shown below.

To add the signals to the Wave window do

- Select the appropriate instance, in the 'Sim' tab
- You will now see the signals of this instance, within the 'Objects' window.
- Select the signals, you want displayed and right-click your mouse, and then select 'Add Wave' to add in the Wave window.

As you add the signals, the Transcript Pane will display corresponding messages.



## 1.6 RUN SIMULATION

To run the simulation, few options are available.

- **Run 100ns**, will run the simulation for 100ns, or as per time specified by you.
- **Run -All** will continue running the simulation, till a *Breakpoint* is hit or a statement like \$stop is hit.

You can stop a simulation, by selecting the 'Break' command.

The commands can be run from the **menu Simulate -> Run ->** or from the **Icons** shown, or by typing in the Transcript pane.



Since in our testbench there is a \$stop statement, at the end, just type **run -all** (lowercase) in the *Transcript pane*.

In our case, you will see that Transcript pane shows the signals, anytime one of them changes, due to the \$monitor command. Further, the Wave window shows the top level, testbench signals as well signals of the instance, 'my\_full\_Adder'



You can try additional things like adding more signals to wave window, from other instances in your design, e.g. from the Half Adder, and **restart** your simulation and run it again.

To end your simulation, do **menu Simulate -> End Simulation**

You exit ModelSim, by doing **menu File -> Quit** This closes ModelSim and takes you back to the Quartus SW.

This concludes the tutorial.

## 1.7 ADDITIONAL INFORMATION

---

Refer to the online resources on ModelSim, including the **ModelSim User Manual** and **Mentor ModelSim Tutorial** which provide lot more detail about additional features of this tool, particularly in using this simulator in a Standalone mode, independent of Quartus software.