verilator/test_regress/t/t_wrapper_clone.v

39 lines
866 B
Systemverilog
Raw Normal View History

// DESCRIPTION: Verilator: Verilog Test module for prepareClone/atClone APIs
//
// This model counts from 0 to 8. It forks a child process (in C++) at 6
// and waits for the child to simulate and exit for resumption (of the parent).
//
// This file ONLY is placed under the Creative Commons Public Domain.
// SPDX-FileCopyrightText: 2023 Yinan Xu
// SPDX-License-Identifier: CC0-1.0
2026-02-17 05:21:53 +01:00
module top (
input clock,
input reset,
input is_parent,
output do_clone
);
2026-02-17 05:21:53 +01:00
reg [3:0] counter;
2026-02-17 05:21:53 +01:00
assign do_clone = counter == 4'h6;
2026-02-17 05:21:53 +01:00
always @(posedge clock) begin
if (reset) begin
counter <= 4'h0;
end
else begin
counter <= counter + 4'h1;
$write("counter = %d\n", counter);
end
2026-02-17 05:21:53 +01:00
if (counter[3]) begin
if (is_parent) begin
$write("*-* All Finished *-*\n");
end
$finish(0);
end
end
endmodule