0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

时序约束连载04~随路时钟

jf_pJlTbmA9 来源:明德扬FPGA科教 作者:明德扬FPGA科教 2023-07-11 17:19 次阅读

本文讲一下随路时钟,什么是随路的时钟呢?

第1节 随路时钟的概念

如图1是一个SDRAM接口时序图,大家如果做外部接口,使用过各种芯片,一般也能看到类似这样接口时序图。CLK是时钟信号,INPUT代表输入SDRAM的各种信号,OUTPUT表示SDRAM输出的各种信号线。其实芯片接口就是一些寄存器,既然是寄存器,那么这些寄存器想要稳定寄存数据,就会对数据信号有建立时间和保持时间相关的要求。

100572377-308714-tu1sdramjiekoushixutu.png

图1 SDRAM接口时序图

如图1所示,在CLK的上升沿时,要求INPUT必须提前tCS到达,并且延迟tCH,所以该接口寄存器的建立时间为tCS,保持时间为tCH,最后通过数据手册可以获取这些参数对应数值。那么在设计时序时就要考虑建立时间和保持时间对数据的影响,即INPUT要在时钟上升沿的建立时间之前稳定,并且在上升沿之后最少稳定保持时间对应的时间。这是SDRAM的一个接口时序要求,也与多数的芯片接口时序类似。

这是芯片接口需要满足的时序要求,那我们在做实际项目的时候,如何去满足这个下游器件的时序要求呢?

第2节 实际应用中,如何做到满足

2.1建立时间、保持时间的影响因素
那在设计当中如何做才能满足这个时序要求,首先分析一下影响建立时间和保持时间的因素有哪些呢?

其实影响建立时间、保持时间的因素是很多的,例如说FPGA内部的寄存器传输延时、寄存器到管脚的延时和PCB板上的走线延时等等,这些延时最终都会影响时钟与数据的关系,从而就会影响到下游器件的输入数据到底能不能满足芯片接口时序的建立时间和保持时间要求了。

2.1.1 理想波形
如图2是一个理想的波形,信号a的波形在时钟的上升沿发生变化,在第2个时钟上升沿到达时,信号a从低电平变为高电平,在第3个时钟上升沿到达时,信号a由高电平变为低电平。在两次变化过程中,没有任何延迟。能够在时钟变化时立即发生相应的变化,这种理想的波形,它的数据会立即到达下一个寄存器,会发现时钟上升沿之前的时间周期就是时钟周期T,而且在时钟上升沿之后稳定的时间是0。由此,很明显理想观点是不满足保持时间要求的。

100572377-308715-tu2lixiangdeshixutu.png

图2 理想的时序图

2.1.2 带有寄存器延时、寄存器到管脚延时的波形
如果信号a在传输时经过寄存器延时、寄存器到FPGA管脚的传输延迟Tco后,那么可能看到FPGA管脚上出来的信号相位关系就变成如图3所示。

100572377-308716-tu3yinrujicunqiyanchihejicunqidaoguanjiaoyanshi.png

图3 引入寄存器延迟和寄存器到管脚延时

clk是时钟,信号a可能对时钟会有一定的延时。由图3中可以看到,信号a会在时钟的第2个上升沿之后的一段时间才发生变化,这是由于寄存器延时造成的。在时钟上升沿第3个去采样时候,才发现信号a会提前时钟周期T-Tco这么长的时间变为稳定。上升沿之后保持了Tco,有时候延时多久就保持多久,对不对?

2.1.3 加上走线或其他延时(Tpcb)
实际波形如下:

100572377-308717-shijiboxing.png

增加延迟,信号可能会相对时钟往后延迟,在时钟上升沿之前的时间会保持多久?在时钟2时信号a变高,经过寄存器延时(tco)之后,在经过走线延迟等等,信号传递时钟3,因此时钟上升沿前的时间为(T-tco-tpcb),上升沿后保持的时间为(tco+tpcb)。那这是正常的延时情况。

那么只要满足T-tco-tpcb这个延时大于建立时间要求,并且tco+tpcb这个延时大于保持时间要求。那电路就是正常的,那如何才能做到这一点呢?但时钟周期,PCB走线延迟一般都是固定的,对于特定的FPGA芯片,寄存器延迟也是固定的,只有信号从寄存器传输到芯片管脚的延迟可以改变。

第3节 两种有效解决方法

3.1 添加时序约束,设置输出延时set_output_delay
有两种做法,一种是添加时序约束,Set output delay。这个约束会告诉综合软件下游器件的建立要求是多少和PCB走线延迟是多少,由于时钟周期和PCB走线延迟是固定的,对于特定的器件,寄存器延时也是固定的,根据T-TCO-TPCB,综合软件就会通过调整寄存器到管角的延时,这个延时放大或放小,从而使下游器件能采集到这个数据,满足下游器件的建立时间和保持性要求。

3.2 添加随路时钟
另一种方式添加随路时钟,什么是随路时钟再看一下。

100572377-308718-suilushizhong.png

如上图所示,信号a是在clk时钟域产生的信号。Sdram_clk是与clk同源、频率相同、相位不同的时钟信号。当sdram_clk 输出作为sdram的工作时钟,通过调整sdram_clk的相位就能调整时序,从而满足建立时间和保持时间的要求。假如这是CLK,用PLL产生一个SDRAM的CLK,这两个CLK的使用频率是一样的。比如说一开始有个150M的FPGA时钟clk ,FPGA的时钟clk通过PLL产生一个相位有一定偏差的150M时钟sdram_clk。可以看到clk上升沿的时候,隔了很久,sdram_clk的上升沿才出现,而这两个时钟的时钟频率一样、相位不一样。

那么sdram_clk如何产生呢?可以通过PLL来产生,PLL可以保证频率相同、相位偏移量,所以该系统的结构如图:

100572377-308719-xitongjiegou.png

第一个时钟clk可能就给Sdram接口模块作为系统时钟,sdram_clk直接就给SDRAM芯片作为数据采集的时钟了,那这样就有什么后果呢?

由于信号a是在clk时钟产生的,使得信号a是相对于时钟clk有一定的延时的。sdram_clk相对时钟clk有一定延时,有一定项目偏差。只要调整sdram_clk相位,就可以使得信号a在时钟sdram_clk的上升沿满足建立时间和保持时间的要求。比如可以调整sdram_clk,让sdram_clk上升沿刚好在信号a变化的中间。也就是说项目开始可以通过调节锁相环PLL的sdram_clk相位,使得下游芯片使用sdram_clk的上升沿去采集信号a时,能够同时满足建立时间和保持时间要求。只要调整好,那么这个系统就可以正常工作。

Sdram_clk就是随路时钟,随时钟把数据一起送到下游芯片。通过调整Sdram_clk相位,让接口信号和时钟满足下游接口芯片的建立时间和保持时间要求,这就是随路时钟的方法。

第4节 两种方法优缺点及取舍

4.1 第一种方法优缺点
那这种方法有什么优缺点,如何取舍,第一点就是常规做法,就是一个时序约束的做法。产生两个时钟,但调试还是比较麻烦的。并且有一点就是我们用的时间,对不对?它是有时间有限度的,因为调整是TCO,它一定是有限度的,就是任意调都可以是吧?比如说是调不了的,这时候就需要用Sdram_clk随路时钟的方法去做了。

4.2 第二种方法优缺点
随路时钟调试起来简单,PLL设置简单,出错可能性小。不断的调整相位,总能找到一个点让时序满足。但是也明显的,需要有个PLL来产生这个时钟,会消耗锁相环硬件资源。如果使用这种方法,就不用设置output delay之类的约束,直接用调整相位方式找到同时满足建立时间和保持时间要求的点就ok 了,所以随路时钟这种方法很多项目都喜欢用。

第5节 接收方向

SDRAM是TX(输出)方向的,输入方向是同样的道理。比如说千兆网模块就是接收数据的,如下图所示。

100572377-308720-jieshoushuju.png

它有个时钟rx_clk,假设信号a为输入数据,时钟信号与数据a对齐。这个时候如果我直接用rx_clk去采集信号a,可能就就不满足了寄存器的建立时间和保持时间了,那怎么办呢?以下两种方法:此时就可以时钟信号,

5.1 方法1
设置输入延时set_input_delay。FPGA根据时序情况,增加寄存器延时、时钟延时等,从而满足FPGA本身的建立时间和保持时间要求。比如说set input delay,FPGA 根据调整,去增加寄存器延时等方式,来满足自身建立时间和保持要求。

5.2 方法2
另一种方式也可以跟SDRAM一样,用rx clk通过锁相环生成一个与rx_clk频率相同,相位不同的pll_clk作为千兆网接口模块的时钟信号。用pll_clk去采集信号a的数据,这样不断调整pll_clk相位,使得pll_clk时钟上升沿位于信号a中间,此时就可能满足寄存器建立时间和保持时间要求了。这个时候就不用设input delay 了,就不用设时序约束了,这个时候就ok 了。所以这种方法特别是做接口调试的时候特别有用。像千兆网、SDRAM、DDR2这种东西,全部都可以用这种方式去做。

100572377-308721-suoxianghuanpll.png

要注意的是由于这种方式,使用了一个锁相环PLL的,锁相环PLL对其输入时钟是有要求的,要求输入的时钟必须来自于FPGA芯片的时钟管脚,否则综合软件会报错,这是唯一的要求。

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1629

    文章

    21748

    浏览量

    604035
  • 寄存器
    +关注

    关注

    31

    文章

    5356

    浏览量

    120570
  • 时钟
    +关注

    关注

    11

    文章

    1735

    浏览量

    131543
  • 时序约束
    +关注

    关注

    1

    文章

    115

    浏览量

    13430
收藏 人收藏

    评论

    相关推荐

    FPGA的IO口时序约束分析

      在高速系统中FPGA时序约束不止包括内部时钟约束,还应包括完整的IO时序约束
    发表于 09-27 09:56 1758次阅读

    FPGA时序约束之衍生时钟约束时钟分组约束

    在FPGA设计中,时序约束对于电路性能和可靠性非常重要。在上一篇的文章中,已经详细介绍了FPGA时序约束的主时钟
    发表于 06-12 17:29 2776次阅读

    FPGA时钟周期约束讲解

    时钟周期约束是用于对时钟周期的约束,属于时序约束中最重要的
    发表于 08-14 18:25 895次阅读

    关于FPGA时序约束的一点总结

    )。方法2调试起来简单,PLL设置简单,出错可能性小。通过不断调整相位,最终肯定可以正确通信。缺点也明显,接口一多,每个都要做时钟就浪费了。最近一直在做时序
    发表于 09-13 21:58

    时序约束时钟约束

    vivado默认计算所有时钟之间的路径,通过set_clock_groups命令可禁止在所标识的时钟组之间以及一个时钟组内的时钟进行时序分析
    发表于 09-21 12:40

    时序约束时序分析 ppt教程

    时序约束时序分析 ppt教程 本章概要:时序约束时序分析基础常用
    发表于 05-17 16:08 0次下载

    FPGA开发之时序约束(周期约束

    时序约束可以使得布线的成功率的提高,减少ISE布局布线时间。这时候用到的全局约束就有周期约束和偏移约束。周期
    发表于 02-09 02:56 719次阅读

    添加时序约束的技巧分析

    。 在添加全局时序约束时,需要根据时钟频率划分不同的时钟域,添加各自的周期约束;然后对输入输出端口信号添加偏移
    发表于 11-25 09:14 2605次阅读

    xilinx时序分析及约束

    详细讲解了xilinx的时序约束实现方法和意义。包括:初级时钟,衍生时钟,异步时终域,多时终周期的讲解
    发表于 01-25 09:53 6次下载

    如何使用时序约束向导

    了解时序约束向导如何用于“完全”约束您的设计。 该向导遵循UltraFast设计方法,定义您的时钟时钟交互,最后是您的输入和输出
    的头像 发表于 11-29 06:47 3007次阅读
    如何使用<b class='flag-5'>时序</b><b class='flag-5'>约束</b>向导

    FPGA时序约束的概念和基本策略

    约束条件可以使综合布线工具调整映射和布局布线过程,使设计达到时序要求。例如用OFFSET_IN_BEFORE约束可以告诉综合布线工具输入信号在时钟之前什么时候准备好,综合布线工具就可以
    的头像 发表于 09-30 15:17 5108次阅读

    时序约束---多时钟介绍

    当设计存在多个时钟时,根据时钟的相位和频率关系,分为同步时钟和异步时钟,这两类要分别讨论其约束
    的头像 发表于 04-06 14:34 1206次阅读
    <b class='flag-5'>时序</b><b class='flag-5'>约束</b>---多<b class='flag-5'>时钟</b>介绍

    约束时序分析的概念

    很多人询问关于约束时序分析的问题,比如:如何设置setup,hold时间?如何使用全局时钟和第二全局时钟(长线资源)?如何进行分组约束?如
    的头像 发表于 05-29 10:06 819次阅读
    <b class='flag-5'>约束</b>、<b class='flag-5'>时序</b>分析的概念

    时序约束连载03~约束步骤总结

    本小节对时序约束做最终的总结
    的头像 发表于 07-11 17:18 649次阅读
    <b class='flag-5'>时序</b><b class='flag-5'>约束</b><b class='flag-5'>连载</b>03~<b class='flag-5'>约束</b>步骤总结

    时序约束连载02~时序例外

    本文继续讲解时序约束的第四大步骤——时序例外
    的头像 发表于 07-11 17:17 719次阅读
    <b class='flag-5'>时序</b><b class='flag-5'>约束</b><b class='flag-5'>连载</b>02~<b class='flag-5'>时序</b>例外