《数字系统设计与Verilogppt课件第3章.ppt》由会员分享,可在线阅读,更多相关《数字系统设计与Verilogppt课件第3章.ppt(48页珍藏版)》请在三一办公上搜索。
1、第3章Quartus II集成开发工具,基于Quartus II进行EDA设计开发的流程,3.1 Quartus II原理图设计,1.为本项工程设计建立文件夹,2.输入设计项目和存盘,元件输入对话框,3.将设计项目设置成可调用的元件,将所需元件全部调入原理图编辑窗并连接好,4.设计全加器顶层文件,连接好的全加器原理图f_adder.bdf,5.将设计项目设置成工程和时序仿真,f_adder.bdf工程设置窗,5.将设计项目设置成工程和时序仿真,加入本工程所有文件,5.将设计项目设置成工程和时序仿真,全加器工程f_adder的仿真波形,3.2 Quartus II的优化设置,1.Setting设
2、置,在Quartus II软件菜单栏中选择“Assignments”中的“Setting”就可打开一个设置控制对话框。可以使用Setting对话框对工程、文件、参数等进行修改,还可设置编译器、仿真器、时序分析、功耗分析等等。,Settings对话框,2.分析与综合设置,Analysis&Synthesis Settings项中包含有四个项目:VHDL InputVerilog HDL InputDefault ParametersSynthesis Netlist Optimization,作为Quartus II的编译模块之一,Analysis&Synthesis包括Quaruts II I
3、ntegrated Synthesis集成综合器,完全支持VHDL和Verilog HDL语言,并提供控制综合过程的选项。支持Verilog-1995标准(IEEE标准1364-1995)和大多数Verilog-2001标准(IEEE1364-2001),还支持VHDL1987标准(IEEE标准1076-1987)和VHDL1993标准(IEEE标准1076-1993)。,3.优化布局布线,Setting对话框的Fitter Settings页指定控制时序驱动编译和编译速度的选择,如下图所示。,Fitter Settings选项页,more Fitter Settings选项页,在Compil
4、ation Report中查看适配结果,在Timing Closure Floorplan中查看适配结果,在Chip Editor中查看适配结果,3.3 Quartus II的时序分析,全程编译前时序条件设置界面,“More Settings”中的设置,时序分析结果,3.4 基于宏功能模块的设计,Megafunction库是Altera提供的参数化模块库。从功能上看,可以把Megafunction库中的元器件分为:算术运算模块(arithmetic)逻辑门模块(gates)储存模块(storage)IO模块(I/O),3.4.1 乘法器模块,算数运算模块库,参数化乘法器lpm_mult宏功能模
5、块的基本参数表,lpm_mult,(1)调用lpm_mult,(2)lpm_mult参数设置,输入输出位宽设置,乘法器类型设置,(3)编译仿真,8位有符号乘法器电路,功能仿真波形,3.4.3 计数器模块,计数器输出端口宽度和计数方向设置,计数器模和控制端口设置,更多控制端口设置,模24方向可控计数器电路,lpm_counter计数器功能仿真波形,参数化锁相环宏模块altpll以输入时钟信号作为参考信号实现锁相,从而输出若干个同步倍频或者分频的片内时钟信号。与直接来自片外的时钟相比,片内时钟可以减少时钟延迟,减小片外干扰,还可改善时钟的建立时间和保持时间,是系统稳定工作的保证。不同系列的芯片对锁
6、相环的支持程度不同,但是基本的参数设置大致相同,下面便举例说明altpll的应用。,3.4.5 锁相环模块,(1)输入altpll宏功能模块,选择芯片和设置参考时钟,锁相环控制信号设置,输入时钟设置,(2)编译和仿真,锁相环电路,功能仿真波形,ROM(Read Only Memory,只读存储器)是存储器的一种,利用FPGA可以实现ROM的功能,但其不是真正意义上的ROM,因为FPGA器件在掉电后,其内部的所有信息都会丢失,再次工作时需要重新配置。Quartus II提供的参数化ROM是lpm_rom,下面用一个乘法器的例子来说明它的使用方法,这个例子使用lpm_rom构成一个4位4位的无符号
7、数乘法器,利用查表方法完成乘法功能。,3.4.6 存储器模块,数据线、地址线宽度设置,控制端口设置,添加.mif文件,如下图所示是基于ROM实现的4位4位的无符号数乘法器电路图,其参数设置为:LPM_WIDTH=8LPM_WIDTHAD=8LPM_FILE=mult_rom.mif,仿真结果,3.4.7 其他模块,Maxplus2库主要由74系列数字集成电路组成,包括时序电路宏模块和运算电路宏模块两大类,其中时序电路宏模块包括触发器、锁存器、计数器、分频器、多路复用器和移位寄存器,运算电路宏模块包括逻辑预算模块、加法器、减法器、乘法器、绝对值运算器、数值比较器、编译码器和奇偶校验器。对于这些小
8、规模的集成电路,在数字电路课程中有详细的介绍。他们的调入方法和Megafunction库中的宏模块是一样的,只是端口和参数无法设置。,计数器74161设计举例,模10计数器,仿真结果,模10计数器仿真波形,3.1 基于Quartus II软件,用D触发器设计一个2分频电路,并做波形仿真,在此基础上,设计一个4分频和8分频电路,做波形仿真。3.2 基于Quartus II软件,用7490设计一个能计时(12小时)、计分(60分)和计秒(60秒)的简单数字钟电路。设计过程如下:(1)先用Quartus II的原理图输入方式,用7490连接成包含进位输出的模60的计数器,并进行仿真,如果功能正确,则
9、将其生成一个部件;(2)将7490连接成模12的计数器,进行仿真,如果功能正确,也将其生成一个部件;(3)将以上两个部件连接成为简单的数字钟电路,能计时、计分和计秒,计满12小时后系统清0重新开始计时。(4)在实现上述功能的基础上可以进一步增加其它功能,比如校时功能,能随意调整小时、分钟信号,增加整点报时功能等。,习 题 3,3.3 基于Quartus II软件,用74161设计一个模99的计数器,个位和十位都采用8421BCD码的编码方式设计,分别用置0和置1两种方法实现,完成原理图设计输入、编译、仿真和下载整个过程。3.4 基于Quartus II软件,用7490设计一个模71计数器,个位
10、和十位都采用8421BCD码的编码方式设计,完成原理图设计输入、编译、仿真和下载整个过程。3.5 基于Quartus II,用74283(4位二进制全加器)设计实现一个8位全加器,并进行综合和仿真,查看综合结果和仿真结果。,习 题,3.6 基于Quartus II,用74194(4位双向移位寄存器)设计一个“00011101”序列产生器电路,进行编译和仿真,查看仿真结果。3.7 基于Quartus II软件,用D触发器和适当的门电路实现一个输出长度为15的m序列产生器,进行编译和仿真,查看仿真结果。,习 题,3.8 采用Quartus II软件的宏功能模块lpm_counter设计一个模为60的加法计数器,进行编译和仿真,查看仿真结果。3.9 采用Quartus II软件的宏功能模块lpm_rom,用查表的方式设计一个实现两个8位无符号数加法的电路,并进行编译和仿真。3.10 先利用LPM_ROM设计4位4位和8位8位乘法器各一个,然后用Verilog语言分别设计4位4位和8位8位乘法器,比较两类乘法器的运行速度和资源耗用情况。3.11 用数字锁相环实现分频,假定输入时钟频率为10MHz,想要得到6MHz的时钟信号,试用altpll宏功能模块实现该电路。,习 题,