仿真搭建的目的是帮助用户能快速搭建起自己的仿真框架,并快速的获得仿真结果。
# 产生例化 & tb file
虽然自动补全可以实现例化的自动补全,但是无法阅览整个项目所有可用的模块并从中选择,因此我们提供了自动例化的功能;除此之外我们还提供了自动生成选定模块testbench的功能。
该插件支持不同语言间的交叉例化,比如在verilog文件中例化verilog和vhdl模块,或者在vhdl文件中例化Verilog和vhdl模块。
步骤如下:
- 将光标放置在文本需要例化处。
- 使用快捷键
F1
启动命令框,输入Instance,选择Instance
。- 或者使用快捷键
Alt + I
。 - 或者在需要例化处右击选择
Instance
- 或者使用快捷键
- 输入需要例化的模块的关键字(插件会自动匹配)。
- 选择需要例化的模块。
【注】
:在使用快捷键时,需检查是否存在快捷键键冲突。
除了自动例化外,插件还提供了一个verilog的仿真模板,使用方式如下:
F1
启动命令框,输入Testbench, 选择testbench
- 或者在需要生成并例化的文件下右击选择
Testbench
。
- 或者在需要生成并例化的文件下右击选择
- 选择仿真文件的类型以及需要存储的位置,如果存在直接替换即可。
如果想要更改testbench模板的话步骤如下:
使用快捷键F1
启动命令框,选择TOOL:Overwrite the template of testbench,选择要更改的仿真文件的类型,这时会打开testbench file的初始化文件在此基础上更改保存即可。此外请保留 //Instance
标志,该标志是用于识别需要例化的位置。
后期会考虑tb文件与例化模块间的智能连线。
# 快速仿真
该功能的目的是为了能快速地对单个模块,或几个模块组成的小工程进行快速地仿真。
iverilog快速仿真
- 如果想要使用该功能,请自行下载iverilog,并加入环境变量。
- VCD渲染目前使用的是wavetrace这个vscode插件,下一个版本会推出我们开发的内嵌波形渲染器,而且完全免费。
- 多文件仿真我们建议不要写include,如果写了include,请在property.json中加入所有include的文件的文件夹路径,例如:
{
...
"iverilogCompileOptions": {
"standard": "2012",
"includes": [
"${workspace}/src",
"${workspace}/src/Controller",
"${workspace}/src/DataPath"
]
},
...
}