大部分初学者(包括本人,学生党)接触并参与的FPGA开发都是基于Windows系统环境下,习惯并依赖于Windows桌面系统的便捷。然而,在后续正式工作中发现需要掌握Linux系统下FPGA的开发(以及芯片设计)。Linux系统下EDA工具更加高效,并且有些FPGA工具只有Linux版本。这一章节需要先, 络上查找了一些关于Linux环境下FPGA的开发经验:
”在linux下开发FPGA,有什么软件推荐吗FPGA的开发分工比较多。如果你指的仅仅是HDL,那还真不推荐用Linux,还是Windows下更省心省事。遇到的坑更少。 但如果是走SoC和Linux。 可能这个还真没有其他平台的开发工具可选。
如果你非要体验Linux下的FPGA HDL开发。 可以选择Xilinx公司的Vivado。 对Linux支持较好。当然,还是推荐在Windows下去做。毕竟谁都希望工具的坑少点。
使用各种工具与系统无关,与你要开发的器件和功能相关。是什么片子用什么工具。应该你唯一有点选择权的就是决定要不要用第三方的综合和仿真软件。
Actel的Libero不清楚。但Xilinx全家桶原生就是linux程序,套了个java虚拟机的壳给windows跑。在linux下运行效率只有更高,并且并行综合线程可以开到20,windows下只有8。
仿真的话,VCS压根没有windows版自不用说。modelsim两个系统都支持得很好。
摘自:https://exp.newsmth.net/topic/31e0fb2d3c437a29690c28815fdc6c33
vivado大家用Linux还是wininux用哪个发行版/p>
richardR:zynq板卡的话肯定windows笔记本更方便,云端服务器开发还是centOS吧,至少像VU这系列的做后端PR还是需要高性能服务器节省时间。
gooddream:我都在用,个人喜欢Linux,Ubuntu
fuchuantian:linux编译时间缩短不少。
摘自:http://www.zijin.net/news/tech/1077437.html
调试FPGA,大家常用的工具主要有以下几种:Quartus,ISE或Vivado ,而仿真工具则常用ModelSim,个别初学者甚至还拿ISE/Vivado或Quartus做过仿真。用ModelSim建工程,然后开始仿真,看波形,对比生成的文件。用ModelSim新建工程,然后开始仿真,看波形,对比生成的文件。
或者把Vivado和ModelSim关联起来,联合仿真
长期以来,对于没有做过芯片设计的FPGA开发人员来讲,早已习惯了上述工具(ISE/Vivado/Quartus+Modelsim)的配合使用,找一个BUG也是借助于上面的工具,费时又费力。尤其是ModelSim,如果要做芯片,ModelSim的仿真结果是不被认可的。同样的工程,ModelSim仿真通过的testcase,再拿专业做芯片用的仿真工具VCS或者NCVerilog等再做仿真就不一定通过。但上面提到的VCS或者NCVerilog等软件是没有Windows版本的,只有Linux版本的工具,这对于习惯了Windows系统环境的FPGA开发人员来讲,为了一个软件,再去熟悉Linux系统的开发环境实在是太麻烦。
[nLint]
NOVAS nLint 是一个广泛的 HDL语言的设计规则检查 工具,它整合于 Verdi和Debussy 调试平台。Verdi和Debussy系统帮助工程师 加速了解复杂设计 以提高设计、验证和调试的效率。nLint提供的功能在于帮助工程师 完整的分析HDL代码的语法和语义的正确性 。 nLint通过对源码的检查,以确保源代码的描述对于诸如同步设计、可测试性设计,命名等设计规则保持一致。nLint帮助工程师在设计的初期尽早的发现问题,以减少验证、综合和调试的时间。并且可以帮助工程师书写出易于阅读和维护的源代码程序,从而实现可以在不同的设计小组之间重复应用的设计描述。在nLint的环境中,可以很方便的进行需测试的文件和规则的整理,工程师可以在nLint提供的图形界面中指定哪些源代码文件需要检查,哪些设计规则需要检查,并且可以针对不同的设计规则赋予不同的参数以符合自身的规则定义。
主要原因还是因为做芯片承担的风险成本要远高于FPGA的开发。
有了上面的原因,很少见做FPGA开发的人去做后仿真的。因为后仿真不但速度超慢,并且如果出现问题后也无法准确的定位到具体的代码中,只能通过FPGA 表中对应的位置去猜测问题可能出现在RTL代码中的具体位置,还不如直接上板运行来的快,出问题了,大不了再重新添加ChipScope观测信 或者SignalTAP观测信 重新运行抓信 判断就是了。
[debussy]
大家在用ModelSim做仿真时,常常遇到这样一个问题。为了追某个BUG的原因,经常发现,跑出来的波形信 里面没有自己想看的变量信 ,因此,不得不重新把想看的信 添加进波形中,重新跑一遍波形。对于大的设计而言,重新跑一遍波形也需要耗费不少的时间。最坏的情况是,上述过程可能需要反复的做很多次才能找到BUG的产生源头。那么,有没有一种办法,只需要跑一次仿真,就可以把整个波形储存下来且不占太大的空间,然后在追踪BUG时,还可以方便的把波形中出错的地方直接对应到代码中具体的某一行上,还可以方便的对某个变量进行后向或者前向的追踪呢/p>
答案是有!这款软件就是Debussy。现在也集成到了Verdi软件中。
1、Debussy 软件简介
Debussy 是 NOVAS Software, Inc(思源科技)开发的 HDL Debug & Analysis tool,这个软件主要 不是用来跑模拟或看波形 ,它最强大的功能是能够在 HDL source code、schematic diagram、wave form、state bubble diagram 之间即时做 trace,协助 FPGA 工程师 debug。
Debussy 是非常实用的 Verilog 或 VHDL 的调试工具,可以帮助设计者快速理解复杂的设计,尤其是初次接触他人写的代码的时候,另外还能够查找和定位设计中存在的 bug,提高效率。可能您会觉的只要有仿真器,如 ModelSim,就可以做 debug 了,我何必再学习这个软件际上这个软件能够帮助设计者快速理解代码、波形和原理图之间的联系,使得调试变得十分地便捷。
Debussy 是支持 Windows 环境的,它的新版本改名为 Verdi,增加了一些功能,但是新版本的 Verdi 只能支持 Linux 环境。
2、用modelsim产生fsdb文件与Debussy协同工作
第一步:挂 PLI
在 modelsim.ini中搜索Veriuser,找到相应行之后进行修改,将文档中
一行修改为:
要去掉前面的分 。
第二步:新建两个环境变量
第一个新建环境变量:D_LIBRARY_PATH
变量值:
第二个新建环境变量:PLIOBJS
变量值:
第三步:在 TestBench 中添加语句
如果上述步骤无法正确完成,则用ModelSim仿真时会 出Warning,导致无法生成fsdb波形文件。
另外,笔者试了一下64位的ModelSim软件,按照上述方法无法正确产生fsdb文件,换回32位的ModelSim软件,如Modelsim SE 6.5b,则能够顺利产生波形文件。如下图所示
3、Debussy软件使用方法
在使用 Debussy 软件过程中,软件并不能直接智能地识别 Verilog-2001 代码,需要对软件进行一下设置,否则添加文件时软件就会 出很多错误告警,而且也看不到原理图,设置的方法如下:
【配置verilog-2001】
点击工具栏的 File,选择 Import Design,点击From File,再点击对话框右侧的 Options,在弹出的 Import Design Options 对话框中输入“-2001”,添加支持 Verilog-2001 标准的设置,如下图所示:
【导入源文件】
设置完成后,就能正常导入文件,进行仿真和调试了,导入方法是点击工具栏的 File,选择 Import Design…,在文件列表框中选中待观察的文件夹,接着全部选中出现的文件,再点击 Add 即可完成文件导入,如下图 所示:
【代码模块分析】
代码添加到Debussy之后,就可以点击查看各个模块的组成及调用关系了。还可以逐级的点进去查看到具体代码一级,包括状态机等。方便大家进行代码的分析及消化理解。
关键的内容来了!
【导入波形文件】
结合上面产生的fsdb文件,下一步就需要把波形文件test.fsdb导入到debussy中,这样就可以跟代码对应上!这一点很重要,可以双击波形中某个时刻的某个信 的波形,直接跳转到对应的代码!
【重新添加信 】
找到对应的代码后,还可以继续找该变量的前驱和后继,同时,随时可以添加进波形中进行查看(这要比ModelSim方便多了,常常因为波形中没有提前添加某个信 ,而不得不重新跑一下仿真)。
当然,Windows版本的debussy还存在不少的问题,使用起来某些地方不如Linux下最新版的Verdi,所以还是建议大家最后自己装个虚拟机,体验一下Linux下代码调试的高效,相比笨拙的ModelSim而言,你会立刻有鸟枪换炮的感觉!
如下动图,是Linux下使用SimVision工具(跟Verdi类似)通过波形上状态机信 对应到实际框图的例子,注意,框图中会实时显示出光标具体时刻对应的信 数值,还可以跟踪到相关的其它信 ,彻底使得代码调试可视化!
FPGA调试不易,且行且珍惜!也请对你身边做芯片或做FPGA开发的同学好一点,他们的压力比较大。据说,海思最近疯狂立项,疯狂招人,人才严重缺乏,也希望同学们多多选择FPGA开发或者芯片设计方向就业,为我们国家的芯片设计和集成电路产业早日摆脱别人的束缚做出自己的贡献!
文章知识点与官方知识档案匹配,可进一步学习相关知识CS入门技能树Linux入门初识Linux24890 人正在系统学习中
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!