2025-06-05 03:43:46 +02:00
|
|
|
// DESCRIPTION: Verilator: Verilog Test module
|
|
|
|
|
//
|
2026-01-27 02:24:34 +01:00
|
|
|
// This file ONLY is placed under the Creative Commons Public Domain.
|
|
|
|
|
// SPDX-FileCopyrightText: 2025 Wilson Snyder
|
2025-06-05 03:43:46 +02:00
|
|
|
// SPDX-License-Identifier: CC0-1.0
|
|
|
|
|
|
|
|
|
|
interface my_ifc ();
|
2026-03-08 23:26:40 +01:00
|
|
|
logic sig;
|
|
|
|
|
modport master(output sig);
|
|
|
|
|
modport slave(input sig);
|
2025-06-05 03:43:46 +02:00
|
|
|
endinterface
|
|
|
|
|
|
|
|
|
|
package my_pkg;
|
2026-03-08 23:26:40 +01:00
|
|
|
typedef virtual my_ifc my_vif;
|
|
|
|
|
function void my_func;
|
|
|
|
|
input my_vif in_vif;
|
|
|
|
|
begin
|
|
|
|
|
in_vif.sig = 1'b1;
|
|
|
|
|
end
|
|
|
|
|
endfunction
|
2025-06-05 03:43:46 +02:00
|
|
|
endpackage
|
|
|
|
|
|
2026-03-08 23:26:40 +01:00
|
|
|
module dut (
|
|
|
|
|
input logic clk,
|
|
|
|
|
my_ifc.slave sif[2]
|
|
|
|
|
);
|
|
|
|
|
generate
|
|
|
|
|
genvar i;
|
|
|
|
|
for (i = 0; i < 2; i++) begin
|
|
|
|
|
always_ff @(posedge clk) begin
|
|
|
|
|
if (sif[i].sig == 1'b1) $display("Hello World %0d", i);
|
2025-06-05 03:43:46 +02:00
|
|
|
end
|
2026-03-08 23:26:40 +01:00
|
|
|
end
|
|
|
|
|
endgenerate
|
2025-06-05 03:43:46 +02:00
|
|
|
endmodule
|
|
|
|
|
|
|
|
|
|
module t;
|
2026-03-08 23:26:40 +01:00
|
|
|
import my_pkg::*;
|
2025-06-05 03:43:46 +02:00
|
|
|
|
2026-03-08 23:26:40 +01:00
|
|
|
logic clk;
|
|
|
|
|
my_ifc sif[2] ();
|
2025-06-05 03:43:46 +02:00
|
|
|
|
2026-03-08 23:26:40 +01:00
|
|
|
dut DUT (.*);
|
2025-06-05 03:43:46 +02:00
|
|
|
|
2026-03-08 23:26:40 +01:00
|
|
|
initial begin
|
|
|
|
|
clk = 0;
|
|
|
|
|
forever #(5) clk = ~clk;
|
|
|
|
|
end
|
2025-06-05 03:43:46 +02:00
|
|
|
|
2026-03-08 23:26:40 +01:00
|
|
|
initial begin
|
|
|
|
|
repeat (4) @(posedge clk);
|
|
|
|
|
my_func(sif[0]);
|
|
|
|
|
my_func(sif[1]);
|
|
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
|
$finish;
|
|
|
|
|
end
|
2025-06-05 03:43:46 +02:00
|
|
|
endmodule
|