时钟域交叉分析方法

网友投稿 419 2022-11-18

时钟域交叉分析方法

市场上出现了许多工具来识别CDC的问题。不幸的是,这些工具经常报告数百个明显的问题,其中许多通常是虚假的。这仅用于结构性CDC分析。如果要更深入地检查,必须在设计中添加断言。此时,错误错误的数量会增加,通过它们所需的时间也会增加,并找到真正的问题点。

有一种方法可以减少这个过程的痛苦。它需要明确的同步规则和CDC分析方法,该方法可以与设计中不可避免的ECO(工程变更单)顺利运行。此外,您的CDC工具必须支持轻松拒绝漏报的方法,并支持不需要在每个设计ECO上重新生成的豁免技术。

同步规程

同步中的挑战是有很多方法可以做到这一点。虽然每种方法都有优势,但在设计中 - 以及在设计组织内 - 临时使用不同技术会使审查过程复杂化。

今天没有工具可以完全按下CDC验证。总是需要一定程度的设计智慧来解释结果并考虑系统级的含义。必须对各种同步技术做出这些判断将不必要地使审查过程复杂化。

许多成功的公司已经认识到这一点,并且只是强制要求必须通过预先设计的单元格或使用一小组预先批准的技术来执行同步。虽然这可能会略微限制创作自由,但同步质量的信心可以弥补这种损失。

应该预先批准的技术取决于他们必须支持的应用范围。作为最严格的级别,可以强制要求所有同步通过预定义的同步单元进行。

最常见的同步单元支持单比特,通用总线和快速到慢速的数据同步。更轻松的方法允许手工制作这个逻辑,但仍然需要从一组有限的样式中绘制插入的逻辑。在后一种情况下,通常需要添加变体 - 同步器的同步复位或半周期移位以降低元稳定性或数据丢失的可能性。图1a和1b显示了两种常见的同步技术。

图1a - 单位亚稳态同步

图1b - 多位同步

在选择CDC工具时,务必确保该工具支持设计中所需的所有技术。更复杂的工具允许设计人员基于各种同步样式定义方法,包括最常用的技术,用户命名的同步单元和用户定义的结构,这些结构将与域交叉结构进行模式匹配。

虚假域名交叉

许多时钟域交叉通常是由复位或配置信号引起的(见图2)。虽然技术上可以在这些准静态信号上发生同步问题,但它将是一次性事件,并且由于此后信号是有效静态的,因此可以在设备的大部分正常运行时间内有效地忽略它们。

cdc_false_path-from rst_n cdc_false_path-from config [*]

cdc_false_path-从use_ck到pci_ck cdc_false_path-从pci_ck到usb_ck

在某些情况下,通过指定直通点可以进一步优化错误路径:

cdc_false_path-from(state)-through(thru-point)-to(end)

这是必要的改进,当确定从/到对在功能上是有效的,但只能通过某些路径。

图2 - 假时钟域交叉的例子

FIFO同步

虚假域交叉的另一个有趣的来源可以是FIFO同步器中的推断内存。通常的做法是在将每个指针同步到相对的域之前对读和写指针进行灰度编码,以便比较和生成满标志和空标志。在读数据信号周围可能发生微妙且很少提到的错误交叉问题。想想如何在RTL中描述这一点:

事实上,这个域名交叉是虚假的,这是一个有趣的原因。虽然理论上可以从与写入相同的地址进行读取(同时),但大多数同步器设计会在读取和写入之间强制执行一些延迟,从而确保在同一地址中不会发生写入和读取。相同的周期(任何一个时钟)。这种延迟确保读取数据至少在几个周期内有效地准静态,因此不能成为域交叉。

一个好的CDC工具可以自动检测和拒绝这些情况。

握手同步

一种非常常见且稳健的同步多个数据信号的方法是握手技术,如图3所示。这很受欢迎,因为握手技术可以轻松管理时钟频率的变化,同时最大限度地减少交叉口的延迟。但是,握手逻辑比标准同步结构复杂得多,大多数工具都不会自动识别。在这些情况下,传统的隐式CDC分析将报告所有交叉数据信号的非同步域交叉。

图3 - 握手同步是时钟域交叉中常用的技术

虽然检查这些属性有好处,但这仍然给设计人员带来了确保所有握手确实已被分析的主要负担。同样,这些结构将导致错误的CC报告,只能通过手动检查来消除。

第三方IP

今天几乎所有的设计都包含一些外部知识产权(IP),无论是内部开发还是商业收购。对于如图4所示的IP,除了进入的检查检查之外,重复检查内部域交叉和同步技术几乎没有价值。在大多数情况下,您无法更改IP的内部,因此任何报告的问题都只是额外的噪音。更重要的是分析围绕该IP和其他设计的CDC,其中IP域和设计域之间的交互可能导致新问题。

某些CDC工具提供约束来屏蔽指定IP内部的所有域交叉报告,同时仍报告其他逻辑与这些IP之间的交叉。这使得检查更容易,更有效。

评论和ECO分析

即使已经消除了所有这些杂散源,也可能需要检查大量可能不同步的域交叉。这些可能来自在复位或配置信号意义上不是准静态的信号,但已知在使用之前“足够长时间”是稳定的。

一旦审查并批准此类案件,除非您选择,否则无需再次查看。处理这些案件的一种实用方法是放弃,在RTL代码内部或外部应用,以标记案件已经过审查和批准。

易于使用和灵活的点 - 和如图5所示,单击豁免方法优于“正式放弃”一种或多种违反任何类型的行为。应该智能地应用这些豁免,适应RTL代码的更改,因此很少需要更新它们。如果需要,这些豁免和他们压制的CDC仍然可以进行设计审查或最终通过,以重新验证所有域名交叉点。

功能分析

CDC的功能分析是自然延伸到结构分析。每个识别的同步结构带有一个或多个功能要求。例如,考虑一个常见的多路复用循环同步器,如图6所示。

到目前为止,这是一项结构性检查。在这种情况下所需的功能检查是当选择“sel”变高时源数据信号“data”是稳定的。由于选择和数据信号是自动识别的,因此应该是自动检查。

此类中的其他检查包括快速到慢速域跨越保持时间,灰色编码检查,握手检查等等。这些检查不会减少,也可能增加报告的问题数量,但在准确的结构识别基础上这样做,大大降低了误报的可能性。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Hadoop 资源管理框架 YARN : ResourceManager
下一篇:【第15天】给定两个整数a和b,求它们的最小公倍数 | LCM运用
相关文章

 发表评论

暂时没有评论,来抢沙发吧~