stariain的个人空间 https://blog.eetop.cn/1260220 [收藏] [复制] [分享] [RSS]

空间首页 动态 记录 日志 相册 主题 分享 留言板 个人资料

日志

verdi 仿真assertion的一些特殊情况

热度 1已有 4264 次阅读| 2017-7-6 16:38 |个人分类:IC备忘录|系统分类:硬件设计

1.   COVER_UART_TX_START_BUSY_1:
assert  property  (@(evt_uart_tx_start_dly)  (dut_uart_busy==1))   \
else  $display (  " ASSERTION   FAILED"  );
针对这种情况,一次成功之后后面不再显示  表示成功的上升箭头。

2.verdi针对1的这种情况,如果失败的话,(会在所有失败的地方飘红,显示下箭头)经过我自己的实验发现并不是这样的,只会出现一次failure的箭头。

3.针对COVER_UART_TX_START_BUSY_1:
assert  property  (@(evt_uart_tx_start_dly)    $rose(dut_uart_busy))   \
else  $display (  " ASSERTION   FAILED"  );
$rose 是采用两个event之间的值变化来判断的,对中间的可能发生的变化并不care。
也因此verdi的event在仿真的最初时刻均有一次触发(即上箭头表示)。
另外,这种情况下失败后在以后的失败中并不会出现其他失败的箭头,因为@event 与$rose,$fell并不能组合使用。

4.在verdi的仿真器中,如果直接assert  property的话,在波形中不会显示全部的触发状态,即使后续的触发并成功了也不会显示成功的信号;而先定义property,再assert property的话可以看到所有触发的状态,便于查看触发的时间点。

点赞

发表评论 评论 (1 个评论)

回复 cdly871226 2020-3-4 15:29
需要添加什么编译选项才能显示出来吗

facelist

您需要登录后才可以评论 登录 | 注册

  • 关注TA
  • 加好友
  • 联系TA
  • 0

    周排名
  • 0

    月排名
  • 0

    总排名
  • 0

    关注
  • 1

    粉丝
  • 0

    好友
  • 0

    获赞
  • 2

    评论
  • 1063

    访问数
关闭

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

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

GMT+8, 2024-4-19 15:41 , Processed in 0.013978 second(s), 9 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
返回顶部