Quartus ii 100教程包含modelsim仿真.docx

上传人:b****8 文档编号:28365950 上传时间:2023-07-10 格式:DOCX 页数:27 大小:895.45KB
下载 相关 举报
Quartus ii 100教程包含modelsim仿真.docx_第1页
第1页 / 共27页
Quartus ii 100教程包含modelsim仿真.docx_第2页
第2页 / 共27页
Quartus ii 100教程包含modelsim仿真.docx_第3页
第3页 / 共27页
Quartus ii 100教程包含modelsim仿真.docx_第4页
第4页 / 共27页
Quartus ii 100教程包含modelsim仿真.docx_第5页
第5页 / 共27页
点击查看更多>>
下载资源
资源描述

Quartus ii 100教程包含modelsim仿真.docx

《Quartus ii 100教程包含modelsim仿真.docx》由会员分享,可在线阅读,更多相关《Quartus ii 100教程包含modelsim仿真.docx(27页珍藏版)》请在冰豆网上搜索。

Quartus ii 100教程包含modelsim仿真.docx

Quartusii100教程包含modelsim仿真

Quartusii10.0教程

说明

本文的部分章节,来源于本人翻译的TerasicDE2-115的英文入门文档。

 

平台

硬件:

艾米电子EP2C8-2010增强版套件

软件:

QuartusII10.0+ModelSim-Altera6.5e(QuartusII10.0)StarterEdition

 

内容

∙典型的CAD流程

∙开始

∙新建工程

∙录入Verilog设计

∙编译设计

∙引脚分配

∙仿真设计电路

∙编程及配置到FPGA器件

∙测试设计电路

 

典型的CAD流程

计算机辅助设计(CAD)软件,使得运用可编程逻辑器件实现所需逻辑电路,变得容易。

比如现场可编程门阵列(FPGA)。

典型的FPGACAD设计流程如图1所示。

图1典型的FPGACAD设计流程

 

CAD流程包含以下步骤:

∙设计输入——所需电路可通过原理图方式或硬件描述语言方式(如Verilog或VHDL)进行设计。

∙综合——输入的设计被综合进入由逻辑元素(LEs,FPGA芯片提供)组成的电路中。

∙功能仿真——综合电路被测试以验证其功能是否正确,次仿真不考虑时序因素。

∙布局布线——CADFitter工具决定网表中定义的LEs如何布置成FPGA芯片中的实际LEs。

∙时序分析——分析已布局布线电路中的不同路径的传播延迟,用以指示所需电路的性能。

∙时序仿真——测试已布局布线电路,验证其是否在功能和时序上都正确。

∙编程及配置——设计的电路,通过编程配置开关,被实现到一个物理的FPGA芯片。

配置开关用于配置LEs和建立所需线路连接。

 

本指南介绍QuartusII软件的基本特征。

展示如何使用Verilog硬件描述语言来设计和实现电路。

使用GUI来实现QuartusII指令。

通过本份指南,读者将学习到:

∙新建工程

∙使用Verilog代码录入设计

∙将综合的电路布局到AlteraFPGA

∙分配电路的输入输出到FPGA上的指定引脚

∙仿真设计电路

∙编程配置艾米电子EP2C8核心板上的FPGA芯片

 

1.开始

在QuartusII中设计的每个逻辑电路或子电路,叫做一个工程。

软件每次运行一个工程,并将所有信息保存在单一文件夹中。

欲开始一个新的逻辑电路设计,第一步就是新建一个文件夹来保存文件。

为了保存本指南的设计文件,在D盘新建introtutorial文件夹。

指南者运行的范例为一个简单的双路灯控电路。

打开QuartusII软件,将看到类似于图2的画面。

该显示画面包括若干窗口,用户可使用鼠标选择,以访问QuartusII软件的相关功能。

QuartusII提供的大多数命令都可用菜单形式来访问。

例如,在图2中,在File标签下点击左键,可打开如图3所示的菜单。

用左键单击Exit可退出QuartusII软件。

图2QuartusII主体显示

 

图3File菜单一例

 

对于有些命令,需要连续访问两个或以上的菜单才可以使用。

 

1.1QuartusII在线帮助

QuartusII软件提供了容易理解的在线文档,可解答许多在使用软件时遇到的问题。

用户可通过选择Help>Search来快速访问帮助话题,在打开的对话框中,可以输入关键字。

另外一个方法是,内容感应帮助,以快速查找指定话题的文档。

在大多数的应用中,按住键盘上的F1键将打开一个显示该应用的可用命令的帮助窗口。

 

 

2新建工程

按如下步骤新建工程:

1.选择File>NewProjectWizard,以打开图4所示窗口,可通过Don'tshowmethisintroductionagain跳过此窗口步骤。

单击Next,出现图5所示窗口。

图4引导的任务显示

 

图5创建新的工程

 

2.选择工作文件夹introtutorial,也可以使用您自己设定的文件夹。

工程必须有一个名字,通常情况下,与顶层设计实体的名字相同。

如图5所示,选择light作为工程名和顶层实体名。

单击Next。

因为还没有创建introtutorial文件夹,QuartusII弹出一个对话框,询问是否新建所需文件夹,如图6所示。

单击Yes,将会引出图7所示的窗口。

图6创建新的工程文件夹与否?

 

图7添加用户指定设计文件

 

3.如果没有已存在的设计文件,单击Next,将会打开如图8所示的画面。

图8选择器件家族和指定的器件

 

4.艾米电子EP2C8核心板采用的器件为CycloneIIEP2C8Q208C8。

此处选择CycloneII器件家族,器件为PQFP封装,有208个引脚,速度等级为8。

单击Next,出现图9所示画面。

图9指定第三方EDA工具

 

5.用户可指定一些第三方EDA工具。

持续Simulation选用ModelSim-Altera,格式为VerilogHDL。

单击Next,出现图10所示窗口。

 

6.设置一览如图10所示。

单击Finish,返回QuartusII主体窗口。

标题栏将显示light工程,如图11所示。

图10工程设置一览

 

图11QuartusII显示已建工程

 

3使用Verilog代码设计输入

作为一个设计范例,我们将采用双路的灯控电路,如图12所示。

此灯可由两个按键中的任一按键来控制,x1和x2,按键的闭合相应的逻辑值为1。

真值表也同时在图中给出。

注意输入x1和x2是异或的关系,但是我们仍然用门来显示。

图12灯控电路

 

所需电路,如图13所示,使用Verilog代码来描述。

注意,Verilog模块叫做light,这个图5所示的名称是一致的。

此代码的编辑可以使用任何可存储ASCII码的文本编辑器,或者使用QuartusII自带的编辑器。

当然,文件的名称可以任意取;而和顶层Verilog模块的名称一致,是一个设计惯例。

文件名称必须带.v扩展名,用以指示此文件为Verilog文件。

所有,我们使用light.v这个名称。

图13图12所示电路的Verilog代码

 

3.1使用QuartusII文本编辑器

本节将展示如何使用QuartusII文本编辑器。

如果你喜欢使用其他文本编辑器来创建Verilog源文件,可以逃过此节。

选择File>New打开图14所示窗口,选择VerilogHDLFile,并单击OK。

这将打开文本编辑器窗口。

第一步是指定所创建的文件的名称。

选择File>SaveAs,打开图15所示的对话框。

选择存储类型为VerilogHDLFile,填写名称为light.v。

单击Save,打开图16所示窗口。

输入图13所示的代码。

使用Ctrl+s保存该文件。

图14选择新建的文件类型

 

图15命名文件

 

图16文本编辑器窗口

 

3.1.1使用Verilog模板

对于设计者来说,Verilog的语法有时很难被记住。

为了解决问题,文本编辑器提供了Verilog模板集。

这些模板提供了不同类型的Verilog表达的范例,譬如module声明、always块和设置语句的陈述。

可以通过Edit>InsertTemplate>VerilogHDL来浏览这些模板,以熟悉这些资源,这是相当值得的。

 

3.3添加设计文件到工程中

正如图7所讨论的那样,我们可以告诉QuartusII软件,哪些文件是当前工程的一部分。

要查看当前的light工程中已包含的文件列表,选择Assignment>Setting>File,这将打开图17所示画面。

另外一个可用的方法是选择标签Project>Add/RemoveFilesinProject。

使用QuartusII文本编辑器创建文件时,勾上Addfiletocurrentproject选项,所创建文件即自动加入到工程文件列表。

如果使用的不是QuartusII自带的文本编辑器,那么图17,列表中就没有所创建的文件,此时必须手动添加文件到工程文件列表中。

欲添加文件到工程文件列表中,单击图17中的FileName:

的按钮,弹出图18所示对话框,选择light.v,单击Open。

再次查看图17画面,此时所添加的文件就已经在文件列表了。

需要注意的是,在大多数案例中,QuartusII软件可根据各个实体自动找到正确的文件,即使某些文件没有被认真地添加到工程中。

然而,对于包含许多文件的复杂工程,按照上述方法,添加指定所需文件到工程中,是一个很好的设计惯例。

图17设置窗口

图18选择文件

 

4编译设计电路

在light.v中Verilog代码,要经过几个QuartusII工具的处理:

分析代码、综合电路以及生成目标芯片的实现内容。

这些应用程序被聚集在一起,且被称作编译器。

选择Processing>StartCompilation运行编译器,或者单击

 按钮运行。

在编译过程中,QuartusII的左边会显示不同阶段的进度。

编译成功(或不成功)后,会弹出一个对话框。

单击OK确认。

QartusII会显示图19所示画面的编译报告。

当编译成功后,也可以通过

 按钮手动打开编译报告。

图19编译报告

 

在此窗口的左面,列出了许多信息的列表。

如图19所示,本工程使用了1个LE和3个引脚。

 

4.1错误

在编译期间,QuartusII在消息窗口,会显示生成的消息。

如果此Verilog设计正确,其中一条消息就会显示编译成功及无错误。

如果编译不是零错误,那么在Verilog代码中,至少有一个错误。

在这种情况下,与错误对应的消息就会在消息窗口显示。

双击某条错误信息,该信息将会滚动显示完整;并且打开QuartusII自带文本编译器,Verilog代码中的某行将被高亮显示。

类似的,编译器也会显示许多警告消息。

同样的方法也适用于查看完整的警告消息。

针对于某条错误或警告消息,想得到更多信息,可选住此条消息,然后按住F1功能键,即可查看。

我们将light.v的最后一行改成endmodules,重新编译。

QuartusII弹出对话框,报告编译错误;单击OK,以确认。

编译报告如图20所示。

在消息窗口,单击Error标签,显示图21所示消息。

双击第一条错误信息,QuartusII文本编辑器打开light.v,最后一行被高亮,如图22所示。

修正代码,重新编译,直至成功为止。

图20编译报告

 

图21错误信息

 

图22指示错误代码的位置

 

 5引脚分配

在艾米电子EP2C8-2010增强版套件中,我们使用LED[1]代表f,SW[1]和SW[2]分别代表x1和x2,所需引脚映射如图23所示。

使用文本编辑器,新建一文件,命名为pins’list.txt。

录入图24所示内容。

选择Assignments>ImportAssignments,打开图25所示窗口。

选择pins’list.txt路径,单击OK导入引脚配置。

选择Assignments>PinPlanner(或单击

 按钮),打开图26所示窗口,查看引脚是否分配正确。

图23所需引脚映射

 

图24引脚分配文件——pins’list.txt

 

图25导入设置

 

图26查看引脚分配

 

5.1配置未用引脚

未用引脚需要一定得约束,倘若没有这些约束,就有可能出现一些莫名其妙的问题。

选择Assignments>Device>DeviceandPinOptions>UnusedPins,打开图27所示窗口。

一般情况下,按照图28所示配置。

图27配置未用引脚

 

图28配置未用引脚为三态输入

 

6仿真所设计的电路

在艾米电子EP2C8-2010增强版套件实现所需电路之前,审慎的做法是,先仿真以确定所设计电路是否正确。

下面将介绍如何使用ModelSim-Altera仿真:

 

6.1新建testbench文件

使用文本编辑器新建testbench文件,文件类型与图9一致,命名为light_tb.v;不要勾Addfiletocurrentproject选项,即不可加入到Quartus工程文件夹列表。

录入图29所示代码。

图29light_tb.v

 

6.2设置ModelSim-Altera路径

第一次使用需要先设置ModelSim-Altera路径。

选择Tools>Options>General>EDAToolOptions,打开EDA工具选择,如图30所示,设置路径。

单击OK,返回QuartusII主题界面。

图30设置ModelSim-Altera路径

 

6.3添加仿真所需测试文件

选择Assignments>Setting>EDAToolSetting>Simulation,打开图31所示窗口。

在NativeLinksetting下,选择Compiletestbench:

标签,单击TestBenches按钮,打开图32所示窗口。

单击New,弹出设置窗口,命名Testbenchname:

为light_tb(与前面编写light_tb.v一致);在Filename:

处,点击…按钮,添加light_tb文件路径;单击Add,完成后如图33所示。

连续三次单击OK,返回QuartusII主题窗口。

图31仿真选项设置

 

图32指定TestBenches

 

图33添加TestBenches

 

6.4开始仿真

选择Tools>RunEDASimulationTool>EDARTLSimulation,进行RTL仿真;或者选择Tools>RunEDASimulationTool>EDAGateLevelSimulation,进行门级仿真。

此处以RTL仿真为示范。

选择选择Tools>RunEDASimulationTool>EDARTLSimulation,弹出图34所示仿真画面。

稍等片刻,波形就会显现。

图34ModelSim-Altera仿真画面

 在Wave窗口右上角,单击

 ,最大化Wave窗口,方便查看波形,如图35所示。

将鼠标放在想要查看的波形上面,按住Ctrl键,滚动鼠标滚轴,可以很方便地放大缩小波形。

图35查看波形

 

 

7编程及配置FPGA器件

7.1安装下载电缆驱动

∙USB-Blaster用户,请参考

∙ByteBlasterII用户,请参考

∙EthernetBlaster用户,请参考

 

7.2JTAG编程

将USB-Blaster与FPGA开发板连接在一起,打开FPGA开发板电源,回到QuartusII主题窗口。

选择Tools>Progrmmer或单击

 按钮,打开图35所示窗口。

选择Mode为JTAG。

缺省情况下,USB-Blaster没有被选中,单击HardwareSetup按钮,在弹出的窗口选择USB-Blaster,如图36所示,单击Close退出。

图36编程器窗口

 

图37硬件设置窗口

 

如图37所示,light.sof已被列入窗口。

如果没有列入的话,单击AddFile,选择light.sof文件加入。

这是一个由编译器的汇编模块生成的二进制文件,它包含配置FPGA器件的数据。

.sof文件后缀,表示SRAM目标文件(SRAMObjectFile)。

同时可以注意到,选中的器件为EP2C8Q208,即艾米电子EP2C8套餐所用器件。

勾上Program/Configure,单击Start开始下载。

图38下载SRAM目标文件

 

8测试设计电路

下载完毕后,就可以测试实现的电路了。

使用SW[1]和SW[2]输入所有可能值,观察LED[1]亮灭是否和预期一致。

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 小学教育 > 其它课程

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1