![altera fpga的设计流程_第1页](http://file3.renrendoc.com/fileroot_temp3/2021-12/6/cf7b2341-db9e-4e37-b05a-d49fb5737e75/cf7b2341-db9e-4e37-b05a-d49fb5737e751.gif)
![altera fpga的设计流程_第2页](http://file3.renrendoc.com/fileroot_temp3/2021-12/6/cf7b2341-db9e-4e37-b05a-d49fb5737e75/cf7b2341-db9e-4e37-b05a-d49fb5737e752.gif)
![altera fpga的设计流程_第3页](http://file3.renrendoc.com/fileroot_temp3/2021-12/6/cf7b2341-db9e-4e37-b05a-d49fb5737e75/cf7b2341-db9e-4e37-b05a-d49fb5737e753.gif)
![altera fpga的设计流程_第4页](http://file3.renrendoc.com/fileroot_temp3/2021-12/6/cf7b2341-db9e-4e37-b05a-d49fb5737e75/cf7b2341-db9e-4e37-b05a-d49fb5737e754.gif)
![altera fpga的设计流程_第5页](http://file3.renrendoc.com/fileroot_temp3/2021-12/6/cf7b2341-db9e-4e37-b05a-d49fb5737e75/cf7b2341-db9e-4e37-b05a-d49fb5737e755.gif)
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Altera FPGA的设计流程的设计流程贺 光 辉清华大学电子工程系1目标目标 掌握掌握FPGAFPGA的标准设计流程和工具的标准设计流程和工具 用Modelsim进行功能级仿真并诊断RTL Code 用Quartus II做设计综合和布局布线 用FPGA Mega-functions做设计 返标SDF并运行门级的仿真 掌握掌握FPGAFPGA的时序约束的时序约束 了解了解FPGAFPGA的设计原则的设计原则2提纲提纲 FPGAFPGA概要概要 FPGAFPGA的设计流程的设计流程 用用ModelsimModelsim进行仿真和调试进行仿真和调试 用用Quartus IIQuartus II
2、进行时序分析、综合等进行时序分析、综合等 FIRFIR滤波器的设计实例滤波器的设计实例3FPGA概要概要4FPGA的优点 集成度高,可以替代多至几千块通用IC芯片 极大减小电路的面积,降低功耗,提高可靠性 具有完善先进的开发工具 提供语言、图形等设计方法,十分灵活 通过仿真工具来验证设计的正确性 可以反复地擦除、编程,方便设计的修改和升级 灵活地定义管脚功能,减轻设计工作量,缩短系统开发时间 布局布线容易,设计过程相当于只有ASIC设计的前端 研发费用低 不需要投片费用5FPGA的应用前景的应用前景 通信、控制、数据计算等领域得到了广泛的应用 减少电子系统的开发风险和开发成本 缩短上市时间(t
3、ime to market) 通过在系统编程、远程在线重构等技术降低维护升级成本 系统的原型实现ASIC的原型验证ASICASIC常用常用FPGAFPGA进行原型机验证进行原型机验证6CPLD与与FPGA的区别的区别CPLDFPGA内部结构ProducttermLookup Table程序存储内部EEPROMSRAM,外挂EEPROM资源类型组合电路资源丰富触发器资源丰富集成度低高使用场合完成控制逻辑能完成比较复杂的算法速度慢快其他资源EAB(嵌入式逻辑块),锁相环保密性可加密一般不能保密7CPLD还是还是FPGA ? 复杂组合逻辑:CPLDCPLDPLD分解组合逻辑的功能很强,一个宏单元就可
4、以分解十几个甚至2030多个组合逻辑输入 复杂时序逻辑:FPGAFPGAFPGA芯片中包含的LUT和触发器的数量非常多,往往都是成千上万8推荐书籍推荐书籍Verilog VerilogVerilog数字系统设计教程数字系统设计教程 夏宇闻 北京航天航空大学出版社 硬件描述语言硬件描述语言VerilogVerilog 刘明业等译 清华大学出版社 FPGA 基于基于FPGAFPGA的嵌入式系统设计的嵌入式系统设计 任爱锋 西安电子科技大学出版社 基于基于FPGAFPGA的系统设计(英文版)的系统设计(英文版) Wayne Wolf 机械工业出版社 IC设计 Reuse methodology ma
5、nual for system-on-a-chip designsReuse methodology manual for system-on-a-chip designs 3rd ed. Michael Keating, Pierre Bricaud. . 片上系统片上系统:可重用设计方法学可重用设计方法学沈戈,等译电子工业出版社, 2004 Writing testbenches : functional verification of HDL Writing testbenches : functional verification of HDL models / Janick Berg
6、eronmodels / Janick Bergeron Boston : Kluwer Academic, c2000 9推荐文章推荐文章10FPGA的设计流程的设计流程11目标目标 完成本单元的学习后你将会 列出FPGA设计过程的步骤(以Altera的FPGA为设计例子) 用缺省的软件选项来实现一个FPGA的设计 Quaturs II Modelsim12FPGA的设计流程的设计流程 FPGAFPGA的设计流程的设计流程 用ModelSim进行仿真 用Quartus II进行综合和时序分析 用Quartus II进行布局布线、调试和下载13FPGA设计流程设计流程综合综合 - Transl
7、ate Design into Device Specific Primitives - Optimization to Meet Required Area & Performance Constraints - Synplify, Quartus IIDesign Specification布局布线 - Map Primitives to Specific Locations inside Target Technology with Reference to Area & Performance ConstraintsDesign Entry/RTL Coding - B
8、ehavioral or Structural Description of DesignRTL仿真仿真 - Functional Simulation (Modelsim, Quartus II) - Verify Logic Model & Data Flow (No Timing Delays) LEM512M4KI/O14FPGA设计流程设计流程时序分析时序分析 - Verify Performance Specifications Were Met - Static Timing Analysis门级仿真门级仿真 - Timing Simulation - Verify De
9、sign Will Work in Target TechnologyPC Board Simulation & Test - Simulate Board Design - Program & Test Device on Board - Use SignalTap II for Debuggingtclk15系统规划和预算系统规划和预算 系统功能的总体规划: 功能集的定义; 端口的定义; 模块的基本划分和功能定义: 每个模块应该完成的功能; 模块之间的接口定义; 模块间通讯的问题一定要考虑好,硬件通信的成本一般比较大。16设计的整体规划设计的整体规划 设计规模的初步估计,大
10、致应该选择哪一层次的芯片; 设计时序的宏观规划: 频率和时钟结构; 可能的关键路径,着重优化; 模块的进一步细化,考虑可重用性等的规划: 可以考虑基本单元,比如加法、乘法器和寄存器等。设计文档化非常重要17设计实现设计实现 用电路框图或者HDL描述实现自己的设计:简单的设计可以用电路框图;大型复杂的一般倾向于用HDL描述;HDL描述和计算机编程中的高级语言描述有很大不同,每一个描述都要考虑硬件的实现能力,是不是可以综合的等等,目前HDL语言标准中仍然有不能被综合的语法,这些要尤其注意。18功能仿真功能仿真 对逻辑功能进行验证: 不考虑时序问题,认为门都是理想门,没有延时; 详细一些的可以认为门
11、延时都是一样,而忽略互连线的延时。RTL代码代码逻辑仿真器逻辑仿真器调用模块的调用模块的行为仿真模行为仿真模型型测试数据测试数据测试程序测试程序(test bench)19逻辑综合逻辑综合 通过映射和优化,把逻辑设计描述转换为和物理实现密切相关的工艺网表:RTL代码逻辑综合器调用模块的黑盒子接口设置综合目标和约束条件EDIF网表(netlist)HDL网表(netlist)20布局布线布局布线 将综合生成的网表,在FPGA内部进行布局布线的设计,并最终生成用于下载的二进制配置文件;逻辑综合器EDIF网表网表(netlist)FPGA厂家工具调用模块的综合模型设置布局布线约束条件HDL网表(ne
12、tlist)SDF文件(标准延时格式)下载/编程文件21时序逼近 时序逼近流程是一个推荐的设计方法可以帮助设计满足它们的时序目标22门级仿真门级仿真FPGA厂家工具厂家工具HDL网表(netlist)SDF文件(标准延时格式)逻辑仿真器逻辑仿真器测试数据测试数据FPGA基本单元仿真模型测试程序(test bench)23SDF 文件文件 Industry Standard Format Automatically Generated When You Compile a Design (Output File with Extension .sdo) Contain Timing Inform
13、ation Device Delays Interconnect Delays Port Delays Path Delays Timing Checks Can be Back-annotated to a Design for Accurate Model of Delays24物理验证物理验证 将生成的二进制配置文件下载到FPGA上,进行实际的功能和时序的测试; Altera (.sof文件) Xlinx (.bit 文件), 由于FPGA常常是作为整个系统一部分,因此还应该将FPGA放到整个系统中进行验证,整个系统工作正常,才算完成了开发过程。25用用ModelSim仿真仿真26内容内
14、容vModelSim产品简介vModelSim的用途v用ModelSim进行功能仿真v用ModelSim进行时序仿真27ModelSim产品简介(1)v 由Mentor Graphics公司 的子公司Model Tech公司开发v 工业上最通用的仿真器之一v 支持Verilog 和 VHDL仿真 OEM版本允许Verilog仿真 或者或者 VHDL 仿真v ModelSim/SE 首要的版本,能混合仿真Verilog 和 VHDLv ModelSim/XE OEM版,包含Xilinx公司的库文件v ModelSim/AE OEM版,包含Altera公司的库文件28ModelSim产品简介(2)
15、ModelSim 用户界面main主窗口:structure结构窗口process处理窗口:Signal&variable信号和变量窗口dataflow数据流窗口source源窗口Wave&list波形和列表窗口29ModelSim的用途1. RTL 仿真(功能仿真) v 验证设计HDL的基本逻辑功能,属于最基本的验证v 仿真速度最快2. 门级仿真 v 采用综合软件综合后生成的门级网表v 不带有布局布线后产生的时序信息3. 时序仿真(后仿真)v 在门级仿真的基础上加入时延文件“.sdf”文件v 速度很慢,需要很长时间30用ModelSim作功能仿真(1)ModelSim 的实现
16、方法:v 交互式的命令行 (Cmd) 利用控制台的命令行v 用户界面 (UI) 能接受菜单输入和命令行输入v 批处理模式 从DOS或UNIX命令行运行批处理文件31用ModelSim作功能仿真(2)基本仿真步骤:1 1 建立库2 映射库到物理目录3 编译源代码- 所有的HDL代码必须被编译4 启动仿真器5 执行仿真32用ModelSim作功能仿真(3)1 建立库UI) 从主菜单里面: Design - Create a New LibraryCmd) 从main, 记录窗口:ModelSim vlib 33用ModelSim作功能仿真(4)2 映射库到物理目录UI) 从主菜单: Design
17、- Browse Libraries Design - Create a New LibraryCmd) 从主体的记录窗口:ModelSim vmap 34用ModelSim作功能仿真(5)3 编译源代码(Verilog)UI) Design - CompilevCmd) vlog -work .v .v文件按出现的顺序被编译文件的顺序或者编辑的顺序不重要v支持增量式编译(只有被改动的设计单元被编译)v缺省编译到work库例如. vlog my_design.v35用ModelSim作功能仿真(6)3 编译源代码点亮一个或多个文点亮一个或多个文件并点击件并点击 Compile36用ModelS
18、im作功能仿真(7)4 启动仿真器UI) Design - Load New DesignCmd) vsim -lib vVHDLvsim top_entity top_architecturevVerilogvsim top_level37用ModelSim作功能仿真(8)4 启动仿真器选择库选择库选择顶级选择顶级module 或或 entity/architecture38用ModelSim作功能仿真(9)5 执行仿真UI) RunCMD) run 按timesteps指定的时间长度执行仿真39用用ModelSim作功能仿真作功能仿真(10)(10)5 执行仿真(UI)选择选择 times
19、teps数量就数量就可以执行仿真可以执行仿真Restart 重装任何已改动重装任何已改动的设计元素并把仿真时间设的设计元素并把仿真时间设为零为零COM) restart40用用ModelSim作功能仿真作功能仿真(11)(11)5 执行仿真-run 命令举例命令举例vrun 1000 从当前位置运行仿真 1000 timestepsvrun 2500 ns 从当前位置运行仿真2500 nsvrun 3000 运行仿真到 timestep 300041用用ModelSim作功能仿真作功能仿真(12)(12)5 执行仿真-仿真器激励v测试台 Verilog 或 VHDL代码非常复杂的仿真(交互式仿
20、真、数据量大的仿真)vforce命令简单的模块仿真直接从命令控制台输入.DO 文件 (宏文件)42用用ModelSim作功能仿真(作功能仿真(13 13)5 执行仿真-仿真器激励.do文件v自动完成仿真步骤的宏文件库设置编译仿真强制仿真激励v能在所有的ModelSim 模式里被调用UI) Macro - ExecuteCOM) do .dov能调用其他的DO文件43用用ModelSim作功能仿真(作功能仿真(14 14)5 执行仿真-仿真器激励.do文件举例vlib workvcom counter.vhdvsim counterview *add wave /*add list /*do r
21、un.doadd wave /clkadd wave /clradd wave /loadadd wave -hex /dataadd wave /qforce /clk 0 0, 1 50 -repeat 100force /clr 0 0, 1 100run 500force /load 1 0, 0 100force /data 16#A5 0force /clk 0 0, 1 50 -repeat 100run 1000cd c:mydirvlib workvcom counter.vhdvsim counterview *do stimulus.domy_sim.dostimulus
22、.do44用用ModelSim作功能仿真(作功能仿真(15 15)5 执行仿真-仿真器激励测试台文件(test bench)v针对复杂的仿真v在测试台文件中将设计模块实例化-将测试台文件置于TOP层,调用设计模块 -在测试台文件中加载时钟激励信号,以及给部分信号赋初值v测试台文件的写法与设计模块写法有区别- 一些符合语法但又无法被综合的语句(根据具体的综合工具而定),可以在测试台文件中使用45用ModelSim作功能仿真(总结)基本仿真步骤:1 1 建立库(Altera MegaFunction库)2 映射库到物理目录3 编译源代码- 所有的HDL代码必须被编译4 启动仿真器5 执行仿真# C
23、reate libary# Create libaryvlib workvlib work# Compile the altera_mf library# Compile the altera_mf libraryvlog d:/quartus51/eda/sim_lib/altera_mf.vvlog d:/quartus51/eda/sim_lib/altera_mf.v# Create altera_mf library and map it to # Create altera_mf library and map it to workworkexec vmap altera_mf w
24、orkexec vmap altera_mf work# source files# source files# FIFO# FIFOvlog ./core/INFIFO.vvlog ./core/INFIFO.v# top_level# top_levelvlog ./src/chip_top.vvlog ./src/chip_top.vvlog ./src/tb_top.vvlog ./src/tb_top.v# simulation and testbenches# simulation and testbenchesvsim -L work tb_topvsim -L work tb_
25、topdo wave_tb_top.dodo wave_tb_top.dorun 5 msrun 5 ms46用ModelSim作时序仿真(1)时序仿真的含义:v 布局布线后进行的后仿真v 包含有延时信息v 仿真结果可能与功能仿真不相同v 除功能仿真时需要的文件以外,还需要网表文件(如time_sim.vhd或time_sim.v)和包含延时信息的文件(time_sim.sdf文件)v 在Quartus中是.vo 和.sdo文件47用ModelSim作时序仿真(2)指定SDF文件指定指定 SDF文件文件使用定时值的等级的使用定时值的等级的类型类型 (如果不是顶级如果不是顶级)48用ModelS
26、im作时序仿真(3)vsim 命令的参数参数 -t 指定仿真的时间分辨率 单位可以是fs, ps, ns, ms, sec, min, hr 如果用了 Verilog的 timescale指令, 将使用整个设计中的最小的时间精度 可选项(缺省是 ns) -sdfmin | -sdftyp | -sdfmax = 注释SDF文件 可选项 使用实例名也是可选项; 如果没有使用, SDF用于顶级49用ModelSim作时序仿真(总结)基本仿真步骤:1 建立库2 编译Altera器件库3 映射库到物理目录4 编译综合后网表5 加入SDF文件4 启动仿真器5 执行仿真# script for Model
27、sim post timing # script for Modelsim post timing simulation of Altera cyclone devicesimulation of Altera cyclone device# by Wayne# by Wayne# set your PC environment# set your PC environmentset modelsim_home set modelsim_home d:/edatools/Modeltech_6.1dd:/edatools/Modeltech_6.1dset quartus_home d:/qu
28、artus51set quartus_home d:/quartus51#build work lib#build work libvlib workvlib work#add cyclone device lib and its sim #add cyclone device lib and its sim modelsmodelsvlog -reportprogress 300 -work vlog -reportprogress 300 -work cyclone cyclone $quartus_home/eda/sim_lib/cyclone_$quartus_home/eda/si
29、m_lib/cyclone_atoms.vatoms.v程序接下页50vmap cyclone workvmap cyclone work# post simulation in modelsim for Altera # post simulation in modelsim for Altera devicesdevicesset design_name chip_topset design_name chip_topset home ./impset home ./impvlog ./src/tb_top.vvlog ./src/tb_top.vvlog ./imp/simulation
30、/modelsim/$design_name.vlog ./imp/simulation/modelsim/$design_name.vovovsim -sdftyp /tb_top/UUT=chip_top_v.sdo -t ps vsim -sdftyp /tb_top/UUT=chip_top_v.sdo -t ps work.tb_topwork.tb_topdo wave.dodo wave.dorun 500 usrun 500 us程序接上页51用用Quartus II 进行综合、进行综合、时序分析和布局布线时序分析和布局布线52设计流程设计流程 Create a New Qua
31、rtus II Project Compile a Design into an FPGA Locate Resulting Compilation Information Assign Design Constraints (Timing & Pin) Perform Timing Analysis & Obtain Results Configure an FPGA53创建一个新的工程54添加文件55Choose Device Family器件选择器件选择56管脚分配Assignments menu-Assignment Editor-Pins57Pin Planner 窗
32、口窗口Unassigned Pins ListPackage View (Top or Bottom)Assigned Pins List58Altera的的IP工具工具 IPIP的概念的概念: 用于用于ASICASIC、ASSPASSP、PLDPLD等芯片中预先设计好的常用但较复等芯片中预先设计好的常用但较复杂的电路功能模块,经过严格测试和优化,如杂的电路功能模块,经过严格测试和优化,如FIRFIR滤波器、滤波器、SDRAMSDRAM控制器、控制器、PCIPCI接口等。接口等。 使用使用IPIP的优势的优势: 提高设计性能提高设计性能 降低开发成本降低开发成本 缩短设计周期缩短设计周期 设计
33、灵活性强设计灵活性强 仿真方便仿真方便59IPIP的分的分类类:软软IPIP、固、固IPIP和硬和硬IPIPMegafunctions/LPMMegafunctions/LPM(免费的宏功能模块):(免费的宏功能模块):如算术组件、门、如算术组件、门、I/OI/O组件、存储器、存储组件组件、存储器、存储组件MegaCoreMegaCore(需要授权的):(需要授权的):如数字信号处理类、通信类、接口和外设类、如数字信号处理类、通信类、接口和外设类、微处理器类微处理器类Altera的的IP工具工具60 下载所要的MegaCore 通过MegaWizard的界面打开IP核的统一界面IP Toolb
34、ench 定制要生成的IP的参数 产生IP的封装和网表文件,以及功能模型 对IP的RTL模型做功能仿真 将IP的封装和网表文件放在工程中,并实现设计 购买IP许可证IP使用的步骤使用的步骤61MegaWizard Plug-In Manager Eases Implementation of Megafunctions & IPEases Implementation of Megafunctions & IPTools MegaWizard Plug-In Manager62MegaWizard 示例示例 Multiply-AddPLLLocate Documentation
35、 in Quartus II Help or the Web63时时序分析64Timing Assignments 5 types of timing assignments exist: fmax, tsu, thold, tco, tpd These timing assignments can be assigned globally or individually65Register的参数的参数DClkQDQClktc-qtholdTtsutsu:建立时间,在时钟有效沿到来之前寄存器数据输入应保持稳定的时间,它间接约束了组合逻辑的最大延时thold:保持时间,在寄存器数据输入的引脚的数
36、据在系统有效时钟沿到来后需要保持稳定的时间,它间接约束了组合逻辑的最小延时tc-q:寄存器从有效时钟沿到来到输出有效的最大时间违反建立或保持时间,都会造成触发器工作异常,产生Metastability。为了可靠工作,在建立时间开始到保持时间为止的这段时间内,触发器的输入端信号不应发生变化。66Clock Skewl在同一个时钟域或者两个时钟域之间时钟信号到达寄存器的最大时间差别l产生原因主要有:时钟源到达各端点的路径长度不同,各端点负载不同,时钟网络中插入的缓冲器不同等l在两个点之间,可以大体认为Skew是固定的值l注意:Clock Skew影响的是时钟的到达时间不同,也就是时钟发生相移,并不
37、影响时钟的周期宽度67Clock Skew(2)68时钟参数满足的条件l时钟周期应大于寄存器延时、组合逻辑延时、和目标寄存器建立时间的和l本寄存器有效输出通过组合逻辑的延时应该大于目的寄存器的保持时间要求69Fmax Assignment70Fmax Assignment: Single/Multiple Clock71Clock Period = Clock-to-Out + Data Delay + Setup Time - Clock Skew = tco + B + tsu - (E - C)fmax = 1/Clock PeriodBCtcotsuE Clock PeriodCloc
38、k Setup (fmax) Worst-Case Clock FrequencyWorst-Case Clock Frequency72Select Clock SetupWorst fmaxFmax Values Are Listed in Ascending Order; Worst Fmax Is Listed on the TopSource, Destination Registers & Associated Fmax ValuesClock Setup (fmax) Tables73fmax Analysis DetailsData Delay (B)Source Re
39、gister Clock Delay (C)Setup Time (tsu)BCtcotsuE Clock PeriodDestination Register Clock Delay (E)Clock to Output (tco)10.384 ns + 7.445 ns + 0.180 ns - 0.000 ns= 124.86 MHzMessages Window (System Tab) in Quartus II74 I/O Assignments:Tsu, Tco75Timing Assignments What can be tagged with a timing assign
40、ments? Registers (all) Clock Pins (all) Input Pins (tsu, th) Output Pins (tco) Bidirectional Pins (all)76Timing SettingsEasy way to enter timing assignmentsConsolidates all timing assignments in one menu Individual clock settings OR overall circuit frequency Default system timing tsu th tco tpd Defa
41、ult external input/output delays Enable/Disable timing analysis during compilation Timing driven compilation77Reporting Timing ResultsTiming information is part of the Compilation Report Summary Timing Analyses fmax (not incl. delays to/from pins) or fmax (incl. delays to/from pins) Register-to-Regi
42、ster Table tsu (Input Setup Times) th (Input Hold Times) tco (Clock to Out Delays) tpd (Pin to Pin Delays) All timing results are reported here78I/O 建立时间和保持时间建立时间和保持时间Clock delaytsu thData delaytsu = data delay - clock delay + intrinsic tsuintrinsic tsu & holdth = clock delay - data delay + intr
43、insic th79I/O Clock-to-Output Analysis (tco)Data delaytcoClock delayclock delay + intrinsic tco + data delay = tcointrinsic tco80Time Slackslack = 期望数据到达时间 数据实际到达时间Slack为正,表示数据提前到达,此时组合逻辑延迟满足条件,Register有足够的建立时间;Slack为负,表示数据比预期的时间晚到达,此时显然不满足Register的建立时间,不满足约束;81Slack Equations (Setup)Slack = Largest
44、 Required Time - Longest Actual TimeRequired Time = Clock Setup - tco - tsu + (clk- clk)Actual Time = Data Delaylaunch edgeclkclksetup latch edgeClock Setup*clktcotsuCombinatorial LogicclkRegister 1Register 2data delay82Slack Equations (Hold)launch edgeclkhold latch edgeClock Hold*clktcothCombinator
45、ial LogicclkRegister 1Register 2data delaySlack = Shortest Actual Time - Smallest Required TimeActual Time = Data DelayRequired Time = Clock Hold - tco + th + (clk- clk)clk83inoutclkreg1reg2clkclkclkslack = p2p required p2p delayp2pp2p required = setup relationship + clock skew tCO - tSUsetup relati
46、onship = latch edge launch edgeclock skew = clk clk launchlatchSimple Register to Register 示例示例84inoutclkreg1reg2clkslack = p2p required p2p delayp2pp2p required = setup relationship + clock skew tCO tSUsetup relationship = latch edge launch edge= 5.0 0.0 = 5.0 clock skew = clk clk 2.2660.110.082tco
47、tsu0.0820.11= 2.521 - 2.993= 5.0 + (-0.472) 0.11 0.082= 4.336 2.266= -0.472= 4.336tcotsu= 2.072.9932.5212.9932.521Simple Register to Register 示例(示例(con)85Input Minimum DelayMinimum Delay from External Device to Altera I/OMinimum Delay from External Device to Altera I/O Represents External Device tco
48、 + PCB Delay + PCB Clock SkewRepresents External Device tco + PCB Delay + PCB Clock SkewConstrains Registered Input Path (th)Constrains Registered Input Path (th)AtcothAltera DeviceExternal DevicePCB DelaythA Input Minimum DelayInput Minimum DelaythACLKCLK86Output Maximum DelayMaximum Delay from Alt
49、era I/O to External DeviceMaximum Delay from Altera I/O to External Device Represents External Device tsu + PCB Delay + PCB Clock SkewRepresents External Device tsu + PCB Delay + PCB Clock SkewConstrains Registered Output Path (Max. tco)Constrains Registered Output Path (Max. tco)BtcotsuAltera Devic
50、eExternal DevicePCB DelaytcoB tCLK - Output Maximum DelaytcoOutput Maximum DelayCLKCLK87Output Minimum DelayMinimum Delay from Altera I/O to External DeviceMinimum Delay from Altera I/O to External Device Represents External Device th - PCB Board DelayRepresents External Device th - PCB Board DelayC
51、onstrains Registered Output Path (Min. tco)Constrains Registered Output Path (Min. tco)BtcothAltera DeviceExternal DeviceBoard DelaytcoB Output Minimum DelaytcoOutput Maximum DelayCLKCLK88Example Input Maximum DelayNotice:1) Input Pin d(6) & d(3) Timing Information Is Included with Clock Setup (
52、fmax) Analysis2) Input Delay Has Been Added to List Path CalculationInput Maximum Delay (d) = 4 ns 89Compiling in Quartus90Compiling in Quartus (Start)91Compiling in Quartus92Done!93Download Bit File94Download Bit File into FPGA95Altera FPGA配置列表配置列表配置模式典型应用被动串行模式(PS)运用增强配置芯片(EPC16,EPC8或EPC4 )EPC1,EP
53、C2,EPC1441,串行同步微处理器,USB接口下载电缆,MasterBlasterTM通信电缆,ByteBlasterTM II并口下载电缆或ByteBlasterMVTM并口下载电缆。主动串行模式(AS)应用串行配置芯片EPCS1,EPCS4等被动并行同步模式(PPS) 并行同步微处理器配置快速被动并行模式(FPP) 增强型配置芯片或8位同步并行微处理器速度为PPS模式的8倍。被动并行异步模式(PPA) 采用异步微处理器,这种模式下微处理器对于目标芯片如同一个存储器。被动串行异步模式(PSA) 串行异步处理器JTAG模式根据 IEEE Std. 1149.1 (JTAG)引脚标准96De
54、bug with SignalTap II97Quartus II 嵌入式逻辑分析仪特点嵌入式逻辑分析仪特点特点优点可以灵活的改变缓冲器模式在循环模式或间隔模式采样时,使每次不同的触发均能采到更加精确的数据。每个器件最高支持1024个通道可以支持多个采用通道和很宽的总线模式采样。每个器件支持128K采样存储使每个通道得到更多的采样数据。采样时钟最高可达270MHz可以采集速率更高的数据。资源使用的评价者可以评估逻辑或存储器件的资源使用情况。不需要额外费用SignalTap II logic Analyzer 是Quartus II免费提供的。可对一个器件进行多重逻辑分析可以从一个复杂的时钟信号
55、中分析出想要得到的数据通过一个JTAG接口可对多个器件进行多重的逻辑分析使设计者可以通过一个JTAG接口同步得到多个芯片的数据对每个信号均有10种触发模式可以捕捉到更加复杂的数据信号,更加景区的找到问题的所在。增加的编译可以在综合编译之前对逻辑分析仪进行修改。98FIR滤波器设计实例滤波器设计实例99一个综合的例子一个综合的例子 FIR滤波器的设计 Modelsim的使用 Quartus II的使用 宏功能模块的使用 仿真、综合等过程及报告的查看100设计要求设计要求 设计一个14阶FIR滤波器,已给出滤波器系数,要求用Verilog/VHDL实现该滤波器,并且选用Altera的Stratix
56、或Stratix II器件。 要求充分利用Altera Stratix/Stratix II的器件的DSPBLOCK资源。 要求每一级都一级流水线(pipeline)。 能够利用Altera的megafunction。 能够在Modelsim下进行仿真。 选用EP2S60F484C3器件。 Fmax达到270Mhz以上。 101设计难点设计难点 难点在于要达到270MHz以上的频率 通过插入流水线可以达到要求 为了不过分的增加流水线寄存器的数量,需要对FIR滤波器的结构进行精心设计 102直接形式结构直接形式结构 关键路径是关键路径是1 1个乘法器和个乘法器和2 2个加法器个加法器 流水线割集
57、插入流水线寄存器,这样得到的关键路径是流水线割集插入流水线寄存器,这样得到的关键路径是1 1个乘法和个乘法和1 1个加法个加法 103数据广播结构数据广播结构关键路径是关键路径是1 1个乘法器和个乘法器和1 1个加法器个加法器 流水线割集插入流水线寄存器,关键路径是流水线割集插入流水线寄存器,关键路径是1 1个乘法个乘法 104设计方案选择设计方案选择寄存器数目寄存器数目关键路径长度关键路径长度直接形式结构直接形式结构39 36个个1个乘法器和个乘法器和1个加法器个加法器数据广播结构数据广播结构13 36个个1个乘法器和个乘法器和1个加法器个加法器进一步流水的数进一步流水的数据广播结构据广播结
58、构27 36个个1个乘法器个乘法器105FIR滤波器的结构滤波器的结构106模块划分模块划分乘法器模块乘法器模块:直接用:直接用AlteraAltera的的DSPBLOCK lpm_multDSPBLOCK lpm_mult进行例化进行例化信号名称I/O描述dataaI乘法器输入数据信号,16bit字长databI乘法器输入数据信号,16bit字长resultO滤波器输出数据信号,32bit字长 加法器模块加法器模块:直接用:直接用AlteraAltera的的DSPBLOCK lpm_add_subDSPBLOCK lpm_add_sub进行例化进行例化 顶层模块顶层模块:将乘法器和加法器连接成数据广播结构的:将乘法器和加法器连接成数据广播结构的FIRFIR滤波器滤波器信号名称I/O描述dataaI乘法器输入数据信号,36bit字长d
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 安全责任协议合同
- 2025年货运从业模拟考试题库
- 2025年本溪a2货运从业资格证模拟考试题
- 2025年铁岭下载b2货运从业资格证模拟考试考试
- 电力负荷平衡合同(2篇)
- 某市人力资源和社会保障局2024年度政治生态分析报告
- 2024-2025学年高中地理课时分层作业1地球的宇宙环境含解析鲁教版必修1
- 2024-2025学年高中英语Module5GreatPeopleandGreatInventionsofAncientChinaSectionⅡGrammar课后篇巩固提升外研版必修3
- 2024-2025学年四年级语文上册第五单元18争吵说课稿语文S版
- 托班第一学期工作总结
- 第3篇 助跑 项目六 异形芯片分拣与安装讲解
- 《建设工程施工现场消防安全技术规范》
- 承包货车司机合同范本
- 传统戏剧艺术与人工智能的创新传播渠道
- 2024年越南天然食用香料与色素行业现状及前景分析2024-2030
- HG-T 2006-2022 热固性和热塑性粉末涂料
- 老舍《骆驼祥子》名著读后感
- 实体瘤疗效评价标准(RECIST11)
- JTT 680.1-2016 船用通信导航设备的安装、使用、维护、修理技术要求 第1部分:总则
- 教案-中国书法史
- 隧道施工-绪论(使用)
评论
0/150
提交评论