verilator/test_regress/t/t_timing_nba_2.v

45 lines
1.1 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.
// SPDX-License-Identifier: CC0-1.0
module t;
logic clk1 = 0, clk2 = 0, clk3 = 0, clk4 = 0;
always #2 clk1 = ~clk1;
assign #1 clk2 = clk1;
assign #1 clk3 = clk2;
assign #1 clk4 = clk3;
int x = 0;
int cyc = 0;
always @(posedge clk1) begin
if (x != 0) $stop;
`ifdef TEST_VERBOSE
$display("[%0t] clk1 | x=%0d cyc=%0d", $realtime, x, cyc);
`endif
@(posedge clk2);
`ifdef TEST_VERBOSE
$display("[%0t] clk2 | x=%0d cyc=%0d", $realtime, x, cyc);
`endif
x <= x + 1;
cyc <= cyc + 1;
if (cyc == 10) begin
$write("*-* All Finished *-*\n");
$finish;
end
end
always @(posedge clk3) begin
`ifdef TEST_VERBOSE
$display("[%0t] clk3 | x=%0d cyc=%0d", $realtime, x, cyc);
`endif
@(posedge clk4);
`ifdef TEST_VERBOSE
$display("[%0t] clk4 | x=%0d cyc=%0d", $realtime, x, cyc);
`endif
x <= x - 1;
end
endmodule