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 Parameterized Interfaces

Interface definitions can take advantage of parameters and parameter redefinition, in the same manner as module definitions. There is no difference between parameters used in a module and a interface.

   

space.gif

Below example shows usage of prameter inside a interface.

   

space.gif

   

space.gif

  ../images/main/bullet_star_pink.gif Example : Parameter
   

space.gif


  1 //+++++++++++++++++++++++++++++++++++++++++++++++++
  2 // Define the interface
  3 //+++++++++++++++++++++++++++++++++++++++++++++++++
  4 interface count_if #(WIDTH = 4) (input clk);
  5   logic   reset;
  6   logic   enable;
  7   logic  [WIDTH-1 : 0] count;
  8   //=================================================
  9   // Modports declaration 
 10   //=================================================
 11   modport dut (input clk, reset, enable, output count);
 12   modport tb  (input clk, count, output reset, enable, import monitor);
 13   //=================================================
 14   // Monitor Task
 15   //=================================================
 16   task  monitor();
 17     while (1) begin
 18       @ (posedge clk);
 19       if (enable) begin
 20         $display ("@%0dns reset %b enable %b count %b",
 21           $time, reset, enable, count); 
 22       end
 23     end
 24   endtask
 25 endinterface
 26 //+++++++++++++++++++++++++++++++++++++++++++++++++
 27 // Counter DUT
 28 //+++++++++++++++++++++++++++++++++++++++++++++++++
 29 module counter #(WIDTH = 4) (count_if.dut dif);
 30   //=================================================
 31   // Dut implementation
 32   //=================================================
 33   always @ (posedge dif.clk)
 34     if (dif.reset) begin
 35        dif.count <= {WIDTH{1'b0}};
 36     end else if (dif.enable) begin
 37        dif.count ++;
 38     end
 39 endmodule
 40 //+++++++++++++++++++++++++++++++++++++++++++++++++
 41 // Program for counter (TB)
 42 //+++++++++++++++++++++++++++++++++++++++++++++++++
 43 program counterp #(WIDTH = 4) (count_if.tb tif);
 44   //=================================================
 45   // Default Clocking for using ##<n> delay
 46   //=================================================
 47   default clocking cb @ (posedge tif.clk);
 48 
 49   endclocking
 50   //=================================================
 51   // Generate the test vector
 52   //=================================================
 53   initial begin
 54     // Fork of the monitor
 55     fork
 56       tif.monitor();
 57     join_none
 58     tif.reset <= 1;
 59     tif.enable <= 0;
 60      ##10  tif.reset <= 0;
 61      ##1  tif.enable <= 1;
 62      ##10  tif.enable <= 0;
 63      ##5  $finish;
 64   end
 65 endprogram
 66 //+++++++++++++++++++++++++++++++++++++++++++++++++
 67 // Top Level 
 68 //+++++++++++++++++++++++++++++++++++++++++++++++++
 69 module interface_parameter();
 70   localparam  WIDTH = 5;
 71   logic clk = 0;
 72   always  #1  clk ++;
 73 
 74   count_if #(WIDTH)         cif (clk);
 75   counter  #(.WIDTH(WIDTH)) dut (cif);
 76   counterp #(WIDTH)         tb  (cif);
 77 
 78 endmodule
You could download file interface_parameter.sv here
   

space.gif

  ../images/main/bullet_star_pink.gif Simulation : Parameter
   

space.gif

 @23ns reset 0 enable 1 count 00001
 @25ns reset 0 enable 1 count 00010
 @27ns reset 0 enable 1 count 00011
 @29ns reset 0 enable 1 count 00100
 @31ns reset 0 enable 1 count 00101
 @33ns reset 0 enable 1 count 00110
 @35ns reset 0 enable 1 count 00111
 @37ns reset 0 enable 1 count 01000
 @39ns reset 0 enable 1 count 01001
 @41ns reset 0 enable 1 count 01010
   

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