mirror of https://github.com/zachjs/sv2v.git
47 lines
1.4 KiB
Systemverilog
47 lines
1.4 KiB
Systemverilog
// This test was adapted from Section 27.6 of IEEE 1800-2017
|
|
|
|
module mod;
|
|
initial $dumpvars(0, mod);
|
|
|
|
parameter genblk2 = 0;
|
|
genvar i;
|
|
|
|
// The following generate block is implicitly named genblk1
|
|
|
|
if (genblk2) logic a; // mod.genblk1.a
|
|
else logic b; // mod.genblk1.b
|
|
|
|
// The following generate block is implicitly named genblk02
|
|
// as genblk2 is already a declared identifier
|
|
|
|
if (genblk2) logic a; // mod.genblk02.a
|
|
else logic b; // mod.genblk02.b
|
|
|
|
// The following generate block would have been named genblk3
|
|
// but is explicitly named g1
|
|
|
|
for (i = 0; i < 1; i = i + 1) begin : g1 // block name
|
|
// The following generate block is implicitly named genblk1
|
|
// as the first nested scope inside g1
|
|
if (1) logic a; // mod.g1[0].genblk1.a
|
|
end
|
|
|
|
// The following generate block is implicitly named genblk4 since
|
|
// it belongs to the fourth generate construct in scope "mod".
|
|
// The previous generate block would have been
|
|
// named genblk3 if it had not been explicitly named g1
|
|
|
|
for (i = 0; i < 1; i = i + 1)
|
|
// The following generate block is implicitly named genblk1
|
|
// as the first nested generate block in genblk4
|
|
if (1) logic a; // mod.genblk4[0].genblk1.a
|
|
|
|
// The following generate block is implicitly named genblk5
|
|
if (1) logic a; // mod.genblk5.a
|
|
endmodule
|
|
|
|
module top;
|
|
mod #(0) m0();
|
|
mod #(1) m1();
|
|
endmodule
|