ImageVerifierCode 换一换
你正在下载:

ISE约束.doc

[预览]
格式:DOC , 页数:7 ,大小:186KB ,
资源ID:3064475      下载积分:20 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-3064475.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(ISE约束.doc)为本站会员(hw****26)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

ISE约束.doc

1、ISE 约束-UCF 编辑的入门介绍 zz From: http:/ ISE 中通过编辑 UCF 文件来对 FPGA 设计进行约束,主要涉及到的约束包括时钟约束、群组约束、逻辑管脚约束以及物理属性约束。Xilinx FPGA 设计约束的分类Xilinx 定义了如下几种约束类型: “Attributes and Constraints” “CPLD Fitter” “Grouping Constraints” “Logical Constraints” “Physical Constraints” “Mapping Directives” “Placement Constraints” “Rou

2、ting Directives” “Synthesis Constraints” “Timing Constraints” “Configuration Constraints”通过编译 UCF(user constraints file)文件可以完成上述的功能。还是用实例来讲 UCF 的语法是如何的。图 1 RTL Schematic图 1 是顶层文件 RTL 图,左侧一列输入,右侧为输出,这些端口需要分配相应的 FPGA管脚。1: NET “pin_sysclk_i“ LOC = AD12 | TNM_NET = pin_sysclk_i;2: TIMESPEC TS_pin_sysclk

3、_i = PERIOD “pin_sysclk_i“ 15 ns HIGH 50 %;3: #4: NET “pin_plx_lreset_n_i“ LOC = B18;5: #6: NET “pin_plx_lhold_i“ LOC = C17;7: NET “pin_plx_lholda_o“ LOC = D17 | SLEW = FAST;8: #9: NET “pin_plx_ads_n_i“ LOC = E18;10: NET “pin_plx_ads_n_i“ OFFSET = IN 6.3 ns AFTER “pin_sysclk_i“ HIGH;11: #12: NET “pi

4、n_plx_lw_r_n_i“ LOC = E9;13: NET “pin_plx_lw_r_n_i“ OFFSET = IN 6.3 ns AFTER “pin_sysclk_i“ HIGH;14: #15: NET “pin_plx_blast_n_i“ LOC = D18;16: NET “pin_plx_blast_n_i“ OFFSET = IN 6.3 ns AFTER “pin_sysclk_i“ HIGH;17: #18: NET “pin_plx_lad_io“ LOC = AD13 | SLEW = FAST | TNM = LAD;19: NET “pin_plx_lad

5、_io“ LOC = AC13 | SLEW = FAST | TNM = LAD;20: NET “pin_plx_lad_io“ LOC = AC15 | SLEW = FAST | TNM = LAD;21: NET “pin_plx_lad_io“ LOC = AC16 | SLEW = FAST | TNM = LAD;22: NET “pin_plx_lad_io“ LOC = AA11 | SLEW = FAST | TNM = LAD;23: NET “pin_plx_lad_io“ LOC = AA12 | SLEW = FAST | TNM = LAD;24: NET “p

6、in_plx_lad_io“ LOC = AD14 | SLEW = FAST | TNM = LAD;25: NET “pin_plx_lad_io“ LOC = AC14 | SLEW = FAST | TNM = LAD;26: NET “pin_plx_lad_io“ LOC = AA13 | SLEW = FAST | TNM = LAD;27: NET “pin_plx_lad_io“ LOC = AB13 | SLEW = FAST | TNM = LAD;28: NET “pin_plx_lad_io“ LOC = AA15 | SLEW = FAST | TNM = LAD;

7、29: NET “pin_plx_lad_io“ LOC = AA16 | SLEW = FAST | TNM = LAD;30: NET “pin_plx_lad_io“ LOC = AC11 | SLEW = FAST | TNM = LAD;31: NET “pin_plx_lad_io“ LOC = AC12 | SLEW = FAST | TNM = LAD;32: NET “pin_plx_lad_io“ LOC = AB14 | SLEW = FAST | TNM = LAD;33: NET “pin_plx_lad_io“ LOC = AA14 | SLEW = FAST |

8、TNM = LAD;34: NET “pin_plx_lad_io“ LOC = D12 | SLEW = FAST | TNM = LAD;35: NET “pin_plx_lad_io“ LOC = E13 | SLEW = FAST | TNM = LAD;36: NET “pin_plx_lad_io“ LOC = C16 | SLEW = FAST | TNM = LAD;37: NET “pin_plx_lad_io“ LOC = D16 | SLEW = FAST | TNM = LAD;38: NET “pin_plx_lad_io“ LOC = D11 | SLEW = FA

9、ST | TNM = LAD;39: NET “pin_plx_lad_io“ LOC = C11 | SLEW = FAST | TNM = LAD;40: NET “pin_plx_lad_io“ LOC = E14 | SLEW = FAST | TNM = LAD;41: NET “pin_plx_lad_io“ LOC = D15 | SLEW = FAST | TNM = LAD;42: NET “pin_plx_lad_io“ LOC = D13 | SLEW = FAST | TNM = LAD;43: NET “pin_plx_lad_io“ LOC = D14 | SLEW

10、 = FAST | TNM = LAD;44: NET “pin_plx_lad_io“ LOC = F15 | SLEW = FAST | TNM = LAD;45: NET “pin_plx_lad_io“ LOC = F16 | SLEW = FAST | TNM = LAD;46: NET “pin_plx_lad_io“ LOC = F11 | SLEW = FAST | TNM = LAD;47: NET “pin_plx_lad_io“ LOC = F12 | SLEW = FAST | TNM = LAD;48: NET “pin_plx_lad_io“ LOC = F13 |

11、 SLEW = FAST | TNM = LAD;49: NET “pin_plx_lad_io“ LOC = F14 | SLEW = FAST | TNM = LAD;50: TIMEGRP “LAD“ OFFSET = IN 6.4 ns AFTER “pin_sysclk_i“ HIGH;51: TIMEGRP “LAD“ OFFSET = OUT 3.1 ns BEFORE “pin_sysclk_i“ HIGH;52: #53: NET “pin_plx_ready_n_o“ LOC = F18 | SLEW = FAST;54: NET “pin_plx_ready_n_o“ O

12、FFSET = OUT 4.2 ns BEFORE “pin_sysclk_i“ HIGH;55: #56: NET “pin_plx_bterm_n_o“ LOC = D10 | SLEW = FAST;57: NET “pin_plx_bterm_n_o“ OFFSET = OUT 4.2 ns BEFORE “pin_sysclk_i“ HIGH;58: #59: NET “pin_led_o“ LOC = D22;60: NET “pin_led_o“ LOC = C22;61: NET “pin_led_o“ LOC = E21;62: NET “pin_led_o“ LOC = D

13、21;63: NET “pin_led_o“ LOC = C21;64: NET “pin_led_o“ LOC = B24;65: NET “pin_led_o“ LOC = C20;66: NET “pin_led_o“ LOC = B23;表 1. UCF example对上面的 UCF 文件进行一些注释:该 UCF 文件主要是完成了管脚的约束、时钟的约束,以及组的约束。第一、二行:主要定义了时钟以及对应的物理管脚。第一行,端口 pin_sysclk_i 分配到 FPGA 管脚 AD12,并放到了 pin_sysclk_i group 中。那如何得知是 AD12 的管脚呢,请看图 2,F

14、PGA 管脚 AD12 是一个 66MHz 的外部时钟。FPGA 的开发板肯定有电路原理图供你分配外部管脚。图 2,电路原理图第二行:时钟说明:周期 15ns,占空比 50%。关键词 TIMESPEC(Timing Specifications),即时钟说明。一般的语法是:TIMESPEC “TSidentifier“=PERIOD “timegroup_name“ value units;其中 TSidentifier 用来指定 TS(时钟说明)的唯一的名称。第七行:pin_plx_lholda_o 连接至物理管脚 D17,并配置该管脚电平变化的速率。关键词:SLEW,用来定义电平变化的速率

15、的,一般语法是:NET “top_level_port_name“ SLEW=“value“;其中 value = FAST|SLOW|QUIETIO, QUIETIO 仅用在 Spartan-3A。第十行:定义 pin_plx_ads_n_i 输入跟时钟的关系。OFFSET IN 和 OFFSET OUT 的约束。OFFSET IN 定义了数据输入的时间和接收数据时钟沿(capture Edge)的关系。一般的语法是:OFFSET = IN value VALID value BEFORE clockOFFSET = OUT value VALID value AFTER clock图 3

16、时序图(OFFSET IN)例子:NET “SysCLk“ TNM_NET = “SysClk“;TIMESPEC “TS_SysClk“ = PERIOD “SysClk“ 5 ns HIGH 50%;OFFSET = IN 5 ns VALID 5 ns BEFORE “SysClk“;上面的定义了基于 SysClk 的全局 OFFSET IN 的属性。时序可看图 3.图 4 时序图(OFFSET OUT)例子:NET “ClkIn“ TNM_NET = “ClkIn“;OFFSET = OUT 5 ns AFTER “ClkIn“;上面设置主要是定了了时钟跟数据的时间关系,时序图 4。可

17、以看到这时一种全局定义,Data1 和 Data2 输出时间都受到 OFFSET = OUT 5 ns AFTER “ClkIn“ 的约束。如果需要单独定义输出端口的 OFFSET OUT 的,需要制定相应的 NET,可参考表 1 中的第 57 行。第 18 至 49 行:pin_plx_lad_io 被归到了名称为 LAD 的 TMN(Timing name),这个可以说是 GROUP 的约束。这样往往给约束带来方便,不用一个一个的 NET 或者 INST 进行约束。第 50 至 51 行:对 TIMEGRP 是 LAD 进行 OFFSET IN 和 OUT 的定义。在时序约束中,在这里还未

18、提及 FROM TO 的约束。FROM TO 的约束主要是用来两个同步模块之间的时间关系的约束。在这里不做深入的讨论。至此,基本上把一般的 UCF 文件的作用进行了注释。注:一般的时间的约束需要通过静态的时序分析,然后再设定相应 PERIOD,OFFSET IN 以及 OFFEET OUT 等的时间参数。当然在例子中还没有涉及到区域的约束。下面会试图说一下。ISE 进行综合后会将设计代码生成相应的逻辑网表,然后经过 translate 过程,转换到Xilinx 特定的底层结构和硬件原语,MAP 过程就是将映射到具体型号的器件上,最后就是就是布线和布局的操作了。区域的约束相当于将布局过程中指定特

19、定型号的器件的位置,这完全可以通过FloorPlanner 的 GUI 界面进行设置,用图形界面设置完后,配置信息会放到 UCF 中,这里只介绍 UCF 的使用。例如:INST “Done“ LOC = “SLICE_X32Y163“ ; #Done 映射为一个寄存器,映射到SLICE_X32Y163 的位置上。( 32,163)相当于一个坐标,可以用 FloorPlanner 进行查看。INST“BRAM4/BU2/U0/blk_mem_generator/valid.cstr/ramloop0.ram.r/v4_init.ram/TRUE_DP.SINGLE_PRIM.TDP“LOC =

20、“RAMB16_X2Y22“ ; #RAM16 的一个映射。又例如,X,Y,Z 是对应的是寄存器。现在想把它们放在一个指定的区域中,我可以这样写,INST “X” AREA_GROUP = reg;INST “X” AREA_GROUP = reg;INST “X” AREA_GROUP = reg;AREA_GROUP reg RANGE = SLICE_X1Y1 :SLICE_X1Y6;注:如何查看 INST 中的名称呢?在 ISE 中 Timing constraints editor 中可以查看。注:NET,LOC,TNM_NET ,TIMESPEC,PERIOD,OFFSET ,IN,OUT,SLEW ,HIGH等都是关键字,UCF 文件是大小敏感的,端口名称必须和源代码中的名字一致,且端口名字不能和关键字一样。但是关键字 NET 是不区分大小写的。其实上述都是约束的入门的内容,如果要想深入的了解的话,请参考 Ref1。笔者也是初学者,如果有什么不对的地方,请批评指正。我的邮箱是: http:/ Guide(10.1 ) ,Xilinx2.ISE 约束文件完整讲解3.如何在 FPGA 设计环境中加时序约束4.Xilinx ISE 所涉及的一些命令以及 Command Line 的使用5. http:/ IC design, FPGA, ISE

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。