|  | 
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  
|  |  | Sample Event Definitions |  
|  |  | A sampling event expression must be specified in the coverage group definition. This sampling event is used for all instantiations of a coverage definition.  The sampling event expression defines when to update the bins.  Coverage objects can be triggered on clock edges, signal edges, variable changes, sync events and OVA events, and completions of user defined tasks.  The default behavior of sampling events is to sample the coverage object in a synchronous fashion (that is, The coverage object is sampled at the end of the simulation cycle after all Vera processing that can change variables is complete). Also, the coverage object is sampled at most once per simulation cycle even if the sampling event triggers more than once, unless the async attribute is used for the sample event. |  
|  |  | 
 |  
|  |  | There are many ways to sample a event as in below list. |  
|  |  | 
 |  
|  |  | 
  Clock and Signal Edges : Coverage objects can be sampled on clock or signal edges as per the synchronization command. When the specified edge occurs, the object is sampled.  Variable Changes : Coverage objects can be sampled when variables change value using the wait_var() system task. When the value of a variable change occurs, the object is sampled.Sync Events : Coverage objects can be sampled on sync events. When the sync is unblocked, the object is triggered.OVA Events : Coverage objects can be sampled on OVA events. When the OVA event occurs in the DUT, the Wait() member task on the OVA object unblocks.General Task Calls : If a coverage group needs an elaborate triggering mechanism, the sampling event can be a task call.Async Behavior : Optionally, the async attribute can be used with the sample event specification to gather coverage information immediately. |  
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  
|  |  | Example |  
|  |  | 
 |  
|  |  | 
  1 // Interface definition
  2 interface ifc {
  3   input clk CLOCK;
  4 }
  5 // Coverage class
  6 class coverage_sample_events {
  7   integer wv;
  8   event   se;
  9   bit     a;
 10   // Wait var as sample event
 11   coverage_group c1 {
 12     sample_event = wait_var (wv);
 13     sample a;
 14   }
 15   // sync event as sample event
 16   coverage_group c2 {
 17     sample_event = sync(ALL,se);
 18     sample a;
 19   }
 20   // sync event with async as sample event
 21   coverage_group c3 {
 22     sample_event = sync(ALL,se) async;
 23     sample a;
 24   }
 25   // CLOCK as sample event
 26   coverage_group c4 {
 27     sample_event = @ (posedge CLOCK);
 28     sample a;
 29   }
 30   // Interface signal as sample event
 31   coverage_group c5 {
 32     sample_event = @ (posedge ifc.clk);
 33     sample a;
 34   }
 35   // wait var on parameter as sample event
 36   coverage_group c6 (var integer wv_i) {
 37     sample_event = wait_var (wv_i);
 38     sample a;
 39   }
 40   // Constructor due to c6 needing a parameter
 41   task new () {
 42     c6 = new(wv);
 43     wv = 0;
 44   }
 45   // task to update coverage
 46   task update_coverage(bit b) {
 47     a = b;
 48     trigger(se);
 49     wv ++;
 50   }
 51 
 52 }
 53 // Program block
 54 program test {
 55   coverage_sample_events cov = new();
 56   bit b;
 57   repeat (2) {
 58     b = random();
 59     printf ("Value of b %b\n",b);
 60     cov.update_coverage(b);
 61     @ (posedge CLOCK);
 62   }
 63 }
You could download file coverage_sample_events.vr here |  
|  |  | 
 |  
|  |  | Simulation log |  
|  |  | 
 |  
|  |  |  Testbench Group List
 
 SCORE  WEIGHT GOAL   NAME                             
                                                       
   0.00 1      100    test::coverage_sample_events::c5 
                                                       
  50.00 1      100    test::coverage_sample_events::c4 
                                                       
 100.00 1      100    test::coverage_sample_events::c3 
                                                       
 100.00 1      100    test::coverage_sample_events::c2 
                                                       
 100.00 1      100    test::coverage_sample_events::c1 
                                                       
 100.00 1      100    test::coverage_sample_events::c6 
                                                       
 
 |  
|  |  | 
 |  
|  |  | 
 |  
|  |  | 
 |  
|  |  |  |  
|  |  | 
 |  |  | 
|  
 |  
 |  
 | 
| 
 | 
|    |  
| Copyright © 1998-2025 |  
| Deepak Kumar Tala - All rights reserved |  
| Do you have any Comment? mail me at:deepak@asic-world.com
 |  |