[X]关闭

[米联客-安路飞龙DR1-FPSOC] FPGA基础篇连载-03安路TD结合modelsim仿真

文档创建者:FPGA课程
浏览次数:679
最后更新:2024-07-28
文档课程分类-安路-DR1
安路-DR1: FPSOC-DR1-FPGA部分 » 2_FPGA实验篇(仅旗舰) » 1-FPGA基础入门实验
本帖最后由 FPGA课程 于 2024-7-28 20:37 编辑

软件版本:Anlogic -TD5.9.1-DR1_ES1.1
操作系统:WIN10 64bit
硬件平台:适用安路(Anlogic)FPGA
实验平台:米联客-MLK-L1-CZ06-DR1M90G开发板
板卡获取平台:https://milianke.tmall.com/
登录"米联客"FPGA社区 http://www.uisrc.com 视频课程、答疑解惑!


1概述
FPGA开发中对设计的代码功能进行必要的仿真可以提高研发效率,详尽的测试条件更能让一些设计隐患提前发现,所以代码的仿真在FPGA开发中非常重要,对于初学者一定不能只满足于表象的功能实现,而应该严谨的对自己编写的代码进行充分仿真验证,之后上板验证。
在进行本实验前,请提前安装好modelsim。本实验所实用的modelsim版本为modelsim-win64-10.6d-se。

实验目的:
1:掌握modelsim如何编译TD的FPGA库
2:掌握modelsim如何仿真安路
3:掌握TD软件如何设置modelsim仿真
4:掌握从TD调用modelsim的仿真方法

2仿真库的编译
以DR1器件为例,TD软件自带有仿真模型,并可在modelsim进行编译,步骤如下:
1:在 modelsim 的安装目录下,新建文件夹,如:anlogic,
2504661-20240723193349904-1804855060.jpg
2:启动 modelsim,选择 file → change directory 将路径转到 anlogic 文件夹下
2504661-20240723193350470-27252525.jpg
2504661-20240723193350998-78118318.jpg
3:在 modelsim 的 file → new → library下新建名为DR1的库
2504661-20240723193351632-870451762.jpg
2504661-20240723193352158-346410938.jpg
5:打开 compile → compile,弹出compile souce files对话框,library中选择刚建立的DR1,查找范围选择 src 下的所有文件,勾选 compile selected files together,执行编译命令
2504661-20240723193352645-191775133.jpg
2504661-20240723193353012-906059318.jpg
TD路径下的FPGA器件仿真库文件具体路径如下:
2504661-20240723193353425-505646521.jpg
单击一个文件,安装ctrl+a全选,之后单击Compile
2504661-20240723193353840-1659441124.jpg
编译成功后单击Done
2504661-20240723193354305-75333914.jpg

3使用modelsim仿真验证3.1 方法一使用modelsim创建仿真工程
本文实验在前一个demo的基础上完整。
1: 选择 file → change directory
2504661-20240723193354743-609031700.jpg
2504661-20240723193355201-1972887137.jpg
1:在 modelsim 中,点击 file → new → project,新建 project,如:sim_prj
2504661-20240723193355593-298059239.jpg
2504661-20240723193355985-1013096824.jpg

2:可点击 add existing file 添加设计文件,也可点击 Create New File 创建新的设计文件,并将其添加到工程。
2504661-20240723193356356-722035408.jpg
3:可以连续多次把需要仿真的文件都添加进来
2504661-20240723193356938-1206895181.jpg
2504661-20240723193357364-2067823010.jpg
4:点击 进行编译,编译成功后,源文件的状态将会由"?"变成"✔"
2504661-20240723193357820-1428221574.jpg
5:点击 simulate → start simulate,在 work Library 中选择 testbench 文件进行仿真,如果想仿真后,在模块列表中查看各信号参数或波形的变化情况,可将"Enableoptimization"前面的勾去掉,否则,Modelsim 会将信号参数优化掉,导致信号列表为空。
2504661-20240723193358223-583344604.jpg
2504661-20240723193358623-2091127649.jpg
6:然后选择 libraries 点击 add,选择之前编译的DR1路径。
2504661-20240723193359084-2030630070.jpg
2504661-20240723193359510-1410932170.jpg
点击 OK 进行仿真

2504661-20240723193359947-33825836.jpg
2504661-20240723193400406-271940193.jpg
如果波形窗口没有出来,单击View->Wave调用出来,其他窗口没有出来的也能通过这里设置
2504661-20240723193400835-1634662723.jpg
点击u_pll_test,选择需要观察到波形窗口的信号
2504661-20240723193401275-478468262.jpg
右击,把信号添加到波形窗口

2504661-20240723193401718-1392150060.jpg
2504661-20240723193402113-1947219307.jpg
设置单步仿真10us
2504661-20240723193402526-1354063816.jpg
2504661-20240723193402896-2076092868.jpg

3.2 方法二使用直接编辑仿真文件仿真
除了第一种方法,对于有一定经验的工程师可以使用第二种更加便捷的方法。
首先看下本工程路径下提供了2个模板文件
2504661-20240723193403252-1236097760.jpg
cmd.do改文件可以直接在modelsim控制台中执行,其中C:/modeltech64_10.6d/anlogic/DR1就是我们前面编译好的仿真库
## part 1: create lib
vlib work
vmap work work

## part 2: load rtl
vlog -timescale 1ps/1ps -sv -f compile.f

## part 3: sim
vsim -L C:/modeltech64_10.6d/anlogic/DR1 -gui -novopt work.sim_top_tb
#vsim -voptargs=+acc work.pll_test_tb

## part 4: add wave
#do wave.do
add wave *

## part 5: show ui
view wave
view structure
view signals

## part 6: run sim
#run -all
run 1000ns

compile.f 设置编译文件的路径,一般只要对compile.f进行修改,本工程只用到了3个文件
../01_rtl/pll_test.v
../02_sim/sim_top_tb.v
../03_ip/al_ip/mypll.v
../03_ip/mypll/DR1_PHY_PLL_WRAPERR_83aa86f42154.v

把cmd.do和compile.f复制到uisrc/02_sim路径
2504661-20240723193403602-131545130.jpg
打开modelsim并且设置路径
2504661-20240723193404028-2107577864.jpg
选择路径
2504661-20240723193404488-1486184291.jpg
在控制台输入do cmd.do
2504661-20240723193404963-1811220948.jpg
可以看到波形完成加载
2504661-20240723193405464-1024852712.jpg
之后的仿真和前面的方法一样。

3.3 方法三使用TD联合仿真
3.3.1 仿真参数设置
TD 支持用户使用第三方工具(如 Synopsys VCS、 Mentor Graphics Modelsim 等)来进行功能验证和时序验证。TD 提供仿真所需的功能和时序模型。
在进行TD联合调试前,请根据本实验前面内容完成仿真库的编译。
以下介绍在TD软件中生成供Modelsim 仿真所需文件的流程。
1:在运行 HDL2Bit Flow 前,先设置相关参数。
2504661-20240723193405963-603690223.jpg
2:点击 Simulation进行仿真相关的设置,设置与当前创建的工程相关联。
2504661-20240723193406349-215149881.jpg
3.3.2 仿真文件do文件设置
1:运行 HDL2Bit Flow
对于向执行什么级别的仿真,就执行对应的HDL2Bit Flow
当 HDL2Bit Flow 运行至 Read Design 这一步时,可执行 Behavioral Simulation;
当 HDL2Bit Flow 运行至 Optimize RTL 这一步时,可执行 Post-RTL Simulation;
当 HDL2Bit Flow 运行至 Optimize Gate 这一步时,可执行 Post-Gate Simulation;
当 HDL2Bit Flow 运行至 Optimize Routing 这一步时,可执行 Post-Route Simulation。
以执行Behavioral Simulation仿真来说,只要执行Read Design 这一步,如下图
2504661-20240723193406820-278117160.jpg
2:TD界面仿真库编译
2504661-20240723193407225-1130871767.jpg
testbench文件可以新建一个tb或者添加一个已经编写好的tb仿真文件,这里我们添加已经编写好的。
2504661-20240723193407647-696996507.jpg
(1)Simulator:选择仿真工具,目前支持 Modelsim 以及 Questasim;
(2)Executable Path:选择仿真工具的可执行文件路径,Windows 系统的 TD 版本支持在默认状态下自动识别目标仿真工具的可执行路径,若目标仿真工具未添加到 PATH 环境变量或者需要覆盖环境变量中的路径时需要设置;
(3)Device Family:选择编译的器件库,TD 支持的器件库以界面选项为准,默认状态下选择编译所有器件库;
(4)Compiled Library Location: 选择保存编译库结果的路径,TD 将在该路径下创建相应的文件夹保存对应器件库的编译结果;
(5)Recompile:选中该选项后会对已编译过的器件库进行重新编译,默认状态不会重编译。

3:定义 testbench 文件
如点击 tools->Simulation则会弹出如下对话框,可以添加一个已经存在的
2504661-20240723193408153-1768141668.jpg
testbench文件可以新建一个tb或者添加一个已经编写好的tb仿真文件,这里我们添加已经编写好的。
2504661-20240723193408722-422425529.jpg
勾选run,点击 OK即调用第三方仿真工具自动执行行为级功能仿真。
2504661-20240723193409137-1016838662.jpg
需要注意,调用IP的时候产生的xml文件不能用来仿真,需要注释掉。
仿真文件需要添加glbl glbl();DR1_PHY_GSR DR1_PHY_GSR();这两句话,不然编译可能会报错。
3.3.3 启动modelsim仿真
2504661-20240723193409640-1810638502.jpg

2504661-20240723193410059-176928353.jpg

4总结
本实验演示了三种方法进行仿真,用户可以根据自己的使用习惯选择仿真方式,我比较推荐第二种方式。如果需要进行布局布线后的仿真,可以选择第三种方式。


您需要登录后才可以回帖 登录 | 立即注册

本版积分规则