|
|
|
|
|
|
|
|
|
|
|
|
Ports In Interface
|
|
|
Wires and Variables inside a interface allows communications within a interface, but a interface needs to interface with other interfaces, then ports in interface can be used. Ports can be of any type as in the case of a module. |
|
|
|
|
|
|
|
|
|
|
|
Example : Simple Interface
|
|
|
|
|
|
1 //+++++++++++++++++++++++++++++++++++++++++++++++++
2 // Define the interface
3 //+++++++++++++++++++++++++++++++++++++++++++++++++
4 interface mem_if (
5 input wire clk,
6 input wire reset,
7 input wire we,
8 input wire ce,
9 input wire [7:0] datai,
10 output logic [7:0] datao,
11 input wire [7:0] addr
12 );
13 endinterface
14
15 //+++++++++++++++++++++++++++++++++++++++++++++++++
16 // DUT With interface
17 //+++++++++++++++++++++++++++++++++++++++++++++++++
18 module simple_if (mem_if mif);
19 // Memory array
20 logic [7:0] mem [0:255];
21 //=================================================
22 // Read logic
23 //=================================================
24 always @ (posedge mif.clk)
25 if (mif.reset) mif.datao <= 0;
26 else if (mif.ce && ! mif.we) begin
27 mif.datao <= mem[mif.addr];
28 end
29 //=================================================
30 // Write Logic
31 //=================================================
32 always @ (posedge mif.clk)
33 if (mif.ce && mif.we) begin
34 mem[mif.addr] <= mif.datai;
35 end
36
37 endmodule
38
39 //+++++++++++++++++++++++++++++++++++++++++++++++++
40 // Testbench
41 //+++++++++++++++++++++++++++++++++++++++++++++++++
42 module tb();
43
44 logic clk = 0;
45 always #10 clk++;
46 logic reset,ce,we;
47 logic [7:0] datai,addr;
48 wire [7:0] datao;
49 //=================================================
50 // Instianciate Interface and DUT
51 //=================================================
52 mem_if miff(
53 .clk (clk),
54 .reset (reset),
55 .ce (ce),
56 .we (we),
57 .datai (datai),
58 .datao (datao),
59 .addr (addr)
60 );
61
62 simple_if U_dut(.mif (miff));
63 //=================================================
64 // Test Vector generation
65 //=================================================
66 initial begin
67 reset <= 1;
68 ce <= 1'b0;
69 we <= 1'b0;
70 addr <= 0;
71 datai <= 0;
72 repeat (10) @ (posedge clk);
73 reset <= 0;
74 for (int i = 0; i < 3; i ++ ) begin
75 @ (posedge clk) ce <= 1'b1;
76 we <= 1'b1;
77 addr <= i;
78 datai <= $random;
79 @ (posedge clk) ce <= 1'b0;
80 $display ("@%0dns Write access address %x, data %x",
81 $time,addr, datai);
82 end
83 for (int i = 0; i < 3; i ++ ) begin
84 @ (posedge clk) ce <= 1'b1;
85 we <= 1'b0;
86 addr <= i;
87 repeat (2) @ (posedge clk);
88 ce <= 1'b0;
89 $display ("@%0dns Read access address %x, data %x",
90 $time,addr, datao);
91 end
92 #10 $finish;
93 end
94
95 endmodule
You could download file interface_ports.sv here
|
|
|
|
|
|
Example : Interface Ports
|
|
|
|
|
|
@230ns Write access address 00, data 24
@270ns Write access address 01, data 81
@310ns Write access address 02, data 09
@370ns Read access address 00, data 24
@430ns Read access address 01, data 81
@490ns Read access address 02, data 09
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Copyright © 1998-2025 |
Deepak Kumar Tala - All rights reserved |
Do you have any Comment? mail me at:deepak@asic-world.com
|
|