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

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

3天内不再提示

XILINX使用方法论设计无法连贯布线

XILINX开发者社区 来源:XILINX开发者社区 作者:赛灵思开发者 2021-09-28 10:41 次阅读

本篇博文中的分析是根据真实客户问题撰写的,该客户的 DFX 设计无法连贯布线,存在布线重叠。本篇博文旨在演示用于缩小根本原因范围以及修复此问题的部分调试技巧。

这是“使用方法论报告”系列博文的第 6 部分。

如需阅读整个系列中的所有博文,请点击下方标题查看。

第1部分:时序以满足,但硬件功能出现错误

第2部分:方法违例对于QoR的影响

第3部分:时序已满足,但硬件中存在 DDR4 校准失败

第4部分:罕见的比特翻转

第5部分:DDR4 IP 校准后硬件故障,指示存在时序问题,但时序报告中无任何违例

问题说明:

在此示例中,用户的 DFX 设计遇到 1 个奇怪的问题,它无法连贯布线,部分信号线保持处于未布线状态。

运行 Tcl 命令 report_route_status 显示如下结果,有 165 条信号线未布线:

根本原因分析:

通过观察设计发现,时钟间路径存在超大保持时间违例,约 - 4.6 ns,如下所示。

但在已布线的检查点上未出现这些违例。route_design 开始处的日志中可以看到这些违例。

注: 要详细分析含估算的布线延迟的时序,请在 Vivado GUI 的“时序汇总 (Timing Summary)”报告中针对互连 (interconnect) 使用“估算 (estimated)”选项。

您可使用以下选项来检查自己的设计的“Timing Summary”:

在 Vivado GUI 中,转至“报告 (Reports)”选项卡 -》“时序 (Timing)”-》“时序汇总报告 (Report Timing Summary)”

运行以下 Tcl 命令:

report_timing_summary -file/timingreport.txt

互连设置用于控制信号线延迟计算方式:根据估算的叶节点单元管脚间布线距离来计算,或者根据实际布线的信号线来计算,或者从时序分析中排除信号线延迟。请扫码参阅 (UG906) 以获取更多信息

或者,也可以使用以下 Tcl 命令来分析含估算的布线延迟的时序。

set_delay_mode -interconnect estimated

借助时钟交互报告 (Report Clock Interaction),即可在所有特定时钟域中发现这些时钟间路径违例,如下所示。

如需在 Vivado GUI 中查看时钟交互报告,请依次选择“报告 (Reports)”-》“时序 (Timing)”-》“时钟交互报告 (Report Clock Interaction)”。

通过观察这些严重的保持时间违例,可以得出如下结论:时钟拓扑结构存在问题,或者设计未正确约束。

而这两种可能性都需要加以详细分析。

通过观察发现,此时钟间路径存在保持时间违例,且其时钟路径偏差非常高,看上去很可疑。

默认情况下,Vivado 将所有时钟都视作为同步时钟来处理。因此,这些 CDC 异步时钟路径同样被视为同步,因此导致在路径中此处添加错误的时钟偏差。在此示例中,偏差约为 4 ns。

那么我们是如何发现这些异步 CDC 未正确约束的呢?

我们是从时钟对分类 (Clock Pair Classification) 和时钟间约束 (Inter clock Constraints) 列中得到此信息的(如下所示)。

请参阅以下“如何正确地约束时钟交互”博客,以便获取详细信息。

这导致出现严重的保持时间违例,因而导致布线器执行大量保持时间修复,从而导致布线拥塞。

布线器始终优先修复保持时间违例,而后才是修复建立时间违例,因为存在保持时间违例的设计无法正常运行,而存在建立时间违例的设计则仍能按较低频率运行。

由于布线绕行导致的布线拥塞可能导致时序违例,也可能导致无法布线。

拥塞严重会导致布线器无法找到任何资源用于布线。此处示例的问题正来自于此。

您可以观察到由于欠约束 CDC 路径,会导致布线器花费大量的布线资源用于修复保持时间违例。

最终,它导致了在此例中所发生的信号线拥塞/未布线问题。

以下截屏显示的保持时间违例中,时钟偏差为 4 ns。

下图显示了发生保持时间违例的非安全 CDC 路径中所使用的布线资源总量。

并且,分析还发现利用率在可控范围内,并未超出阈值。而根本原因同样源于约束不正确。

要在 Vivado GUI 中查看资源利用率,请转至“报告 (Reports)”选项卡 -》“报告利用率 (Report Utilization)”。

或者,您可在 Tcl 控制台内运行 report_utilization 命令。

那么在此情况下,方法论报告又如何发挥作用呢?

通过观察此报告可以发现,在设计中存在大量方法警告。

以下列出了影响设计 QoR 且需要优先解决的主要警告。

要在 Vivado GUI 中打开方法论报告,请转至“报告 (Report)”选项卡 -》“方法论报告 (Report Methodology)”,或者在 Tcl 控制台中,使用 report_methodology。

以下截屏显示的方法论报告包含有关 TIMING-6、7、8、15 和 35 的警告消息。

根据 TIMING-6、TIMING-7、TIMING-8 和 TIMING-35 警告,可以得出结论,即设计未正确约束,并且必须对其加以正确约束。

因此,用户需参阅时钟交互报告以了解时钟间路径的时序是否安全。如需获取有关“时钟交互报告 (Clock Interaction Report)”的更多信息,请参阅 (UG906)。

TIMING-15 警告显示在时钟间路径上存在严重的保持时间违例,必须先加以解决,然后才能生成比特流。

由于布线器始终会尝试解决保持时间违例,并且这也会影响布线,因此建议正确约束设计,并清除上述警告消息中提及的时钟间路径中的错误。

通过检查时序汇总可以发现,时钟间路径的保持时间违例非常高,达到约 -3 ns。

结论:

通过观察分析可以发现,如果在调试初始阶段,客户遵循方法论报告中的警告将其逐一解决,那么即可大幅缩短调试此信号线未布线问题的时间。

添加如下约束后,即可解决这些幽灵时序违例:

set_max_delay -datapath_only -from [] -to []

如需获取有关添加正确的时序例外的更多信息,可参阅 (UG903) 和“如何正确地约束时钟交互”博文,其中均提供了诸多实用信息。

最后,完成上述修改后,用户得以成功将可重配置模块的利用率提升到 55% FF 利用率。

责任编辑:haq

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

    关注

    11

    文章

    704

    浏览量

    65159
  • Xilinx
    +关注

    关注

    71

    文章

    2155

    浏览量

    120837

原文标题:开发者分享 | 使用方法论报告6: 设计无法连贯布线

文章出处:【微信号:gh_2d1c7e2d540e,微信公众号:XILINX开发者社区】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    华为云,调出AI原生三原色

    方法论、云基座与大模型,构成了AI原生时代的起点
    的头像 发表于 09-20 17:33 1736次阅读
    华为云,调出AI原生三原色

    天津港:码头与数智世界间的船票

    正确的方法论,是数智化的起点与蓝图
    的头像 发表于 09-18 10:13 1208次阅读
    天津港:码头与数智世界间的船票

    探针头型使用方法有哪些

    探针头型的使用方法多种多样,具体取决于探针头型的类型、被测对象的特性以及测试需求。以下是一些常见探针头型的使用方法概述: 1. 凹头探针 用途 :主要用于测试长导脚、端子及绕线柱等较长或较粗的被测点
    的头像 发表于 09-07 10:57 381次阅读

    DC/DC模拟的基本使用方法和特性确认方法

    本篇介绍了DC/DC模拟的基本使用方法及确认基本特性的方法
    的头像 发表于 08-20 17:08 532次阅读
    DC/DC模拟的基本<b class='flag-5'>使用方法</b>和特性确认<b class='flag-5'>方法</b>

    浅谈锡膏的储存及使用方法

    锡膏(焊锡膏)是电子组装过程中常用的材料,它的储存和使用方法对保证焊接质量和性能至关重要。以下是详细的储存及使用方法
    的头像 发表于 06-27 10:02 704次阅读

    可编程电源使用方法

    可编程电源使用方法 可编程电源使用方法 摘要:本文详细介绍了可编程电源的使用方法,包括其基本概念、主要功能、选择原则、操作步骤、注意事项以及实际应用案例,旨在帮助读者全面了解可编程电源
    的头像 发表于 06-10 15:29 830次阅读

    手柄控制代码及使用方法

    手柄控制代码及使用方法
    的头像 发表于 05-15 10:19 1436次阅读

    555集成芯片的使用方法

    555集成芯片的使用方法主要依赖于其特定的引脚功能和电路设计。
    的头像 发表于 03-25 14:39 1222次阅读

    深度解析DevOps架构的概念、关键组成部分及其优势

    DevOps(Development和Operations的合并)是一种旨在加速软件开发和部署的方法论
    的头像 发表于 01-15 09:38 2112次阅读
    深度解析DevOps架构的概念、关键组成部分及其优势

    磁场探头和电场探头的使用方法与技巧

    磁场探头和电场探头的使用方法与技巧  磁场探头和电场探头是用于测量磁场和电场的仪器。它们在科学实验、工程设计和实际应用中都起着重要的作用。本文将详细介绍磁场探头和电场探头的使用方法和技巧。 一、磁场
    的头像 发表于 01-05 14:31 767次阅读

    为行业找路径,为商业筑壁垒,解码容联云的大模型“方法论

    为行业找路径,为商业筑壁垒,解码容联云的大模型“方法论
    的头像 发表于 12-21 21:56 1237次阅读
    为行业找路径,为商业筑壁垒,解码容联云的大模型“<b class='flag-5'>方法论</b>”

    pads如何使用自动布线功能

    安排,并在遵循设计规范的同时实现电路的稳定性和可靠性。本文将详细介绍pads自动布线功能的使用方法和技巧,帮助读者更好地掌握该功能。 pads自动布线功能的基本概念及原理介绍 自动布线
    的头像 发表于 12-21 16:06 4308次阅读

    SUMIF函数的使用方法

    SUMIF函数是Excel中常用的求和函数之一,它可以根据指定的条件对范围内的数值进行求和。本文将详细介绍SUMIF函数的使用方法,并通过实例演示其具体操作。 SUMIF函数的语法如下: SUMIF
    的头像 发表于 11-30 16:34 4752次阅读

    MFM推拉力测试机的应用领域和使用方法

    MFM推拉力测试机的应用领域和使用方法
    的头像 发表于 11-22 09:08 472次阅读
    MFM推拉力测试机的应用领域和<b class='flag-5'>使用方法</b>

    电力电子器件大全及使用方法

    电子发烧友网站提供《电力电子器件大全及使用方法.pdf》资料免费下载
    发表于 11-18 14:46 2次下载
    电力电子器件大全及<b class='flag-5'>使用方法</b>