Xilinx-ISE的ucf文件分析_第1页
Xilinx-ISE的ucf文件分析_第2页
Xilinx-ISE的ucf文件分析_第3页
Xilinx-ISE的ucf文件分析_第4页
Xilinx-ISE的ucf文件分析_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

Xilinx-ISE中约束的设计1. Xilinx-ISE中的约束文件1.1 约束的分类利用FPGA进行系统设计常用的约束主要分为3类。(1)时序约束:主要用于规范设计的时序行为,表达设计者期望满足的时序条件,知道综合和布局布线阶段的优化算法等。(2)布局布线约束:主要用于指定芯片I/O引脚位置以及指导软件在芯片特定的物理区域进行布局布线。(3)其它约束:指目标芯片型号、接口位置、电气特性等约束属性。1.2 约束的主要作用(1)提高设计的工作效率对很多数字电路设计来说,提高工作频率是非常重要的,因为高的工作频率意味着高效的电路处理能力,通过附加约束可以控制逻辑的综合、映射、布局和布线,以减少逻辑和布线的延迟,从而提高工作效率。(2)获得正确的时序分析报告几乎所有的FPGA设计平台都包含静态时序分析工具,利用这类工具可以获得映射或者是布局布线后的时序分析报告,从而对设计的性能做出评估。静态时序分析工具以约束作为判断时序是否满足设计要求的标准,因此要求设计者正确输入约束,以便静态时序分析工具输出正确的时序分析报告。(3)指定FPGA引脚位置与电气标准FPGA的可编程性使电路板设计加工和FPGA设计可以同时进行,而不必等FPGA引脚位置的完全确定,从而节约了系统开发时间。电路板加工完成后,设计者要根据电路板的走线对FPGA加上引脚位置约束,以保证FPGA与电路板正确连接。另外通过约束还可以指定I/O引脚所支持的接口标准和其他电气特性。为了满足日新月异的通信发展,Xilinx新型FPGA可以通过I/O引脚约束设置支持,诸如AGP、BLVDS、CTT、GTL、GTLP、HSTL、LDT、LVCMOS、LVDCI、LVDS、LVPECL、LVDSEXT、LVTTL、PCI、PCIX、SSTL、ULVDS等丰富的I/O接口标准。 (4)利于模块化设计通过区域约束还能在FPGA上规划各个模块的实现区域,通过物理布局布线约束完成模块化设计等。1.3 UCF约束文件ISE 通过综合工具XST对设计进行约束,XST的综合约束文件时XCF文件,而在布局布线阶段,最重要的约束文件是用户约束文件UCF(user constraint file),两者有着千丝万缕的联系,UCF几乎支持XCF的所有约束语言和命令。通常在使用XST综合流程时,仅仅通过综合属性设置来设置全局的综合策略与参数,细化的约束是通过实现阶段的约束文件UCF完成的。因此,UCF文件时约束文件的核心,通过编译UCF文件可以实现时序、布局布线约束以及其他约束的绝大部分功能。2. 约束设计实例2.1 时序约束时序约束分为周期约束、I/O时序约束、分组约束和专门约束2.1.1 周期约束周期约束是一个基本时序和综合约束,它附加在时钟网络上,时序分析工作根据周期约束检查时钟域内所有同步器件的时序是否满足要求,它将检查与同步时序约束端口相连接的所有路径的延迟,但不会检查PAD到寄存器路径。周期时序约束示意图如图1所示图1 周期约束示意图在图1中,周期约束的路径包括CLB1的Q输出端到CLB2的D输入端。周期约束的语法如下: TIMESPEC “TS_identifier”=PERIOD “TNM_reference” period High|lowhigh_or_low_time说明:(1) TIMESPEC是一个基本时序相关约束标识(2) TM_identifier包括字母TM和一个标识符identifier共同组成一个时序规范。(3) 参数period为要求的时钟周期,可以使用ps、ns、us或者ms等单位,大小写都可以,缺省单位为ns(4) “”为必选项,HIGH|LOW关键词指出时钟周期里的第一个脉冲是高电平还是低电平(5) “”内为可选项,high_or_low_time为脉冲的延续时间,缺省单位是ns,默认占空比为50%(6) 定义时钟周期约束时,首先需要对待约束的时钟网络上附加一个TNM_NET约束,把由该时钟驱动的所有同步器件定义为一个分组,然后使用TIMESPEC约束定义时钟周期。【例1】 周期约束设计实例NET “usr_clk” TNM_NET= “usr_clk”;TIMESPEC “TS_usr_clk” = PERIOD “usr_clk” 5.0ns例1中第一条约束定义时钟usr_clk驱动的所有同步器件为一个分组;第二条约束定义其周期为5ns,即200MHZ2.1.2 I/O时序约束I/O时序约束定义了时钟和I/O接口之间的时序关系,只用于与I/O接口相连的信号,不能用于内部信号。I/O时序约束可以约束输入数据、输出数据相对于时钟的时序关系,从而在综合实现中调整布局布线,是正在开发的FPGA的输入建立时间、输出保持时间保持系统要求。I/O时序约束的语法如下:OFFSET=IN “offset_time” units BEFORE “clk_name” TIMEGRP “group_name”;OFFSET=OUT “offset_time” units AFTER “clk_name” TIMEGRP “grout_name”;说明:(1)OFFSET、IN、BEFORE是I/O时序约束输入建立时间标识,具体含义为:输入数据与时钟的时序关系满足offset_time定义的时间(2)OFFSET、OUT、AFTER是I/O时序约束输出保持时间标识,具体含义为:输出数据与时钟的时序关系满足offset_time定义的时间(3)”offset_time”是约束要求的时间(4)”clk_name”为参考时钟(5)TIMEGRP “grout_name”为约束的寄存器组。【例2】I/O时序约束INST “io_emif_data” TNM=TS_emif_data;INST “io_emif_data” TNM=TS_emif_data;INST “io_emif_data” TNM=TS_emif_data;INST “io_emif_data” TNM=TS_emif_data;INST “io_emif_data” TNM=TS_emif_data;INST “io_emif_data” TNM=TS_emif_data;INST “io_emif_data” TNM=TS_emif_data;INST “io_emif_data” TNM=TS_emif_data;NET “IO_emif_clk” TNM_NET= I_emif_clk;TIMEGRP “TS_emif_data” OFFSET = OUT 7ns AFTER “I_emif_clk”;例2表示,约束定义TS_emif_data寄存器组与时钟I_emif_clk的关系为时钟有效后7ns输出TS_emif_data寄存器的可靠数据。2.1.3 分组约束分组约束是将一些具有相同时序要求的器件归为一组,进行相同的时序约束。分组约束的语法如下:NET|INST “net_name” TNM_NET= predefined_group identifier;NET|INST|PIN “net_or_pin_or_inst_name” TNM = predefined_group identifier;(1) INST、NET和PIN为信号,引脚等关键词。(2) TNM为分组约束关键词(3) TNM_NET为分组约束关键词,其作用于TNM加在网上是基本相同,即把该网线所在路径上的所有有效同步元件作为命名组的一部分。不同之处在于当TNM约束加在PAD NET 上时,TNM的值将被赋予PAD,而不是该网线所在的路径上的同步元件,即TNM的约束不能穿过IBUF。而用TNM_NET约束就不会出现这种情况。(4) identifier为标识符(5) predefined_group为预先定义组标识符分组约束的例子参见【例2】2.1.4 专门约束约束文件设计的一般策略是首先设定整体约束,例如PERIOD、OFFSET等,然后对局部的电路附加专门约束,这些专门约束通常比整体约束宽松,通过在可能的地方尽量放松约束可以提高布局布线通过率,减小布局布线的时间。(1) FROM_TO约束FROM_TO约束在两个定义的组之间进行时序约束,对两者之间的逻辑和布线延迟进行控制。语法如下:TIMESPEC “TS_name”= FROM “group1” TO “group2” value;其中value为延迟时间,可以使具体数值或表达式。(2) MAXDELAY约束MAXDELAY约束定义了特定路径上的最大延迟。语法如下:NET “net_name” MAXDELAY = value units;2.2 布局布线约束布局布线约束包括引脚约束与位置约束2.2.1 引脚约束约束FPGA输入输出引脚的具体位置。引脚约束的语法如下:NET “net_name” LOC= “PIN”;说明:(1) NET,LOC引脚约束关键词(2) “net_name”为FPGA内部定义的输入输出信号名称;(3) “PIN”为FPGA实际引脚名称。【例3】 引脚约束实例 NET “sys_rst_n” LOC= “J12”;2.2.2 位置约束位置约束是通过约束语法将设计中的某些硬件结构约束到指定的位置。位置约束的语法如下。(1) INST “instance_name” LOC=location;对设计中的硬件约束到具体位置,可以约束的硬件结构包括:寄存器、IOB、LUT、BRAM、乘法器、PLL等。(2) INST “instance_name” RLOC= location;对设计中的硬件约束到相对位置, 可约束的硬件结构包括:寄存器、IOB、LUT、BRAM、乘法器、PLL等。必须与RLOC_ORIGIN配套使用。(3) INST “instance_name” RLOC_ORIGIN =location;与RLOC对应,指定RLOC的起始位置约束,与RLOC配套使用。(4) INST “instance_name“ HU_SET=value;高级属性定义约束,定义独立的组,与RLOC配套使用,以保持结构的完整性。【例4】 位置约束设计实例1 INST “u_receive_serdes/gtp_dual_i” LOC = GTP_DUAL_X0Y0; INST “u_idelayctrl” LOC=IDELAYCTRL_X2Y1; INST “u_en_dqs_ff” LOC=SLICE_X0Y51; INST “u_iddr_dq_ce” LOC=”ILOGIC_X0Y102;例4的4个约束分别约束了GTP模块、IDELAYCTRL、SLICE以及ILOGIC.【例5】 位置约束实例2INST “delay_inout_u/in1” RLOC_ORIGIN=X00Y60;INST”delay_inout_u/in1” RLOC=X0Y0;INST”delay_inout_u/in2” RLOC=X0Y1;INST”delay_inout_u/*” HU_SET=MA;例5利用了RLOC_ORIGIN以及RLOC和HU_SET定义了一个相对位置约束。其中*为通配符,指”delay_inout_u/”内所有元件具有的属性。2.3 其他约束除了时序约束以及引脚和位置约束外,Xilinx公司还提供了其他一些约束,例如:(1) PULLDOWN约束NET “pad_net_name” PULLDOWN说明:下拉约束,输出低电平,以避免在无驱动时三态门的输出悬空。(2) PULLUP约束NET “pad_net_name” PULLUP说明:上拉约束,输出高电平,以避免在无驱动时三态门的输出悬空。(3) IOSTAN

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论