没有合适的资源?快使用搜索试试~ 我知道了~
Xilinx时序约束笔记用户文件FPGA设计中的约束文件有3类:用户设计文件(.UCF文件)、网表约束文件(.NCF文件)以及物理约束文件(.PCF文件),可以
资源详情
资源评论
资源推荐
Xilinx 时序约束笔记
用户文件
FPGA 设计中的约束文件有 3 类:用户设计文件(.UCF 文件)、网表约束文件(.NCF 文件)
以及物理约束文件(.PCF 文件),可以完成时序约束、管脚约束以及区域约束。3 类约束文
件的关系为:用户在设计输入阶段编写 UCF 文件,然后 UCF 文件和设计综合后生成 NCF 文
件,最后再经过实现后生成 PCF 文件。
UCF 文件是 ASC 2 码文件,描述了逻辑设计的约束,可以用文本编辑器和 Xilinx 约束文
件编辑器进行编辑。NCF 约束文件的语法和 UCF 文件相同,二者的区别在于: UCF 文件由
用户输入,NCF 文件由综合工具自动生成,当二者发生冲突时,以 UCF 文件为准,这是因为
UCF 的优先级最高。PCF 文件可以分为两个部分:一部分是映射产生的物理约束,另一部分
是用户输入的约束,同样用户约束输入的优先级最高。一般情况下,用户约束都应在 UCF
文件中完成,不建议直接修改 NCF 文件和 PCF 文件。
约束文件的后缀是.ucf,所以一般也被称为 UCF 文件。创建约束文件有两种方法,一种
是通过新建方式,另一种则是利用过程管理器来完成。
第一种方法:新建一个源文件,在代码类型中选取“Implementation Constrains File”,在
“File Name”中输入约束文件的名称。单击“Next”按键进入模块选择对话框,选择要约束
的模块,然后单击“Next”进入下一页,再单击“Finish”按键完成约束文件的创建。
第二种方法:在工程管理区中,将“Source for”设置为“Synthesis/Implementation”。
“Constrains Editor”是一个专用的约束文件编辑器,双击过程管理区中“User Constrains”
下的“Create Timing Constrains”就可以打开“Constrains Editor”。
需要注意的是,UCF 文件是大小敏感的,端口名称必须和源代码中的名字一致,且端口
名字不能和关键字一样。但是关键字 NET 是不区分大小写的。
UCF 文件的语法说明:
1.语法
UCF 文件的语法为:
{NET|INST|PIN} "signal_name" Attribute;
其中,“signal_name”是指所约束对象的名字,包含了对象所在层次的描述;“Attribute”为
约束的具体描述;语句必须以分号“;”结束。可以用“#”或“”添加注释。需要注意的是:
UCF 文件是大小写敏感的,信号名必须和设计中保持大小写一致,但约束的关键字可以是大
写、小写甚至大小写混合。例如:
NET "CLK" LOC = P30;
“CLK”就是所约束信号名,LOC = P30;是约束具体的含义,将 CLK 信号分配到 FPGA
的 P30 管脚上。
对于所有的约束文件,使用与约束关键字或设计环境保留字相同的信号名会产生错误信
息,除非将其用" "括起来,因此在输入约束文件时,最好用" "将所有的信号名括起来。
2.通配符
在 UCF 文件中,通配符指的是“*”和“?”。“*”可以代表任何字符串以及空,“?”则
代表一个字符。在编辑约束文件时,使用通配符可以快速选择一组信号,当然这些信号都要
包含部分共有的字符串。例如:
NET "*CLK?" FAST;
将包含“CLK”字符并以一个字符结尾的所有信号,并提高了其速率。
在位置约束中,可以在行号和列号中使用通配符。例如:
INST "/CLK_logic/*" LOC = CLB_r*c7;
把 CLK_logic 层次中所有的实例放在第 7 列的 CLB 中。
3.定义设计层次
在 UCF 文件中,通过通配符*可以指定信号的设计层次。其语法规则为:
* 遍历所有层次
Level1/* 遍历 level1 及以下层次中的模块
Level1/*/ 遍历 level1 中的模块,但不遍历更低层的模块例 4-5 根据图 4-75 所示的结
构,使用通配符遍历表 4-3 所要求的各个模块。
管脚和区域约束语法(或使用 Floorplanner
约束)
LOC 约束是 FPGA 设计中最基本的布局约束和综合约束,能够定义基本设计单元在 FPGA
芯片中的位置,可实现绝对定位、范围定位以及区域定位。此外, LOC 还能将一组基本单
元约束在特定区域之中。LOC 语句既可以书写在约束文件中,也可以直接添加到设计文件中。
换句话说,ISE 中的 FPGA 底层工具编辑器(FPGA Editor)、布局规划器(Floorplanner)和引
脚和区域约束编辑器的主要功能都可以通过 LOC 语句完成。
LOC 语句语法
INST "instance_name " LOC = location;
其中“location”可以是 FPGA 芯片中任一或多个合法位置。如果为多个定位,需要用逗
号“,”隔开,如下所示:
LOC = location1,location2,...,locationx;
目前,还不支持将多个逻辑置于同一位置以及将多个逻辑至于多个位置上。需要说明的
是,多位置约束并不是将设计定位到所有的位置上,而是在布局布线过程中,布局器任意挑
选其中的一个作为最终的布局位置。
范围定位的语法为:
INST “instance_name” LOC=location:location [SOFT];
表-常用的 LOC 定位语句
使用 LOC 完成端口定义时,其语法如下:
NET "Top_Module_PORT" LOC = "Chip_Port";
其中,“Top_Module_PORT”为用户设计中顶层模块的信号端口,“Chip_Port”为 FPGA
芯片的管脚名。
LOC 语句中是存在优先级的,当同时指定 LOC 端口和其端口连线时,对其连线约束的
优先级是最高的。例如,在下图中,LOC=11 的优先级高于 LOC=38。
图 LOC 优先级示意图
LOC 属性说明
LOC 语句通过加载不同的属性可以约束管脚位置、CLB、Slice、TBUF、块 RAM、硬核乘
法器、全局时钟、数字锁相环(DLL)以及 DCM 模块等资源,基本涵盖了 FPGA 芯片中所有
类型的资源。由此可见,LOC 语句功能十分强大,下面列出了 LOC 的常用属性。
表-LOC 语句常用属性列表
时序约束的语法(或使用 constraint editor
约束)
UCF 文件中时序约束的语法
约束 UCF 文件,从 Constrains Editor 直接输入是最方便、最直接的添加约束的方法了。
以下是几种常用的语法:
1) 周期约束(PERIOD)
PERIOD 约束是一个基本时序和综合约束,它附加在时钟网线上,时序分析工具根据
PERIOD 约束检查时钟域内所有同步元件的时序是否满足要求,它将检查与同步时序约束端
口相连接的所有路径的延迟,但是不会检查 PAD 到寄存器的路径。
附加时钟周期约束的首选方法(Preferred Method)语法如下:
TIMESPEC “TS_identifier” = PERIOD “TNM_reference” period {HIGH|LOW} [high_or_low_time]
其中“[ ]”内为可选项,“{ }”为必选项,参数 period 为要求的时钟周期,可以使用 ps、
ns、us 或者 ms 等单位,大小写都可以,缺省单位为 ns。HIGH|LOW 关键词指出时钟周期里
的第一个脉冲是高电平还是低电平,而 high_or_low_time 为脉冲的延续时间,缺省单位也是
ns,如果不提供该项,则缺省占空比为 50%。
TIMESPEC 是一个基本时序相关约束标识,表示本约束为时序规范。TSidentifier 包括字
母 TS 和一个标识符 identifier(为 ASCII 码字符串)共同组成一个时序规范。
例如定义时钟周期约束时,首先在时钟网线 clk 上附加一个 TNM_NET 约束,把 clk 驱动
的所有同步元件定义为一个名为 sys_clk 的分组,然后使用 TIMESPEC 约束定义时钟周期。
NET “clk” TNM_NET=”sys_clk”;
#定义 clk 驱动的所有同步元件为 sys_clk 的分组
TIMESPEC “TS_sys_clk”= PERIOD “sys_clk” 50 HIGH 30;
#定义可引用的时序规范 TS_sys_clk,
#这个规范规定 sys_clk 组的时钟情况
而定义派生时钟的语法如下:
TIMESPEC “TSidentifier_2”=PERIOD “timegroup_name” “TSidentifier_1” [*or/] factor
PHASE [+|-] phase_value [units];
#定义第二个时序规范 TSidentifier_2
#其内容是名为 timegroup_name 的分组是第一个时序规范 TSidentifier_1 派生的
其中 TSidentifier_2 为要定义的派生时钟,TSidentifier_1 为已经定义的时钟,factor 指出两者
周期的倍数关系,是一个浮点数。phase_value 指出两者之间的相位关系,为浮点数。例如:
定义主时钟 clk0:
TIMESPEC “TS01” = PERIOD “clk0” 10.0 ns;
定义派生时钟 clk180,其相位与主时钟相差 180°:
TIMESPEC “TS02” = PERIOD “clk180” TS01 PHASE + 5.0 ns;
定义派生时钟 clk180_2,其周期为主时钟的 1/2,并延迟 2.5ns:
TIMESPEC “TS03” = PERIOD “clk180_2” TS01 /2 PHASE + 2.5 ns;
剩余48页未读,继续阅读
雨后的印
- 粉丝: 14
- 资源: 288
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 基于pygame实现的烟花代码
- mcu-printf关于51单片机使用printf函数进行串口调试的方法
- MySQL和数据表操作
- 微信小程序面试题.pdf
- 基于matlab实现电力系统仿真计算软件包,包括潮流计算,最优潮流计算等.rar
- 基于matlab实现电力系统各种故障波形仿真,单相接地故障,两相间短路,两相接地短路,三相短路等.rar
- 基于matlab实现电动汽车动力性,爬坡性,续驶里程等性能仿真.rar
- Python动态烟花代码.pdf
- 基于matlab实现串口发送接收数据 可配置端口,波特率等 发送可选择ASCII方式或HEX方式
- matlab基于BP神经网络手写字母识别(单一).zip代码9
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0