forked from github/verilator
Fix nested generate if genblk naming (#3189).
This commit is contained in:
parent
304697d133
commit
758264dc77
1
Changes
1
Changes
@ -16,6 +16,7 @@ Verilator 4.215 devel
|
|||||||
* Internal code cleanups and improvements. [Geza Lore]
|
* Internal code cleanups and improvements. [Geza Lore]
|
||||||
* Fix array method names with parens (#3181) (#3183). [Teng Huang]
|
* Fix array method names with parens (#3181) (#3183). [Teng Huang]
|
||||||
* Fix split_var assign merging (#3177) (#3179). [Yutetsu TAKATSUKASA]
|
* Fix split_var assign merging (#3177) (#3179). [Yutetsu TAKATSUKASA]
|
||||||
|
* Fix nested generate if genblk naming (#3189). [yanx21]
|
||||||
|
|
||||||
|
|
||||||
Verilator 4.214 2021-10-17
|
Verilator 4.214 2021-10-17
|
||||||
|
@ -105,6 +105,21 @@ private:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool nestedIfBegin(AstBegin* nodep) { // Point at begin inside the GenIf
|
||||||
|
// IEEE says directly nested item is not a new block
|
||||||
|
// The genblk name will get attached to the if true/false LOWER begin block(s)
|
||||||
|
// 1: GENIF
|
||||||
|
// -> 1:3: BEGIN [GEN] [IMPLIED] // nodep passed to this function
|
||||||
|
// 1:3:1: GENIF
|
||||||
|
// 1:3:1:2: BEGIN genblk1 [GEN] [IMPLIED]
|
||||||
|
AstNode* const backp = nodep->backp();
|
||||||
|
return (nodep->implied() // User didn't provide begin/end
|
||||||
|
&& VN_IS(backp, GenIf) && VN_CAST(backp, GenIf)->elsesp() == nodep
|
||||||
|
&& !nodep->nextp() // No other statements under upper genif else
|
||||||
|
&& (VN_IS(nodep->stmtsp(), GenIf)) // Begin has if underneath
|
||||||
|
&& !nodep->stmtsp()->nextp()); // Has only one item
|
||||||
|
}
|
||||||
|
|
||||||
// VISITs
|
// VISITs
|
||||||
virtual void visit(AstNodeFTask* nodep) override {
|
virtual void visit(AstNodeFTask* nodep) override {
|
||||||
if (!nodep->user1SetOnce()) { // Process only once.
|
if (!nodep->user1SetOnce()) { // Process only once.
|
||||||
@ -539,12 +554,10 @@ private:
|
|||||||
virtual void visit(AstBegin* nodep) override {
|
virtual void visit(AstBegin* nodep) override {
|
||||||
V3Config::applyCoverageBlock(m_modp, nodep);
|
V3Config::applyCoverageBlock(m_modp, nodep);
|
||||||
cleanFileline(nodep);
|
cleanFileline(nodep);
|
||||||
AstNode* backp = nodep->backp();
|
AstNode* const backp = nodep->backp();
|
||||||
// IEEE says directly nested item is not a new block
|
// IEEE says directly nested item is not a new block
|
||||||
const bool nestedIf = (nodep->implied() // User didn't provide begin/end
|
// The genblk name will get attached to the if true/false LOWER begin block(s)
|
||||||
&& (VN_IS(nodep->stmtsp(), GenIf)
|
const bool nestedIf = nestedIfBegin(nodep);
|
||||||
|| VN_IS(nodep->stmtsp(), GenCase)) // Has an if/case
|
|
||||||
&& !nodep->stmtsp()->nextp()); // Has only one item
|
|
||||||
// It's not FOR(BEGIN(...)) but we earlier changed it to BEGIN(FOR(...))
|
// It's not FOR(BEGIN(...)) but we earlier changed it to BEGIN(FOR(...))
|
||||||
if (nodep->genforp()) {
|
if (nodep->genforp()) {
|
||||||
++m_genblkNum;
|
++m_genblkNum;
|
||||||
@ -576,9 +589,13 @@ private:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
virtual void visit(AstGenIf* nodep) override {
|
virtual void visit(AstGenIf* nodep) override {
|
||||||
++m_genblkNum;
|
|
||||||
cleanFileline(nodep);
|
cleanFileline(nodep);
|
||||||
{
|
bool nestedIf
|
||||||
|
= (VN_IS(nodep->backp(), Begin) && nestedIfBegin(VN_CAST(nodep->backp(), Begin)));
|
||||||
|
if (nestedIf) {
|
||||||
|
iterateChildren(nodep);
|
||||||
|
} else {
|
||||||
|
++m_genblkNum;
|
||||||
VL_RESTORER(m_genblkAbove);
|
VL_RESTORER(m_genblkAbove);
|
||||||
VL_RESTORER(m_genblkNum);
|
VL_RESTORER(m_genblkNum);
|
||||||
m_genblkAbove = m_genblkNum;
|
m_genblkAbove = m_genblkNum;
|
||||||
|
21
test_regress/t/t_gen_ifelse.pl
Executable file
21
test_regress/t/t_gen_ifelse.pl
Executable file
@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env perl
|
||||||
|
if (!$::Driver) { use FindBin; exec("$FindBin::Bin/bootstrap.pl", @ARGV, $0); die; }
|
||||||
|
# DESCRIPTION: Verilator: Verilog Test driver/expect definition
|
||||||
|
#
|
||||||
|
# Copyright 2021 by Wilson Snyder. 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
|
||||||
|
|
||||||
|
scenarios(simulator => 1);
|
||||||
|
|
||||||
|
compile(
|
||||||
|
);
|
||||||
|
|
||||||
|
execute(
|
||||||
|
check_finished => 1,
|
||||||
|
);
|
||||||
|
|
||||||
|
ok(1);
|
||||||
|
1;
|
35
test_regress/t/t_gen_ifelse.v
Normal file
35
test_regress/t/t_gen_ifelse.v
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
// DESCRIPTION: Verilator: Verilog Test module
|
||||||
|
//
|
||||||
|
// This file ONLY is placed under the Creative Commons Public Domain, for
|
||||||
|
// any use, without warranty, 2021 by Wilson Snyder.
|
||||||
|
// SPDX-License-Identifier: CC0-1.0
|
||||||
|
|
||||||
|
module s;
|
||||||
|
parameter A = 0;
|
||||||
|
generate
|
||||||
|
if (A == 1)
|
||||||
|
int i;
|
||||||
|
else if (A == 2)
|
||||||
|
int i;
|
||||||
|
else
|
||||||
|
int i;
|
||||||
|
endgenerate
|
||||||
|
generate
|
||||||
|
if (A == 1)
|
||||||
|
int i;
|
||||||
|
else if (A == 2)
|
||||||
|
int i;
|
||||||
|
else
|
||||||
|
int i;
|
||||||
|
endgenerate
|
||||||
|
endmodule
|
||||||
|
|
||||||
|
module t;
|
||||||
|
s #(0) s0();
|
||||||
|
s #(1) s1();
|
||||||
|
s #(2) s2();
|
||||||
|
initial begin
|
||||||
|
$write("*-* All Finished *-*\n");
|
||||||
|
$finish;
|
||||||
|
end
|
||||||
|
endmodule
|
Loading…
Reference in New Issue
Block a user