Amiya · 2021年11月23日

当simulation hang住的时候该怎么办?

最近bug猎人遇到一个棘手的问题,用VCS跑simulation hang住了。

遇到此类问题,我第一个想到的是去打印一些log看看,比如设置定时打印,调高UVM打印级别等。我在仿真环境里面设置定时打印log的信息,发现hang住之后不会打印了。由此猜测是环境里面存在0延时的死循环,导致仿真无法继续推前。
image.png
VCS提供了ucli可以进行单步调试,如果遇到0延时的死循环,理论上进行单步调试的时候,会循环的执行某一段代码。但是考虑到可能涉及到的循环逻辑比较多,单纯用手工单步调试会非常困难。如果用脚本自动运行几千行,然后将单步调试的结果保存在log文件中,将非常有助于分析出死循环的代码。对于这种想法网友已经用tcl脚本实现。让我们看看网友怎么用loop detect的方式寻找0延时的死循环。

  • 第一步用vcs -debug_all 编译文件。
  • 第二步用simv -ucli 执行文件
  • 第三步在ucli界面里面source  loop_detect.tcl 这个 tcl文件

Loop_detect.tcl 的文件内容如下

#!/usr/bin/tclsh

proc loop_detect(args) {

    set help"-help"

    if{\[stringequal $args $help\] != 1} {

       configfollowactivescope on

       set i 0;

       while {$i< $args} {

         run_step

         incr i

       }

    }

    else {

      puts"Usage: loop_detect <no. of iteration>"

    }

}

proc run_step{} {

  redirect -floop.txt -a {set x \[step\]}; 

  redirect -floop.txt -a {set y \[scope\]}; 

  puts $x;

  puts $y;

}
  • 第四步在ucli 里面用run {time} 执行到hang住的地方,比如simulation 是在1000ns的地方hang住了,可以用run1000ns 执行到此处。
  • 第五步在ucli里面用loop_detect {number of steps} 检查hang住的原因,比如我用loop_detect 1000 则表示单步执行了1000次,并将每步的结果存在loop.txt 中。然后从loop.txt 中查看是否有0延时的死循环。

我的问题用这种方法寻找到了0延时的死循环逻辑。如果通过上面五步,在loop detect中没有看到死循环怎么办,还有其他办法吗?这可能需要借助 Verdi和VCS进行联合仿真了。怎么用Verdi和VCS进行单步调试呢?

第一步用  vcs  -debug_access+all -kdb -lca进行编译

第二步用 simv -gui=verdi启动联合单步调试

image.png

通过verdi进行单步调试,让debug变比较容易。

如果通过Verdi和VCS联合单步调试还没发现问题呢?各位同行们还有什么手段,欢迎各位留言讨论。

作者:IC bug 猎人
原文链接:https://mp.weixin.qq.com/s/P5iJqoSFj-sEYQSRpyzmxw

推荐阅读

更多IC设计技术干货请关注IC设计技术专栏。
推荐阅读
关注数
20467
内容数
1311
主要交流IC以及SoC设计流程相关的技术和知识
目录
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息