2011-10-28 00:56:38 +00:00
|
|
|
// DESCRIPTION: Verilator: Verilog Test module
|
|
|
|
//
|
2020-03-21 15:24:24 +00:00
|
|
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
|
|
|
// any use, without warranty, 2011 by Wilson Snyder.
|
|
|
|
// SPDX-License-Identifier: CC0-1.0
|
2011-10-28 00:56:38 +00:00
|
|
|
|
|
|
|
module t;
|
2012-04-26 22:43:12 +00:00
|
|
|
// verilator lint_off PINMISSING
|
2011-10-28 00:56:38 +00:00
|
|
|
`ifdef T_GEN_MISSING_BAD
|
|
|
|
foobar #(.FOO_TYPE(1)) foobar; // This means we should instatiate missing module
|
|
|
|
`elsif T_GEN_MISSING
|
|
|
|
foobar #(.FOO_TYPE(0)) foobar; // This means we should instatiate foo0
|
|
|
|
`else
|
|
|
|
`error "Bad Test"
|
|
|
|
`endif
|
|
|
|
endmodule
|
|
|
|
|
|
|
|
|
|
|
|
module foobar
|
|
|
|
#( parameter
|
|
|
|
FOO_START = 0,
|
|
|
|
FOO_NUM = 2,
|
|
|
|
FOO_TYPE = 1
|
|
|
|
)
|
|
|
|
(
|
2017-09-11 23:18:58 +00:00
|
|
|
input wire[FOO_NUM-1:0] foo,
|
2011-10-28 00:56:38 +00:00
|
|
|
output wire[FOO_NUM-1:0] bar);
|
|
|
|
|
|
|
|
|
|
|
|
generate
|
|
|
|
begin: g
|
|
|
|
genvar j;
|
|
|
|
for (j = FOO_START; j < FOO_NUM+FOO_START; j = j + 1)
|
|
|
|
begin: foo_inst;
|
|
|
|
if (FOO_TYPE == 0)
|
|
|
|
begin: foo_0
|
|
|
|
// instatiate foo0
|
|
|
|
foo0 i_foo(.x(foo[j]), .y(bar[j]));
|
|
|
|
end
|
|
|
|
if (FOO_TYPE == 1)
|
|
|
|
begin: foo_1
|
|
|
|
// instatiate foo1
|
|
|
|
foo_not_needed i_foo(.x(foo[j]), .y(bar[j]));
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
endgenerate
|
|
|
|
endmodule
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
module foo0(input wire x, output wire y);
|
|
|
|
|
|
|
|
assign y = ~x;
|
2017-09-11 23:18:58 +00:00
|
|
|
|
2011-10-28 00:56:38 +00:00
|
|
|
initial begin
|
|
|
|
$write("*-* All Finished *-*\n");
|
|
|
|
$finish;
|
|
|
|
end
|
|
|
|
endmodule
|