sv 功能覆盖率

本文介绍了SystemVerilog中的covergroup概念,如何在类外部定义以及如何在类内部使用。文章详细阐述了`binsof`函数用于从位向量中提取1的位置并返回集合,以及`intersect`函数计算两个集合交集的功能。这两个函数在功能覆盖率收集方面起到关键作用,帮助开发者分析和处理覆盖率数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

covergroup定义在类外面:

covergroup cmd_fcov with function sample(svt_axi_transaction tr);
    coverpoint tr.addr;
    coverpoint tr.id;
    coverpoint tr.data.size;
endgroup

class xx_refm extends uvm_refm;

cmd_fcov  A_cov;

function new(string name = "psub_sdma_scb", uvm_component parent);
A_cov = new();
endfunction

//在具体的位置调用:A_cov.sample(axi_tr); 
endclass

一下常用表达:表达很大位宽的最大值


功能覆盖率的cross采样:

功能覆盖率基于采样事件采样到当前时刻的值进行cross,不会在不同时间片段之间进行cross,已验证;


接口覆盖率:

方法一:

  1. 定义一个module接口和DUT保持一致,接口方向定义为input。
  2. 在这个module里面定义covergroup去采样相关接口信号。
  3. 在module里面的initial块里面去实例化covergroup。
  4. 在top_connect顶层去把fcov_if_module bind到DUT上。
  5. 采用:bind  DUT_inst1    fcov_if_module   fcov_if_module_inst1(.*)

这个方法的好处是在ST重用场景如果BT有多个时,会比较友好,可以去bind到不同实例上。

方法二:直接定义在外面一个文件,include到顶层连接文件。就是比较简单快捷。如果ST重用有多个对应DUT可以考虑通过实例化多份,采样对应的实例信号。


常用的方法:

在SystemVerilog中,`binsof`和`intersect`是用于处理位向量和集合的内建函数。

- `binsof`函数用于从一个位向量中提取1的位置,并将结果返回为一个集合。它的语法如下: ```systemverilog function integer binsof(input logic [N-1:0] vector); ``` 其中,`vector`是一个位向量,`N`代表位向量的宽度。`binsof`会遍历`vector`的每一位,并将值为1的索引添加到返回的集合中。例如,对于位向量`8'b11010011`,`binsof`会返回`{0, 3, 4, 6, 7}`。

- `intersect`函数用于计算两个集合的交集,并将结果返回为一个集合。它的语法如下: ```systemverilog function static integer intersect(input integer A[$], input integer B[$]); ``` 其中,`A`和`B`是两个集合。`intersect`会返回`A`和`B`的交集。例如,对于集合`{1, 2, 3, 4}`和`{3, 4, 5}`,`intersect`会返回`{3, 4}`。

在 SystemVerilog 中,`binsof` 和 `intersect` 是在功能覆盖率收集上使用的两个关键字。

`binsof` 用于在 `covergroup` 或 `coverpoint` 中获取已定义的覆盖率桶(coverage bin)的集合。通过使用 `binsof`,可以访问和操作覆盖率桶中的信息。

以下是 `binsof` 的示例用法: ```systemverilog

covergroup my_coverage;

coverpoint my_signal {

bins data = {0, 1, [2:5], 8};

bins edge = {posedge, negedge}; }

endgroup

function void my_function();

int my_bins[$];

my_bins = my_coverage.my_signal.binsof(data);

foreach (my_bins[i]) $display("Data bin: %0d", my_bins[i]);

// 获取与两个覆盖率桶相交的交集

my_bins = intersect(my_coverage.my_signal.binsof(data), my_coverage.my_signal.binsof(edge)); foreach (my_bins[i])    $display("Intersection bin: %0d", my_bins[i]);

endfunction

``` 在上述示例中,`my_coverage` 是一个 `covergroup`,其中包含了一个 `coverpoint` `my_signal`,它定义了两个覆盖率桶 `data` 和 `edge`。通过使用 `binsof`,可以获取名为 `data` 的覆盖率桶,并在 `my_function` 中进行操作和输出。 `intersect` 是一个函数,用于获取两个集合的交集。在上述示例中,`intersect` 函数用于获取 `data` 和 `edge` 这两个覆盖率桶集合的交集,并在 `my_function` 中进行操作和输出。 这些关键字和功能可以帮助开发人员在进行功能覆盖率分析时收集和处理相关数据。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值