1、约束的目的
介绍fpga约束原理,理解约束的目的为设计服务,是为了保证设计满足时序要求,指导fpga工具进行综合和实现,约束是vivado等工具努力实现的目标。所以首先要设计合理,才可能满足约束,约束反过来检查设计能否满足时序。主要涉及到xilinx vivado xdc约束语法,给出对应的ise ucf 语法。另外quatus的语法和xdc几乎兼容,原理都一样。
时序约束中最基本的是时钟,时钟有抖动(jitter),偏移(skew),占空比失真(duty cycle distortion)三种特性。
1、抖动,分为周期抖动(cycle jitter),周期差抖动(cycle to cycle jitter)和长期抖动(long term jitter)。
2、偏移和时钟线的长度,时序单元的负载电容和个数有关。fpga的全局时钟采用全铜工艺和树状结构,偏移非常小,可以忽略。
3、占空比失真就是高低电平不对称,会吞噬时序裕量。
2、基本的时钟约束
最简单的情况,设计只有一个时钟。这时候需要对这个时钟的周期进行约束,(当然也可以对占空比进行约束,默认为50%)。如果不对时钟进行约束,我们就不知道自己的设计是否时序收敛。简单的说,比如系统时钟是200m的,那么周期就是5ns,也就是说信号从一个寄存器出来,经过了一系列的组合逻辑,要在下一个时钟的上升沿到来之前被目的寄存器采样到。当然考虑到,实际情况还复杂很多。
假如设计里有很多时钟,那么哪些时钟是必须要约束的呢?
首先是从端口进入fpga的时钟。其他衍生时钟(如通过pll或者mmcm生成的)跟它是同源时钟,工具会自动推导。然后是gt的rx_clk和tx_clk必须要约束。最后是用户自己分频产生的行波时钟(用于简单的低频应用),必须约束。
create_clock -name clk_200m -period 5 [get_ports i_clk200]
3、跨时钟域cdc约束
set_clock_groups –asynchronous -group [get_clocks -include_generated_clocks clk_1]
-group [get_clocks -include_generated_clocks clk_2]
4、input delay
input delay和output delay都是分析的外部延时,与ise的ucf约束fpga内部延时恰恰相反。
5、output delay
假设周期是10ns
offset = out 4ns after clock;
set_output_delay 6 -clock [get_clocks ] [get_ports ]
通过把input output register pack到iob中,和约束slew可以更容易满足接口时序要求。
rtl中约束
(* iob = “true” *)
o_config_dat
xdc中约束
set_property iob true [get_ports o_config_dat]
set_property slew fast [get_ports o_config_dat]
小米第三季度营收和利润均超出市场预期,研发投入也创下季度新高
Pedro Domingos教授的研究论文汇集机器学习研究人员的经验教训
VK1072B/C/D LCD驱动器概述及特点
多功能锂离子电池测试的解决方案
AIC3643的特性及应用
FPGA约束的详细介绍
定氮仪是实验室比较重要的理化分析仪器之一
流延膜表面缺陷检测系统的原理、参数及功能
MIKROE推出新开源软硬件解决方案使数百个Click板能够热插拔到Linux开发环境中
ireadert6评测 远优于市场同价位
Intersil推出业内首款专门针对汽车应用的全高清LCD视频处理器
银行和政务终端领域的安全之选:国产工控机引领硬件革新
完美白色全屏,美炸了!谷歌Pixel 2代外形曝光
联发科PA 射频放大芯片累计销售超过22亿颗
国产汽车巨头,裁员95%!
SPI/I2C/USART通讯方式的特点
小米MIX2怎么样?小米MIX2评测:小米MIX2真机上手优缺点分析
中国芯支撑云存储 国产化替代切实可行
一亿像素有何看头 更高像素的意义是什么
AMD、英伟达在GPU 市场的厮杀现状