// DESCRIPTION: Verilator: Verilog Test module // // This file ONLY is placed under the Creative Commons Public Domain, for // any use, without warranty, 2022 by Antmicro Ltd. // SPDX-License-Identifier: CC0-1.0 module t; logic clk1 = 0; assign #3 clk1 = ~clk1; logic clk2 = 0; assign #11 clk2 = ~clk2; logic flag = 0; int a1 = 0; int b1 = 0; int c1 = 0; always @(posedge clk1) begin if (flag) #4 a1 = a1 + 1; else @(posedge clk2) b1 = b1 + 1; c1 = c1 + 1; flag = ~flag; end int a2 = 0; always_comb begin a2 = a1 << 1; `ifdef TEST_VERBOSE $display("[%0t] a2 = %0d", $time, a2); `endif end int b2 = 0; always_comb begin b2 = b1 << 2; `ifdef TEST_VERBOSE $display("[%0t] b2 = %0d", $time, b2); `endif end int c2 = 0; always_comb begin c2 = c1 << 3; `ifdef TEST_VERBOSE $display("[%0t] c2 = %0d", $time, c2); `endif end always @(posedge clk1) begin #1 if (c2 != c1 << 3) $stop; #5 if (a2 != a1 << 1) $stop; end always @(posedge clk2) #1 if (b2 != b1 << 2) $stop; initial #78 begin `ifdef TEST_VERBOSE $display("a1=%0d, b1=%0d, c1=%0d, a2=%0d, b2=%0d, c2=%0d", a1, b1, c1, a2, b2, c2); `endif if (a1 != 3) $stop; if (b1 != 4) $stop; if (c1 != a1 + b1) $stop; if (a2 != a1 << 1) $stop; if (b2 != b1 << 2) $stop; if (c2 != c1 << 3) $stop; $write("*-* All Finished *-*\n"); $finish; end endmodule