Formality:探针(Probe Point)的设置与使用

相关阅读

Formalityhttps://blog.csdn.net/weixin_45791458/category_12841971.html?spm=1001.2014.3001.5482


一般情况下,verify命令会对参考设计和实现设计所有匹配的比较点各自进行验证,但有些时候为了调试,可能需要验证参考设计和实现设计的逻辑锥中两个线网的等价性,这时就有两种选择:第一种方法是在使用set_cutpoint命令设置一对线网为cut-point,实际上这创建了一对新的比较点,并改变了原本逻辑锥的顶点和底点,有时候还需要用户使用set_user_match命令显式匹配这对比较点;第二种方法是使用GUI界面或set_probe_points命令在一对线网上设置探针,这不会影响逻辑锥结构,因为它是一个类似监视器的被动探针,本文就将详细阐述探针的设置与使用。

本文将以一个简单的例子进行说明,其中为了简便使用了RTL作为实现设计(一般情况下,实现设计是综合后的网表)。

复制代码
// 参考设计
module probe(a, b, c, clk, z1, z2);
  input a, b, c, clk;
  output reg z1, z2;

  always @ (posedge clk)
  begin
    z1 <= a & b;
    z2 <= a | c;
  end
endmodule

// 实现设计
module probe1(a, b, c, clk, z1, z2);
  input a, b, c, clk;
  output reg z1, z2;

  always @ (posedge clk)
  begin
    z1 <= a & b & c;
    z2 <= a | c;
  end
endmodule

下面的图1是参考设计的原理图,图2是实现设计的原理图。

图1 参考设计的原理图

图2 实现设计的原理图

实现设计和参考设计的区别显而易见:参考设计中的z1寄存器由输入端口a、b驱动,而实现设计中的z2寄存器由输入端口a、b、c驱动。

验证结果失败,如下所示,这符合预期。

复制代码
********************************* Verification Results *********************************
Verification FAILED
-------------------
 Reference design: r:/WORK/probe
 Implementation design: i:/WORK/probe1
 3 Passing compare points
 1 Failing compare points
 0 Aborted compare points
 0 Unverified compare points
----------------------------------------------------------------------------------------
Matched Compare Points     BBPin    Loop   BBNet     Cut    Port     DFF     LAT   TOTAL
----------------------------------------------------------------------------------------
Passing (equivalent)           0       0       0       0       2       1       0       3
Failing (not equivalent)       0       0       0       0       0       1       0       1
****************************************************************************************

探针一般用于隔离错误,假设在如图3所示的位置设置了探针,如果探针验证通过,则问题更可能出现在逻辑锥中的Logic2部分,如果探针验证失败,则问题更可能出现在逻辑锥中的Logic1部分。

图3 一种可能的调试情况

在逻辑锥视图中,可以很方便的设置探针,只需要同时选中参考设计和实现设计中的一对线网,同时在Edit ToolBar中点击Set Probe按钮即可(如果找不到Edit ToolBar,可以在ToolBar右键查看是否隐藏了Edit ToolBar,如图4所示),当然直接使用set_probe_points命令也是可以的。

图4 在GUI界面设置探针

假设在GUI界面设置了图5所示的探针。

图5 在GUI界面设置探针

在基于流程的工具栏上,点击6. Debug,在Probe Points列表中可以看到已设置的探针,如图6所示。

图6 查看已设置的探针

点击Verify按钮,或者右键并点击Verify Probes即可验证所有探针,当然直接使用verify -probe命令也是可以的,此时验证结果成功,如下所示。

复制代码
***************************** Probe Verification Results *******************************
Probe Verification SUCCEEDED
----------------------------
 Reference design: r:/WORK/probe
 Implementation design: i:/WORK/probe1
 1 Passing probe points
****************************************************************************************

探针验证后,甚至可以像比较点那样,打开探针的逻辑锥视图和模式窗口,如图7所示。

图7 探针的逻辑锥视图和模式窗口

由此分析可得,问题应该出在探针右侧,唯一有可能出错的就是实现设计中多出的C1与门,调试结束。

相关推荐
水龙吟啸5 小时前
计算机组成原理与体系结构-实验四 微程序控制器 (Proteus 8.15)
硬件架构·proteus·硬件工程
S,D8 小时前
MCU引脚的漏电流、灌电流、拉电流区别是什么
驱动开发·stm32·单片机·嵌入式硬件·mcu·物联网·硬件工程
国科安芯11 天前
基于ASP4644多通道降压技术在电力监测系统中集成应用与发展前景
嵌入式硬件·硬件架构·硬件工程
逼子格11 天前
硬件工程师笔试面试高频考点汇总——(2025版)
单片机·嵌入式硬件·面试·硬件工程·硬件工程师·硬件工程师真题·硬件工程师面试
Svan.12 天前
Portable Watch:基于STM32的便携智能手表
arm开发·驱动开发·stm32·嵌入式硬件·硬件工程·pcb工艺·智能手表
阿群今天学习了吗12 天前
python基础(3)
python·学习·算法·硬件工程
aixingkong92112 天前
需求初步探讨-从OR-AR
服务器·嵌入式硬件·自动驾驶·硬件工程
QQ_77813297413 天前
DFT ATPG中core chain 和wrap chain区别
硬件工程·智能硬件
nikoni2313 天前
Return ratio法计算环路增益
笔记·其他·硬件工程
日晨难再15 天前
VC Spyglass:Lint官方Hands-on Training(二)
硬件工程·数字ic