Tutorial: DSim Studio
Contents
- Introduction
- Prerequisites
- Example design
- Open a project
- Create a project
- Add files to your project
- Add a Simulation Configuration
- Compile your design
- Run your design
- View the waveform
- Debug your design
- Run your design in the cloud
- Next Steps
Introduction
DSim Studio is a versatile Visual Studio Code (VSC) extension, offering unparalleled flexibility in HDL simulation, supporting both cloud-based and local (on-prem) workflows. This article describes how to use DSim Studio to run a simple simulation.
NOTE: The screenshots in this article may not exactly match what you see on your computer. The functionality and performance of DSim Studio remain the same.
Prerequisites
Example design
For this tutorial, use the carry_lookahead_adder example design. If you haven't already done so,
1. Download carry_lookahead_adder-main.zip.
2. Extract the zip file into a folder with read/write access.
3. Open the folder and rename the subfolder carry_lookahead_adder-main to carry_lookahead_adder.
4. Click the VSC Explorer and navigate to the folder /carry_lookahead_adder. If the folder is not visible in the VSC Explorer, open it by clicking Open Folder from the File menu.
If you want to simply compile and simulate this example design, proceed to Open a project.
If you want to create the project from scratch, proceed to Create a project.
Open a project
To open an existing project, simply right-click the project's .dpf file from the VSC Explorer and select DSim Studio: Open Project.
For this tutorial, navigate to the folder /VHDL_SystemVerilog/sim/, right-click carry_lookahead_adder_mixed.dpf and select DSim Studio: Open Project.
Then skip to the step Compile your design.
Create a project
Simulating designs in DSim Studio is project-based, so the first thing you need to do is create a project.
1. Navigate to the folder /VHDL_SystemVerilog, right-click the folder /sim and select DSim Studio: New Project.
2. Enter carry_lookahead_mixed for the Project File Name and click Save.
Add files to your project
As with any simulator, you need to know all the source files and their dependent files that need to be compiled, as well as what libraries they are compiled into. It is highly recommended that you use file lists to compile files of the same language and options.
Example steps
1. Navigate to /VHDL_SystemVerilog/sim, right-click filelist_VHDL.txt and select DSim Studio: Configure File.
2. This is a file list of VHDL files to be compiled into the library dut, so enter dut into the box Library Name (Optional), select VHDL from Choose a Language, and tick the box Configure as file list. Click Save.
3. Navigate to /testbench, right-click carry_lookahead_adder_directed_tb.v and select DSim Studio: Configure File.
4. This is a SystemVerilog file to be compiled into the default library work, so the defaults are correct. Click Save.
5. Click the DSim Studio view and expand the libraries in the LIBRARY CONFIGURATION.
The file list and file appear in their respective libraries. Note that there are different icons for file lists and files. The ? beside the libraries and files indicate that their Compilation Status is Unknown, ie. they have not been compiled yet.
Add a Simulation Configuration
Once you've finished adding all of your files to your project, you can add a Simulation Configuration. This enables you to elaborate and run different simulations on the same set of compiled libraries. Add a new Simulation Configuration:
1. Hover over the SIMULATION CONFIGURATION drop-down menu and click the + button.
2. Enter the following in the Configure Simulation tab:
- Sim 1 for the Simulation Name.
- -top work.carry_lookahead_adder_tb -L dut +acc+b -waves waves.mxd for the Options. These are the DSim options executed when you hit the 'Run' button. In our example, this elaborates and runs the testbench as the top-level module and generates a waveform file during runtime as specified by the Options:
-top work.carry_lookahead_adder_tb: top-level module is carry_lookahead_adder_tb found in the compiled library work
-L dut: : search these compiled libraries
+acc+b: generate support for waveform dump
-waves waves.mxd: enable wave dump to waves.mxd
Click Save.
For common DSim options, see the DSim column under the Standard Options section of DSim Common Options.
Compile your design
1. Click the 'Compile Project' play button under the LIBRARY CONFIGURATION to compile your project.
All of the executed DSim simulator commands and their resulting output are displayed in the OUTPUT window. A notification pops up indicating the overall result of the compile. The ? beside the libraries in the LIBRARY CONFIGURATION turn into check marks after the successful compilation of the library.
Optionally, click the 'Turn Auto Scrolling On' button (lock icon) in the OUTPUT window to have the output scroll automatically.
Run your design
After the successful compilation of your design, you can run it locally (on-prem) by simply clicking the 'Run' button beside Sim 1 in the SIMULATION CONFIGURATION.
All of the executed DSim simulator commands and their resulting output are displayed in the OUTPUT window. A notification pops up indicating the overall result of the run. A check mark appears beside Sim 1 in the SIMULATION CONFIGURATION after a completed simulation run.
View the waveform
1. Click the VSC Explorer and double-click on /VHDL_SystemVerilog/sim/waves.mxd.
2. Use the integrated waveform viewer like you would any other waveform viewer. See User Guide: DSim Waveform Viewer for details.
3. Close the waves.mxd tab when you're done. Subsequent simulations will overwrite this waveform file unless you change its name in the Simulation Configuration Options dialog box.
Debug your design
1. Using a combination of the waveform waves.mxd, the compilation log dvlcom.log, and the simulation log dsim.log, debug your design.
2. Make any necessary changes to your HDL and testbench files in the VSC Explorer and save them.
3. Close all the tabs in the Editor pane.
4. You only need to re-compile the files or libraries that have changed. For example, if you only changed the testbench file, click the 'Compile File' play button next to carry_lookahead_adder_directed_tb.sv in the LIBRARY CONFIGURATION of the DSim Studio view.
5. After the successful re-compilation of your design, you can re-run it by simply clicking the 'Run' button beside Sim 1 in the SIMULATION CONFIGURATION.
Run your design in the cloud
1. When you're ready to run your simulation in the cloud, click the 'Run in DSim Cloud' button next to the desired Simulation Configuration.
2. DSim Studio automatically converts your local simulation to a job file and submits it to the cloud. You must be signed into your DSim Cloud account to submit a job to the cloud. A notification pops up indicating the status of your job submission. When it is complete, click the 'Show Jobs' button, or in your DSim Studio view, expand the JOBS section to see your job.
3. Expand your job to see the status of each task. Sometimes it may take a while (several minutes) for remote cloud resources to become available to run your job.
4. Once your job is complete, click the 'Download All Artifacts' button to retrieve your simulation artifacts.
5. A notification pops up indicating the status of your artifact download. When it is complete, click the 'Reveal in Explorer' button or in your VSC Explorer view, navigate to /VHDL_SystemVerilog/sim/_downloaded_artifacts/carry-lookahead-mixed-xxxxx/work.
6. Your VSC Explorer will open to the folder where your simulation artifacts were downloaded from your simulation in the cloud.
Next Steps
1. Play around with the DSim Studio GUI. Right-click on the files in the VSC Explorer to see what options are available. The DSim Studio options are prefixed with DSim Studio:. Right-click on the files in the LIBRARY CONFIGURATION and SIMULATION CONFIGURATION to see what options are available.
2. Create your own projects for the carry_lookahead_adder design:
- For the SystemVerilog version of the design (hint: use /SystemVerilog/sim/filelist.txt).
- For the VHDL version of the design.
- Using no file lists and only individual files.
3. Create and simulate your own designs.
Was this article helpful?
That’s Great!
Thank you for your feedback
Sorry! We couldn't be helpful
Thank you for your feedback
Feedback sent
We appreciate your effort and will try to fix the article