ignore_bins和default两者之间有些什么细微差别呢?

电子说

1.3w人已加入

描述

在SystemVerilog中,经常会需要将一些值或者翻转行为从覆盖率中排除掉,ignore_bins是经常被用到的一种方式,其实除了ignore_bins之外,还可以将一些bins的值范围指定为关键字defualt,从而实现将一些不期望或者无效的数据进行分配,同样也可以实现命中该仓的数据不被收集到覆盖率中。既生瑜何生亮,效果都一样,为什么要存在两个呢?两者之间有些什么细微差别呢?下文将通过示例说明。

1 ignore_bins

【示例】忽略一些数值 

仿真器

【仿真结果】 

仿真器

示例中仿真统计结果中可以看到,命中val仓(ignore_bins)的数值被排除在覆盖率的计算之外,即被exclude掉了,并且val仓及其中相关数值在解析时不会被命中。通过例子可以看到,当定义了ignore_bins时,EDA仿真工具不会收集相应ignore_bins中的数据,即ignore_bins一般用于将一些值或者翻转行为从覆盖率中排除掉。

2 default bins

【示例】 

仿真器

【仿真结果】 

仿真器

示例仿真统计结果中可以看到,命中val1仓(default)的数值被排除在覆盖率的计算之外,即被exclude掉了,但是val1仓在仿真时会被命中,从某种程度上来说ignore_bins更像是刻意去exclude一些数值,而default更像是要囊括一些确定要覆盖数据之外的数据。既然两者都这么“不接受不拒绝”,那么可不可把ignore_bins后头的数值范围也省略了直接用default呢?请看下例。

【示例】 

仿真器

【仿真结果】 

仿真器

么办法,工具提示ignore_bins和default这两个这种行为是不允许的,不能既想当老鸨还要立牌坊,即不能将ignore_bins的取值范围设成default,

在上述ignore_bins的示例中,注意到可以不定义其他的仓,仅仅只指定ignore_bins,那么对于指定的default仓,是否可以不指定其他仓,仅仅只指定一个仓为default呢?请看下头的例子。

【示例】 

仿真器

【仿真结果】 

仿真器

从仿真结果中可以看到,仿真工具已经无法显示percent了,因为此时val仓的取值范围为default,仿真工具不知道default之外的值是什么,所以也就无法进行相关的覆盖率统计,当然一般情况下也么人这么无聊在一个coverpoint中指定一个仓并且将其取值范围设为default。

通过上面几个示例,ignore_bins和仓的default之间的关系可以简单汇总如下:

Øignore_bins和仓的default对于coverage都么有什么影响;

Øignore_bins在仿真时不会进行仓的命中的统计,而仓的default会进行仓命中情况的统计;

Øignore_bins指定的取值范围不能设为default;

Øignore_bins偏重于忽略一些具体范围的值,即确定要忽略的一些值;

Ø仓取值范围设为default主要是涵盖一些不在计划中或者无效的数据,即一些不是太确定的数值;





审核编辑:刘清

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分