卢骏 · 2020年05月24日

使用fsdbedit工具修改fsdb波形的层次结构

verdi工具有一个很强大的功能,可以将代码和波形对应起来,这样debug效率就很高。但是这需要有一个前提,代码的信号的层次路径,要和波形里面该信号的层次路径一致,这样verdi工具才能够进行对应。

但是如果代码里面的信号层次路径,和波形里面的信号层次路径不一致,那verdi工具就无能为力了。也就不能进行代码和波形的对应。

但是有时候,会有这样的一种情况。对于同一个模块,在不同的仿真环境下,所在的层次路径是不一样的。比如对于模块D:

  • 在仿真环境A中,所在的层次路径为 tb_top1.xxx.a
  • 在仿真环境B中,所在的层次路径为 tb_top2.yyy.a

此时在A仿真环境中生成的fsdb波形,如果我只想看模块D的波形,那么该fsdb波形,能够在仿真环境B中查看了吗?

当然,在仿真环境B中,能够直接打开该fsdb波形,但是不能将模块D的代码和波形中模块D的波形进行对应,因为他们的层次路径不一样。

所以,这个时候,如果能直接修改fsdb波形文件的层次路径,将tb_top1.xxx.a,修改为tb_top2.yyy.a,那么就可以直接在仿真环境B中,将模块D的代码和波形中模块D的波形进行对应了。

一、fsdbedit工具

为了实现这个功能,我们需要使用 fsdbedit 工具。该工具属于verdi的子工具之一。

使用 fsdbedit -h 命令,可以查看该命令的使用方法:

Usage fsdbedit: fsdb_file_name [options]

options:

[-insert configFile]

[-delete configFile]

[-insert_scope scope_string [-attribute attr_string]]

[-delete_scope scope_string]

[-add_top_analog_scope scope_name]

[-rename_scope ]

[-o fsdb_file_name]

help信息中,还提供了一个例子:

examples:

  1. Insert a leaf scope.

    %fsdbedit verilog.fsdb -insert_scope '/system/$scope(test1)' -o sig.fsdb

  1. Insert a scope before another scope.

    %fsdbedit verilog.fsdb -insert_scope '/system/$scope(test1)/i_cpu' -o sig.fsdb

  1. Delete one scope.

    %fsdbedit verilog.fsdb -delete_scope '/system/$scope(i_cpu)' -o sig.fsdb

  1. Delete one scope and all the sub-scopes and signals.

    %fsdbedit verilog.fsdb -delete_scope '/system/$scope(i_cpu)/*' -o sig.fsdb

  1. Insert the scope in the configuration file.

    %fsdbedit verilog.fsdb -insert insert.cfg -o sig.fsdb

  1. Delete the scope in the configuration file.

    %fsdbedit verilog.fsdb -delete delete.cfg -o sig.fsdb

  1. Add top scopes for Nanosim or Spice FSDB files.

    %fsdbedit analog_or_nanosim.fsdb -add_top_analog_scope 'aa.bb' -o sig.fsdb

  1. Rename scope.

    %fsdbedit verilog.fsdb -rename_scope 'top/system' 'A' -o sig.fsdb

其中的$scope(),就是需要操作的波形的层次路径。

下面,介绍一下几个常用的选项的用法:

二、-insert_scope

该选项,用于向fsdb波形中,插入指定的层次路径。

比如我之前的层级路径为 tb_top/u_my_and。

1.png

现在想在 u_my_and 层次之上,插入 xxx.yyyy 层次。

那么命令为:

fsdbedit -insert_scope '/tb_top/$scope(xxx/yyy)/u_my_and' -o a.fsdb

此时生成的a.fsdb波形文件,层次路径如下:

2.png

$scope(),参数指定要插入的层次路径信息,使用 / 作为层次分隔符。

三、-rename_scope

该选项,用于向fsdb波形中,重命名指定的层次路径。

比如我之前的层级路径为 tb_top/xxx/yyy/u_my_and。

3.png

现在想把 xxx,给重命名成mmm。

那么命令为:

fsdbedit a.fsdb -rename_scope /tb_top/xxx' 'mmm' -o b.fsdb

此时生成的fsdb波形中,层次路径信息如下:

4.png

四、-delete_scope

该选项,用于向fsdb波形中,删除指定的层次路径。

比如我之前的层级路径为 tb_top/xxx/yyy/u_my_and。

5.png

现在想在删除xxx层次。那么命令为:

fsdbedit a.fsdb -delete_scope '/tb_top/$scope(xxx)' -o c.fsdb

此时生成的fsdb波形中,层次路径信息如下:
6.png

五、总结

利用fsdbedit工具,可以方便的修改fsdb波形文件中的模块的层次路径信息,从而match不同的仿真环境的模块的层次路径信息,从而能够高效的利用verdi进行debug。

更多相关阅读

systemverilog使用$fwrite系统函数打印信息到屏幕
sv利用fork join_none实现信号打拍操作
手机AI芯片有多神秘?解读华为自研架构NPU

原文首发于骏的世界博客
作者:卢骏.
更多IC设计相关的文章请关注IC设计极术专栏,每日更新。

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