verilator/test_regress/t/t_clocking_react.v
Krzysztof Bieganski 51691dfde5 Fix driving clocking block in Reactive
Signed-off-by: Krzysztof Bieganski <kbieganski@antmicro.com>
2024-09-04 07:57:51 -04:00

43 lines
1.4 KiB
Systemverilog

// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2024 by Antmicro Ltd.
// SPDX-License-Identifier: CC0-1.0
interface axi_if;
logic clk;
wire rlast;
wire rvalid;
clocking cb @(posedge clk);
inout rlast, rvalid;
endclocking
endinterface
module t;
axi_if axi_vi();
initial begin
axi_vi.clk = 1'b0;
#1 axi_vi.clk = 1'b1; // triggers line 26
#1 axi_vi.clk = 1'b0; // triggers line 29 (shouldn't happen)
#1 axi_vi.clk = 1'b1; // triggers line 18 (shouldn't happen)
end
initial begin
@(negedge axi_vi.rvalid);
$display("[%0t] rvalid==%b", $time, axi_vi.rvalid);
$display("[%0t] rlast is 1: ", $time, axi_vi.rlast === 1);
if (axi_vi.rlast === 1) $stop;
$write("*-* All Finished *-*\n");
$finish;
end
initial begin
$display("[%0t] rvalid <= 1", $time);
axi_vi.cb.rvalid <= 1'b1; // assigned on first clk posedge (line 13)
@(posedge axi_vi.rvalid);
$display("[%0t] rvalid <= 0", $time);
axi_vi.cb.rvalid <= 1'b0; // assigned on second clk posedge (line 15), but should be on first
@(negedge axi_vi.clk);
$display("[%0t] rlast <= 1", $time);
axi_vi.cb.rlast <= 1'b1; // assigned on second clk posedge (line 15), shouldn't happen
end
endmodule