quick.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

space2.gif

   

space.gif

   

space.gif

  ../images/main/bulllet_4dots_orange.gif event data types

The event data type is same as that found in Verilog, with slight improvement. In SystemVerilog one event variable can be aliased to another event variable and also SystemVerilog allows a event variable to be always triggered.

   

space.gif

Syntax : event variable_name [= initial_value];

   

space.gif

Where initial_value can be another event variable if you want to alias, or null if you want variable_name to be triggered always. If you don't specify any initial value then it behave like a new event variable as in Verilog 2001.

   

space.gif

   

space.gif

  ../images/main/bullet_star_pink.gif Example - event
   

space.gif


  1 module events();
  2 // Declare a new event called ack
  3 event ack; 
  4 // Declare done as alias to ack 
  5 event done = ack; 
  6 // Event variable with no synchronization object
  7 event empty = null; 
  8 
  9 initial begin
 10    #1  -> ack;
 11    #1  -> empty;
 12    #1  -> done;
 13    #1  $finish;
 14 end
 15 
 16 always @ (ack)
 17 begin
 18   $display("ack event emitted");
 19 end
 20 
 21 always @ (done)
 22 begin
 23   $display("done event emitted");
 24 end
 25 
 26 /*
 27 always @ (empty)
 28 begin
 29   $display("empty event emitted");
 30 end
 31 */
 32 
 33 endmodule
You could download file events.sv here
   

space.gif

  ../images/main/bullet_star_pink.gif Simulator Output
   

space.gif

 ack event emitted
 done event emitted
 ack event emitted
 done event emitted
   

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