quick.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

   

space.gif

   

space.gif

  ../images/main/bullet_green_ball.gif Vera Functional Coverage

Vera supports a functional coverage system. This system is able to monitor all states and state transitions, as well as changes to variables and expressions. By setting up a number of monitor bins that correspond to states, transitions, and expression changes, Vera is able to track activity in the simulation. Each time a user-specified activity occurs, a counter associated with the bin is incremented. By establishing a bin for each state, state transition, and variable change that you want monitored, you can check the bin counter after the simulation to see how many activities occurred. It is, therefore, simple to check the degree of completeness of the testbench and simulation.

   

space.gif

In this section we will covering following topics in details.

   

space.gif

  • Coverage Group
  • Measuring Coverage
  • Cumulative and Instance-based Coverage
   

space.gif

Basically functional coverage can be seen as bunch of counters, and these counters increment based on some events. Events can be simple or complex. Functional coverage point for a memory controller could have coverage samples as

   

space.gif

  • Reads
  • Writes
  • Reads Followed by write
  • Write folloed by read
  • Data width
  • Address width
   

space.gif

Functional coverage is declared inside a class, just like randomization constraints. They need to declared before any method is declared.

   

space.gif

   

space.gif

  ../images/main/bulllet_4dots_orange.gif Coverage Group

The coverage_group construct specifies the coverage model. It is defined either at the top level defined in a class (referred to as "embedded") The syntax is the same for both.

   

space.gif

Syntax

   

space.gif

coverage_group definition_name [(argument_list)]
{
sample_event_definition;
[coverage_point_definitions]
[cross_definitions]
[attribute_definitions]
}
   

space.gif

Where

   

space.gif

  • definition_name : Is the name of the coverage_group.
  • argument_list : Are arguments passed at instantiation. They have the same conventions as subroutine arguments and can have their default values set within the declaration
  • sample_event_definition : Defines when (or frequency at which) the coverage objects are sampled.
  • coverage_point_definitions : define the coverage points that are sampled by the coverage_group. They are declared using the sample construct of a coverage_group.
  • cross_definitions : cross_definitions define cross coverage by crossing subsets of the coverage points being sampled by a coverage_group which includes the cross_definition. Crosses of coverage points of a coverage_group can be specified using the cross construct.
   

space.gif

  ../images/main/bullet_star_pink.gif embedded coverage group

When a coverage is defined inside a class it is called embedded coverage group. It is recommended that embedded coverage group is used.

   

space.gif

Example


  1 class coverage_covergroup {
  2   // All variables declared here
  3   integer abc;
  4   bit [7:0] data;
  5 
  6   // Declare coverage_groups here
  7   coverage_group c1 {
  8      sample_event = wait_var(abc);
  9      // Body of coveragegroup here
 10      sample data;
 11    
 12   }
 13 
 14   // All the class methods here
 15   task new () {
 16     // do something
 17   }
 18 }
 19 
 20 program test {
 21   coverage_covergroup cov = new();
 22 }
You could download file coverage_covergroup.vr here
   

space.gif

  ../images/main/bullet_star_pink.gif Standalone coverage group

When a coverage is defined outside a class it is called stanalone coverage group.

   

space.gif

Example


  1 coverage_group c1 {
  2    sample_event = wait_var(abc);
  3    // Body of coveragegroup here
  4    sample data;
  5 }
  6 
  7 program test {
  8   integer abc;
  9   bit [7:0] data;
 10 }
You could download file coverage_covergroup_standalone.vr here
   

space.gif

   

space.gif

   

space.gif

   

space.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

  

Copyright © 1998-2025

Deepak Kumar Tala - All rights reserved

Do you have any Comment? mail me at:deepak@asic-world.com