verilator/test_regress/t/t_process_fork.v
2023-06-01 10:02:08 -04:00

31 lines
741 B
Systemverilog

// DESCRIPTION: Verilator: Verilog Test module
//
// This file ONLY is placed under the Creative Commons Public Domain, for
// any use, without warranty, 2023 by Antmicro Ltd.
// SPDX-License-Identifier: CC0-1.0
module t;
process job[] = new [8];
bit is_alloc = 0;
initial begin
foreach (job[j]) fork
begin
$write("job started\n");
job[j] = process::self();
end
join_none
foreach (job[j]) begin
is_alloc = !!job[j];
wait (is_alloc);
end
$write("all jobs started\n");
foreach (job[j]) begin
job[j].await();
end
$write("all jobs finished\n");
$write("*-* All Finished *-*\n");
$finish;
end
endmodule