在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
查看: 7521|回复: 12

[求助] 急求,Formality吃了svf后的unmatch问题

[复制链接]
发表于 2020-12-2 09:49:48 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x
各位大神,不吝赐教啊!!!

1、环境:DC 2016 2018均试过,FM为2016

2、背景:A、B两个项目,A中有个小harden名为C,B和C都比对过了,只有A有大量unmatch

3、现象:A的DC生成了svf,Formality吃了该svf,依然有大量unmatch。分析发现,这些unmatch点均为DC中被merge掉了,但是Formality没吃到merge信息,认为这些cell还存在

4、其他:(1)查看了DC生成的网表,这些cell确实被merge掉了
               (2)dc.log里没有这些merge信息
               (3)Formality生成的svf.txt中也没有这些cell的merge信息(不是rejected,而是压根没有)

现在不确定merge信息是Formality吃.svf二进制文件时丢失了,还是DC压根就没写入,请问有没有大神遇到过类似问题,现在卡住了,不知道如何往下debug。

各位大神,不吝赐教啊!!!
发表于 2020-12-2 16:20:12 | 显示全部楼层
DC是不是analyze&elaborate(也可以是read的过程) 的过程没有被svf记录?这个过程不记录会导致这一类问题。
 楼主| 发表于 2020-12-2 18:51:20 | 显示全部楼层


13129969857 发表于 2020-12-2 16:20
DC是不是analyze&elaborate(也可以是read的过程) 的过程没有被svf记录?这个过程不记录会导致这一类问题。 ...


    您说这个倒是没有考虑过,有这个可能。
  那么请问如何保证这个过程被记录呢?现在set_svf已经是写在最前面了,光有这句话能保证吗?

发表于 2020-12-3 09:12:21 | 显示全部楼层


zaqi 发表于 2020-12-2 18:51
您说这个倒是没有考虑过,有这个可能。
  那么请问如何保证这个过程被记录呢?现在set_svf已经是写在 ...


是的,set_svf写在最前面就可以了。
 楼主| 发表于 2020-12-3 11:35:47 | 显示全部楼层
本帖最后由 zaqi 于 2020-12-3 11:37 编辑

追加调试进度:
    现在单拎出某一个不到1000行代码的.v,居然都比对不过。
    该module内有一个[10:0]的reg,第[9] bit实际用不到。
    根据各种输出报告,该bit的cell在DC compile前还存在,compile后就没了,看不到remove。

    Formality无论吃不吃svf,都是这一bit的cell unmatch,因为它认为在ref中该cell还存在,但是在imp中找不到

    DC版本2016 2018  Formality版本2016 2017,4种排列组合都尝试了,现象一致。
   
    现在定位,Formality与DC对那一bit的处理策略明显不一样,但是在svf中又看不到那一bit的remove,不知该如何是好了。

    ps:这只是为了debug的手段,实际工程庞大,有大量类似问题,所以不可能通过修改代码或者单独用语句去处理那一个寄存器的方法来规避问题。

    各位大神显显神通,救救小弟啊!!!
发表于 2020-12-4 09:40:25 | 显示全部楼层
看看编译脚本?formality的问题之前也是很头疼,一般来说,只要流程规范,formality有时候是会出现unmatch的,但是verify会过。
发表于 2020-12-4 10:58:21 | 显示全部楼层
不用太纠结unmatch,看下log里面是VERIFYED SUCCESSED还是FAILED,或者可以start_gui看下
发表于 2020-12-6 23:11:22 | 显示全部楼层
1、首先确认formality是否fail;
2、如果fail,看是否是unmatch 导致;如果是的话就比较麻烦,建议首先确认综合和formality两边读取代码的方式是否一致,尤其是宏定义顺序、传参等影响;如果不是可以进入第三步
3、如果success或者非unmatch 导致fail,需要设计分析unmatch原因,看是否对功能无影响;确认完毕即可。
unmatch对于大设计来说是很正常的,不过你说的merge的问题,还没有遇到过,希望解决之后share一下原因。
发表于 2020-12-16 13:40:47 | 显示全部楼层
路过学习,很实用,谢谢分享
发表于 2020-12-16 15:40:51 | 显示全部楼层
路过学习,很实用,谢谢分享
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /1 下一条

小黑屋| 手机版| 关于我们| 联系我们| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2025-1-27 12:08 , Processed in 0.027701 second(s), 6 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表