forked from github/verilator
3737d209f6
Fixes (#3324).
47 lines
1.2 KiB
Systemverilog
47 lines
1.2 KiB
Systemverilog
// DESCRIPTION: Verilator: Verilog Test module
|
|
//
|
|
// Copyright 2022 by Geza Lore. This program is free software; you can
|
|
// redistribute it and/or modify it under the terms of either the GNU
|
|
// Lesser General Public License Version 3 or the Perl Artistic License
|
|
// Version 2.0.
|
|
// SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
|
|
|
// This hits a case where parameter specialization of recursive modules
|
|
// used to yield a module list that was not topologically sorted, which
|
|
// then caused V3Inline to blow up as it assumes that.
|
|
|
|
module top #(
|
|
parameter N=8
|
|
) (
|
|
input wire [N-1:0] i,
|
|
output wire [N-1:0] o,
|
|
output wire [N-1:0] a
|
|
);
|
|
|
|
sub #(.N(N)) inst(.i(i), .o(a));
|
|
|
|
generate if (N > 1) begin: recursive
|
|
top #(.N(N/2)) hi(.i(i[N - 1:N/2]), .o(o[N - 1:N/2]), .a());
|
|
top #(.N(N/2)) lo(.i(i[N/2 - 1: 0]), .o(o[N/2 - 1: 0]), .a());
|
|
end else begin: base
|
|
assign o = i;
|
|
end endgenerate
|
|
|
|
endmodule
|
|
|
|
module sub #(
|
|
parameter N = 8
|
|
) (
|
|
input wire [N-1:0] i,
|
|
output wire [N-1:0] o
|
|
);
|
|
|
|
generate if (N > 1) begin: recursive
|
|
sub #(.N(N/2)) hi(.i(i[N - 1:N/2]), .o(o[N - 1:N/2]));
|
|
sub #(.N(N/2)) lo(.i(i[N/2 - 1: 0]), .o(o[N/2 - 1: 0]));
|
|
end else begin: base
|
|
assign o = i;
|
|
end endgenerate
|
|
|
|
endmodule
|