FPGA中的时序约束设计

一个好的fpga设计一定是包含两个层面:良好的代码风格和合理的约束。时序约束作为fpga设计中不可或缺的一部分,已发挥着越来越重要的作用。毋庸置疑,时序约束的最终目的是实现时序收敛。时序收敛作为 fpga设计的重要验证手段之一,是保证fpga正常工作的必要条件。那么当时序无法收敛时我们应该采取怎样的措施呢?
首先需要明确一点,与ise有显著不同,在vivado中综合是时序驱动的综合,综合后的时序报告是可信的,因此要在综合之后就开始阅读时序报告,进行时序分析。
如下图所示,总体而言,在综合之后,如果时序未收敛(可以有-300ps的slack),那么此时所能做的就是优化代码或者相关的模块,还有就是优化约束。这时更多关注的是代码风格引发的问题。这和ultrafast设计方法学的理念是一致的,尽可能地尽早发现潜在的问题,在设计前端把问题解决掉。在生成综合后的时序报告时,有一个选项值得大家注意,如下图红色标记所示。为了发现关键路径(slack最差的路径)可以将interconnect设置为none,意味着相应的线延迟为0,这时就只有门级延时(本身综合后的网表就只有门级延时)。
布局布线后如果时序未收敛,可采取的措施更多的关注于相应的布局布线策略以及时序约束的合理性,可见,此时我们所能采取的措施相对单一一些,尽管也可以重新优化rtl代码,但需要重新综合、布局布线,必然费时费力。因此,在开始fpga设计时最好遵循ultrafast设计方法学所提供的设计理念,在写代码时做到心中有时序目标。
为了确保时序收敛,应从以下几个方面着手: 1. 代码风格 良好的代码风格可以确保综合后网表的高质量。因此,在写代码时要注意:
(1) 合适的复位:对于复位要遵循“全局复位局部化,异步复位同步化”的原则;
(2) 尽可能少的控制集:控制集由clk、ce、rst构成,控制集种类过多会导致触发器分散到不同的slice中,导致线延时过大,同时也降低了资源的利用率;
(3) 避免使用锁存器:锁存器会导致触发器资源浪费,因此,可将锁存器转换为带使能的触发器;
(4) 与器件结构相匹配的代码描述:例如xilinx 7系列fpga中的触发器是高有效,那么代码描述时也要采用高有效,以使描述对象能够很好地映射到目标器件中。
2. 时钟树 时钟的fpga设计中必然会用到的资源,规划好时钟的个数以及时钟之间的关系至关重要,这直接决定了时钟资源的利用率。显然,时钟个数过多会给时序收敛带来一定挑战。
3. 关于约束 (1) 确保合理的时钟约束,通过report_clock_networks查看约束对象是否为root clock,通过report_clock_interatcion来查看时钟之间的关系;通过report_cdc来查看跨时钟域之间的路径约束是否合理;
(2) 多周期路径与伪路径约束越少越好;
4. 查看线延时 如果线延时过大,可通过两种方法来降低线延时:代码优化和手工布局。
5. 尝试不同的实现策略 vivado提供了五大类实现策略,同时支持运行多个implementation,如下图所示。因此,在vivado中尝试不同的策略将变得非常容易。

神州云动:CRM系统在制造业的最佳实践
特朗普政府出招了——签署启动”美国AI计划“
欧盟目标 10 年内让 3000 万辆电动汽车上路
EMC辐射超标测试案例分析
FPC在新能源汽车上的应用
FPGA中的时序约束设计
TA2104芯片在便携式收音机和耳机电路中的应用
做时间的朋友:荣耀X系列与英雄梦想
苹果或推出“数字健康”功能,帮助用户管理花在手机上的时间
工程师分享的单片机emc设计经验,注意几点秒变高手
R&S联合中信科智联在实验室环境下,成功通过空口仿真RTK高精度定位测试
各种LED驱动技术
制造业机器人传感器技术的解决方案
晶闸管可控硅是什么材料做的
指针万用表修理方法
信号线束的工艺--屏蔽
DSP芯片加工及选型参数
荣耀v9、酷玩6最新消息:买新不买旧!17年坚果pro、荣耀v9、酷玩6领衔的10款新手机
接触器通电后反复吸合是怎么回事
智能仿真全景视频管理系统在港口的应用分析